@charset "UTF-8";
/* CSS Document */
/*--------------------
01.共通
02.ヘッダー
03.フッター
04.下層ページ-共通
--------------------*/

/*----------
01.共通
----------*/

@font-face {
font-family: 'A-OTF-UDShinGoPro';
src:url('../font/A-OTF-UDShinGoPro-Regular.woff2') format('woff2'),
url('../font/A-OTF-UDShinGoPro-Regular.woff') format('woff'),
url('../font/A-OTF-UDShinGoPro-Regular.otf')  format('opentype'); /* ttf - Safari, Android, iOS */
font-weight: 400;
}
@font-face {
font-family: 'A-OTF-UDShinGoPro';
src:url('../font/A-OTF-UDShinGoPro-Medium.woff2') format('woff2'),
url('../font/A-OTF-UDShinGoPro-Medium.woff') format('woff'),
url('../font/A-OTF-UDShinGoPro-Medium.otf')  format('opentype'); /* ttf - Safari, Android, iOS */
font-weight: 500;
}
@font-face {
font-family: 'A-OTF-UDShinGoPro';
src:url('../font/A-OTF-UDShinGoPro-Bold.woff2') format('woff2'),
url('../font/A-OTF-UDShinGoPro-Bold.woff') format('woff'),
url('../font/A-OTF-UDShinGoPro-Bold.otf')  format('opentype'); /* ttf - Safari, Android, iOS */
font-weight: 700;
}


body{
-webkit-font-smoothing: antialiased;
}

*{
box-sizing: border-box;
}

*:focus {
outline: none;
}

#wrapper{
width: 100%;
overflow: hidden;
font-family: 'A-OTF-UDShinGoPro';
font-weight: 400;
font-size: 16px;
color: #333333;
}

.pc{
display: block;
}

.sp{
display: none;
}

.mini{
  display: none;
}

.contents_in{
width: 100%;
margin: 0 auto;
}

a{
color: #333;
}

a:hover{
color:#333;
}

a:link{
color:#333;
}

img{
width: 100%;
height: auto;
display: block;
}
.contents{
margin-top: 70px;
}
/*page top btn*/
#page-top a{
position: relative;
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
padding-bottom: 10px;
-webkit-box-align: end;
-ms-flex-align: end;
align-items: flex-end;
background:#fff;
border-radius: 50%;
width: 80px;
height: 80px;
border: 1px solid #109D99;
box-shadow: 0 0 10px rgba(0,0,0,0.15);
font-family: 'A-OTF-UDShinGoPro';
color: #109D99;
text-transform: uppercase; 
text-decoration: none;
font-size:13px;
line-height: 1.5;
font-weight: 500;
transition:all 0.3s;
}
#page-top a::after{
content: "";
position: absolute;
top: 15px;
left: 50%;
transform: translateX(-50%) rotate(-45deg);
width: 10px;
height: 10px;
border-top: 2px solid #109D99;
border-right: 2px solid #109D99;
}
#page-top a:hover{
opacity: 0.7;
}
#page-top {
position: fixed;
right: 20px;
bottom:10px;
z-index: 2;
opacity: 0;
transform: translateY(100px);
}
#page-top.UpMove{
animation: UpAnime 0.5s forwards;
}
@keyframes UpAnime{
from {
opacity: 0;
transform: translateY(140px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
#page-top.DownMove{
animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime{
from {
opacity: 1;
transform: translateY(0);
}
to {
opacity: 1;
transform: translateY(140px);
}
}
/*----------
02.ヘッダー
----------*/
header {
box-sizing: border-box;
background: #FFFFFF;
box-shadow: 0 4px 4px -4px #5C5C5C;
position: fixed;
top: 0;
width: 100%;
height: 70px;
left: 0;
z-index: 10;
}
header .contents_in {
display: flex;
align-items: center;
justify-content: space-between;
box-sizing: border-box;
padding: 14px 0;
width: 98%;
height: 70px;
max-width: 1040px;
position: relative;
}
header h1 a {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-align: end;
-ms-flex-align: end;
align-items: flex-end;
}
header h1 .cnt_img {
max-width: 230px;
}
header h1 p {
font-size: 18px;
color: #AAAAAA;
padding-left: 10px;
min-width: 200px;
}
nav {
float: left;
}
header .nav_in {
display: flex;
align-items: center;
margin-left: 50px;
width: 500px;
}
header .nav_in .menu_btn {
line-height: 50px;
}

header .nav_in li {
width: auto;
}

header .nav_in li:not(:last-child){
margin-right: 20px;
}

header .nav_in li a {
display: inline-block;
width: 100%;
color: #109D99;
font-size: 14px;
text-align: left;
margin: 0 auto;
}
header .nav_btn {
background-color: #109D99;
border-radius: 5px;
width: 180px;
padding: 10px;
margin: 0 50px 0 20px;
}
header .nav_btn a {
display: flex;
/* justify-content: flex-end; */
width: 120px;
margin: 0 auto;
}
header .nav_btn .cnt_img {
max-width: 25px;
display: none;
}
header .nav_btn p {
color: #FFFFFF;
padding: 2px 0 0 10px;
}
#top .mainimg {
background-color: #FFFFFF;
padding-top: 16px;
}
/* Submenu */
ul li ul {
position: absolute;
left: 0;
width: 100%;
background-color: #FFFFFF;
padding-top: 10px;
}
ul li ul li {
display: block;
}
ul li ul li a:hover {
background-color: #ddd;
}

header ul li ul{
display: none;
}
header ul li:hover ul {
display: block;
display: flex;
width: 100%;
position: absolute;
/*padding-top: 40px;*/
}
header .sub_menu {
display: flex;
justify-content: center;
height: 238px;
width: 1040px;
padding: 50px 0;
margin: 0 auto;
}

header .bg_gray {
background-color: #F7F7F7;
width: 100%;
}
header .sub_menu .sub_menu_btn {
border: solid #109D99 1px;
border-radius: 5px;
background-color: #FFFFFF;
width: 180px;
}
header .sub_menu .sub_menu_title {
font-size: 18px;
line-height: 18px;
margin-top: 18px;
text-align: center;
}
header .sub_menu .line02 .sub_menu_title {
line-height: 22px;
}
header .sub_menu .line02 .sub_menu_title span {
font-size: 14px;
line-height: 17px;
}
header .sub_menu .sub_menu_img {
display: flex;
margin: 25px 0;
}
header .sub_menu .line02 .sub_menu_img {
display: flex;
margin: 10px 0;
}
header .sub_menu .cnt_img {
width: 45px;
margin: 0 auto;
}
header .nav_in:last-child{
display: none;
}
/*----------
03.フッター
----------*/
footer{
padding: 30px 0 27px;
background: #F7F7F7;
text-align: center;
font-size: 14px;
font-weight: 500;
line-height: 2.2;
}
footer ul{
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: justify;
-ms-flex-pack: justify;
justify-content: space-between;
width: 662.71px;
margin: 0 auto;
}
footer ul li a{
position: relative;
}
footer ul li a::after{
content: "";
position: absolute;
bottom: 0;
right: -18px;
width: 13.71px;
height: 14px;
background: url("../../img/common/link_icon.png")no-repeat center / cover;
}
footer ul li a:hover{
opacity: 0.7;
cursor: pointer;
}
footer a:link{
color: #AAAAAA;
}
footer small{  
display: block;
margin-top: 12px;
color: #AAAAAA;
}

/*----------
04.下層ページ-共通
----------*/

/*----mv画像エリア----*/
.under_page .gallery{
margin:0 0 54px 0;
max-width:476px;
height: 476px;
}
.under_page .gallery img{
width:476px;
}
.under_page .gallery li{
list-style:none;
background-color: #fff;
}
.under_page .slide-dots li{
  background-color: transparent;
}
.under_page .gallery li.medal_logo{
position: relative;
}
.under_page .gallery li.medal_logo::after{
position: absolute;
content: '';
top: 30px;
right: 25px;
width: 21.01%;
height: 100px;
background: url(../../img/common/medal_gold.png)no-repeat center / contain;
}
.under_page .gallery li.medal_logo span, .under_page .gallery li.has_span span{
position: absolute;
bottom: 40px;
right: 0;
left: 0;
margin: auto;
font-family: 'A-OTF-UDShinGoPro';
font-size: 11px;
line-height: 1.5;
text-align: center;
font-weight: 500;
}
.under_page .choice-btn{
width: 476px;
}
.under_page .choice-btn li{
cursor: pointer;
outline: none;
background:#fff;
list-style:none;
width: 87px!important;
}
.under_page .choice-btn li:not(:last-child){
margin-right: 11px;
}
.under_page .choice-btn img{
max-width: 87px;
}
/*---dots---*/
.under_page .slide-dots{
position: absolute;
bottom: 20px;
list-style: none;
display: block;
text-align: center;
padding: 0;
margin: 0;
width: 100%;
}
.under_page .slide-dots li{
position: relative;
display: inline-block;
height: 20px;
width: 20px;
margin: 0 5px;
padding: 0;
cursor: pointer;
}
.under_page .slide-dots li.slick-active button::before{
color: #109D99;
}
.under_page .slide-dots li button{
background: transparent;   
border:0;   
font-size: 0pt; 
}
.under_page .slide-dots li button::before{
content: '●';
font-size: 10px;
text-indent: 0px;
width: 20px;
height: 20px;
position: absolute;
top: 0;
left: 0;
color: #AAAAAA;
font-family: "slick";
}
/*----mvテキストエリア-------*/
.under_page .item_visual{
background: #F7F7F7;
padding: 57px 0;
}
.under_page .cnt_g{
max-width: 1040px;
width: 96%;
margin: 0 auto;
}
.under_page .cnt_flex{
display:-webkit-box;
display:-ms-flexbox;
display:flex;
}
.under_page .cnt_flex .cnt_imgs{
margin-right: 78px;
}
.under_page .cnt_flex .ttl{
margin-bottom: 42px;
font-size: 30px;
line-height: 2;
color: #109D99;
font-weight: 500;
}
.under_page .cnt_flex .txt_area dl{
/* margin-bottom: 115px; */
margin-bottom: 50px;
}
.under_page .cnt_flex .txt_area .cnt_text{
  margin-bottom: 30px;
}
.under_page .cnt_flex .txt_area select{
appearance: none;
font-size: 20px;
padding: 5px 10px;
width: 85%;
white-space: break-spaces;
background-color: #fff;
color: #333;
border: 1px solid;
}
.under_page .cnt_flex .txt_area .form{
  display: flex;
  align-items: center;
  margin-bottom: 20px;
}
.under_page .cnt_flex .txt_area .form span{
  width: 15%;
  display: block;
}
.under_page .cnt_flex .txt_area .cnt_text a{
  text-decoration: underline;
}
.under_page .cnt_flex .txt_area dt,
.under_page .cnt_flex .quantity{
display: inline-block;
font-size: 20px;
line-height: 2.2;
}
.under_page .cnt_flex .txt_area dd{
display: inline-block;
}
.under_page .cnt_flex .price_down{
position: relative;
}
.under_page .cnt_flex .price_down::before{
position: absolute;
content: '';
top: 0px;
right: 210px;
width: 80px;
height: 80px;
background: url('../../img/outlet/outlet.png')no-repeat center / contain;
transform: rotate(-20deg);
}

.under_page .cnt_flex .price dd{
font-size: 30px;
font-weight: 500;
}
.under_page .cnt_flex .price dd span{
font-size: 14px;
font-weight: 400;
margin-left: 10px;
}
.under_page .cnt_flex .price .sale_p span{
font-size: 16px;
font-weight: 400;
margin-left: 10px;
}
.under_page .cnt_flex .price .sale_p{
margin-bottom: 20px;
font-size: 30px;
font-weight: 500;
}
.under_page .cnt_flex .price .original_p{
position: relative;
font-size: 20px;
}
.under_page .cnt_flex .price .original_p::after{
position: absolute;
content: "";
display: block;
background-color: red;
width: 100%;
height: 1px;
top: 50%;
left: 0;
}
.under_page .cnt_flex .code,
.under_page .cnt_flex .code dt{
margin-bottom: 20px;
font-size: 13px;
line-height: 1;
}


/*----下層ページ btn-------*/
.under_page .btn_add{
display: inline-block;
margin-bottom: 20px;
padding: 35px 0;
width: 100%;
max-width: 486px;
border-radius: 8px;
box-shadow: 0 0 10px rgba(0,0,0,0.1);
background: #109D99;
text-align: center;
}
.under_page .btn_add p{
position: relative;
display: inline-block;
padding-left: 30px;
color: #fff;
font-size: 20px;
font-weight: 500;
}
.under_page .cnt_flex .btn_add p::before{
content: "";
position: absolute;
top: 50%;
left: 0;
transform: translateY(-50%);
width: 26.85px;
height: 22.73px;
background: url("../../img/common/cart.png")no-repeat center / cover;
}
.under_page .cnt_flex .btn_fav{
display: inline-block;
padding: 19px 0;
width: 100%;
max-width: 257px;
border-radius: 8px;
box-shadow: 0 0 10px rgba(0,0,0,0.1);
background: #fff;
text-align: center;
}
.under_page .cnt_flex .btn_fav p{
position: relative;
display: inline-block;
padding-left: 30px;
color: #AAAAAA;
font-size: 14px;
font-weight: 400;
}
.under_page .cnt_flex .btn_fav p::before{
content: "";
position: absolute;
top: 50%;
left: 0;
transform: translateY(-50%);
width: 22.61px;
height: 19.23px;
background: url("../../img/common/heart_icon.png")no-repeat center / cover;
}
.under_page .btn_back{
display: inline-block;
padding: 19px 0;
width: 100%;
max-width: 307px;
border-radius: 8px;
border: 1px solid #109D99;
box-shadow: 0 0 10px rgba(0,0,0,0.1);
background: #fff;
text-align: center;
}
.under_page .btn_back p{
position: relative;
display: inline-block;
color: #109D99;
font-size: 20px;
font-weight: 500;
}
.under_page .btn_back p::before{
content: "";
position: absolute;
top: 50%;
left: -50px;
transform: translateY(-50%);
width: 28.48px;
height: 28.48px;
background: url("../../img/common/btn_back_arrow.png")no-repeat center / cover;
}
.under_page .item_info .btn_area{
text-align: center;
}

/*----商品説明-------*/
.under_page .item_info{
margin: 62px auto 84px;
width: 96%;
max-width: 1040px;
}
.under_page .item_info h3{
position: relative;
padding-bottom: 10px;
margin-bottom: 20px;
font-size: 26px;
line-height: 2.1;
font-weight: 500;
}
.under_page .item_info h3::after{
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 57.6px;
height: 3px;
background: #109D99;
}
.under_page .item_info .t_heading{
font-size: 26px;
line-height: 2.1;
font-weight: 500;
color: #109D99;
}
.under_page .item_info .t_body{
line-height: 1.75;
}
.under_page .item_info .t_body.fwb{
  font-weight: 500;
}
.under_page .item_info .cnt_box{
margin-bottom: 70px;
}
.under_page .item_info .cnt_box .cnt_package{
margin: 15px auto 0;
max-width: 800px;
width: 100%;
}
.under_page .dltable{
width: 630px; 
border-top: 1px solid #ddd; 
border-left: 1px solid #ddd; 
display:-webkit-box;
display:-ms-flexbox;
display: flex;
flex-wrap: wrap; 
}
.under_page .dltable dt,
.under_page .dltable dd{
border-bottom: 1px solid #ddd; 
border-right: 1px solid #ddd;
padding: 19px 0 19px 20px; 
}
.under_page .dltable dt{
width: 220px;
background: #EFEFEF;
}
.under_page .dltable dd{
width: calc(100% - 220px);
}
.under_page .dltable dd span{
font-size: 12px;
margin-left: 30px;
}
@media only screen and (max-width:1024px){
/*----------
01.共通
----------*/


/*----------
02.
----------*/


}
@media only screen and (max-width:960px){
/*----------
02.ヘッダー
----------*/
header .nav_in:last-child{
display: block;
}
header .nav_in:nth-child(2){
display: none;
}
header .contents_in{
max-width: none;
width: auto;
}

header h1{
float: none;
padding: 7px 0;
margin: 0 auto;
}
header .nav_in{
display: block;
background: #F7F7F7;
height: calc(100vh - 70px);
width: 100%;
padding: 0;
position: absolute;
left: -100%;
top: 70px;
}
header .nav_in li{
float: none;
position: relative;
width: 100%;
border-top: 1px solid #ddd;
}
header .nav_in li:last-child{
border-bottom: 1px solid #ddd;
}

header .nav_in li::after{
content: "";
z-index: 2;
position: absolute;
top: 50%;
right: 20px;
transform: translateY(-50%) rotate(180deg);
width: 22px;
height: 22px;
border-radius: 50%;
background: url("../../img/common/btn_back_arrow.png")no-repeat center / cover;
}
header .nav_in li::before{
content: "";
position: absolute;
z-index: 1;
top: 50%;
right: 20px;
transform: translateY(-50%);
width: 22px;
height: 22px;
background-color: #fff;
border-radius: 50%;
}
header .nav_in .cnt_flex{
display:-webkit-box;
display:-ms-flexbox;
display:flex;
}
header .nav_in .cnt_flex li:first-child{
border-right: 1px solid #ddd;
}
header nav .ham_btn{
width: 20px;
height: 14px;
position: absolute;
top: 50%;
left: 20px;
}
header nav .nav_line{
width: 20px;
border-top: 2px solid #AAAAAA;
display: inline-block;
transition: all .4s;
box-sizing: border-box;
position: absolute;
left:0;
right:0;
margin:0 auto;
}
header .ham_btn .nav_line01{
top:0px;
}
header .ham_btn .nav_line02{
top:6px;
}
header .ham_btn .nav_line03{
top:12px;
}
header .ham_btn.active .nav_line01{
-webkit-transform: translateY(6px) rotate(-45deg);
transform: translateY(6px) rotate(-45deg);
}
header .ham_btn .nav_line02.hover_line{
-webkit-transform: translateX(9px) rotate(0deg);
transform: translateX(9px) rotate(0deg);
}
header .ham_btn.active .nav_line02{
top:12px;
left: 50%;
opacity: 0;
-webkit-animation: active-menu-bar02 .8s forwards;
animation: active-menu-bar02 .8s forwards;
}
header .ham_btn.active .nav_line03{
-webkit-transform: translateY(-6px) rotate(45deg);
transform: translateY(-6px) rotate(45deg);
}
header .nav_in{
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
margin-left: 0;
overflow: auto;
}
header .contents_in{
position: relative;
justify-content: space-between;
padding: 11px 20px 0;
}
header h1 a{
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
padding-left: 30px;
}
header h1 p{
width: 100%;
padding: 12px 0 0 0;
font-size: 14px;
font-weight: 500;
text-align: center;
}
header h1 .img_area{
margin: 0 auto;
}
header .nav_btn a{
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
width: 100%;
}
header .nav_btn .cnt_img {
max-width: 14px;
}
header .nav_btn{
width: 79px;
min-width: 110px;
margin: 0;
}
header .nav_btn p{
padding: 0;
font-size: 12px;
}
header .nav_in li a{
padding: 30px 20px;
color: #333;
}
header .nav_in li a span{
margin-top: 8px;
font-size: 12px;
}
/*----------
04.下層ページ-共通
----------*/
.under_page .pc{
display: none;
}
.under_page .sp{
display: block;
}
.under_page .cnt_g{
width: 100%;
}
.contents {
margin-top: 70px;
}

/*--mv-*/
.under_page .cnt_flex{
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
}

.under_page .gallery{
margin: 0 auto 12px;
width: 100%;
height: 365px;
background: #fff;
}

.under_page .gallery li.medal_logo span, .under_page .gallery li.has_span span {
bottom: 10px;
}

.under_page .gallery img{
max-width: 306px;
margin: 0 auto;
}
.under_page .cnt_flex .cnt_imgs{
width: 100%;
}
.under_page .item_visual{
padding: 29px 0 40px;
}
.under_page .cnt_flex .ttl,
.under_page .cnt_flex .txt_area{
max-width: 476px;
margin: 0 auto;
}
.under_page .cnt_flex .txt_area{
text-align: center;
}
.under_page .cnt_flex .ttl{
margin-bottom: 26px;
font-size: 22px;
line-height: 1.6;
}
.under_page .cnt_flex .txt_area dl {
/* max-width: 200px; */
max-width: 335px;
margin: 20px auto 34px;
text-align: left;
}
.under_page .cnt_flex .pack_area dl{
margin: 20px auto 34px;
}
.under_page .cnt_flex .txt_area dt,
.under_page .cnt_flex .quantity{
font-size: 18px;
}
.under_page .cnt_flex .txt_area .code dt,
.under_page .cnt_flex .txt_area .code{
font-size: 12px;
}
.under_page .cnt_flex .price dd{
font-size: 28px;
}
.under_page .cnt_flex .price dd span{
font-size: 12px;
}
.under_page .cnt_flex .price_down::before {
right: -50px;
width: 60px;
height: 60px;
}

/*--btn-*/
.under_page .cnt_flex .btn_add{
max-width: 291px;
margin-bottom: 0;
padding: 26px 0;
}
.under_page .cnt_flex .btn_fav{
display: none;
}
.under_page .cnt_flex .btn_add p{
font-size: 16px;
}
.under_page .choice-btn{
margin: 0 auto;
}
/*--txt area-*/
.under_page .item_info{
margin: 42px auto 80px;
text-align: center;
}
.under_page .item_info h3{
display: inline-block;
margin-bottom: 20px;
font-size: 20px;
}
.under_page .item_info h3::after {
bottom: 0;
left: 50%;
transform: translateX(-50%);
width: 57.6px;
height: 3px;
background: #109D99;
}
.under_page .item_info .t_heading{
margin-bottom: 19px;
font-size: 20px;
line-height: 1.8;
}
.under_page .item_info .t_body{
text-align: left;
}
.under_page .item_info .cnt_box{
margin-bottom: 82px;
}
.under_page .item_info .cnt_box:nth-child(2){
margin-bottom: 40px;
}
/*----table----*/
.under_page .dltable{
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
width: 94%;
margin: 0 auto;
font-size: 14px;
}
.under_page .dltable dt,
.under_page .dltable dd{
width: 100%;
}
.under_page .dltable dt{
padding: 8px 0;
font-weight: 500;
}
.under_page .dltable dd{
padding: 20px 0;
}
.under_page .dltable dd span{
display: inline-block;
margin: 12px auto 0;
font-size: 12px;
line-height: 1.5;
}
}

@media only screen and (max-width:768px){

/*----------
01.共通
----------*/

.pc{
display: none;
}

.sp{
display: block;
}

.contents_in{
width: 94%;
}


/*----------
03.フッター
----------*/
footer{
padding: 28px 0 9px;
font-size: 12px;
line-height: 2.1;
}
footer ul{
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
width: 100%;
}
footer ul li:not(:last-child){
margin-bottom: 28px;
}

footer small{  
display: block;
margin-top: 44px;
color: #AAAAAA;
font-weight: 400;
}

.under_page .gallery li.medal_logo span, .under_page .gallery li.has_span span{
bottom: 0;
}
/*----------
04.下層ページ-共通
----------*/
.under_page .cnt_flex .ttl{
  text-align: left;
  max-width: 335px;
  margin: 0 auto;
}
.under_page .cnt_flex .txt_area select {
  font-size: 16px;
  width: 80%;
}
.under_page .cnt_flex .txt_area .form span{
  width: 20%;
}
.under_page .cnt_flex .txt_area .cnt_text {
  font-size: 15px;
}
}

@media only screen and (max-width:425px) {
  .mini{
    display: block;
  }
}