@charset "utf-8";

/* common
================================================== */
.Noto_Sans {
font-family: 'Noto Sans JP', sans-serif;
}
.Noto_Serif {
font-family: 'Noto Serif JP', serif;
}
.shippori_mincho {
font-family: "Shippori Mincho", serif;
}
.Lato {
font-family: 'Lato', sans-serif;
}
.inter {
font-family: 'Inter', sans-serif;
}

#contents {
font-family: 'Inter','Noto Sans JP', sans-serif;
font-weight: 400;
width: auto;
font-feature-settings: "palt";
-webkit-font-feature-settings: "palt";
letter-spacing: 0.05em;
}

#pageBody {
zoom: 100%;
background: none;
margin: 0 auto 0 auto;
width: 375px;
overflow: hidden;
}

#contents a:hover,
#contents a:hover img {
filter: alpha(opacity=100);
-moz-opacity:1.0;
opacity:1.0;
}

/****************************************
#mainVisual
*****************************************/
#mainVisual {
text-align: center;
}
#mainVisual .vis {
position: relative;
background: url(../img/title_bg.jpg) no-repeat center top;
background-size: 375px 650px;
margin: 0 auto;
width: 375px;
height: 650px;
overflow: hidden;
}
#mainVisual h1 {
box-sizing: border-box;
position: absolute;
left: 0;
top: 27px;
padding-left: 18px;
width: 100%;
text-align: center;
}
#mainVisual .vis ul {
margin: 0 auto;
padding-top: 473px;
width: 330px;
}
#mainVisual ul li {
margin-bottom: 15px;
}
#mainVisual ul li a {
box-sizing: border-box;
display: block;
position: relative;
background-color: #fff;
border: solid 2px #009999;
border-radius: 8px;
padding: 12px 24px 8px 24px;
font-weight: 500;
font-size: 18px;
line-height: 1.32;
text-decoration: none;
text-align: left;
color: #000;
}
#mainVisual ul li a::after {
transform: translateY(-50%) rotate(45deg);
content: '';
display: block;
box-sizing: border-box;
position: absolute;
right: 20px;
top: 50%;
margin-top: -3px;
border-right: solid 2px #000;
border-bottom: solid 2px #000;
width: 13px;
height: 13px;
}
#mainVisual ul li span {
font-size: 14px;
color: #009999;
}
.campaignBanner {
box-sizing: border-box;
display: flex;
flex-direction: column;
align-items: center;
background: linear-gradient(to right, #eebb66, #eebb66);
margin: 0;
padding: 25px 0 0 0;
width: 375px;
height: 185px;
text-align: left;
}
.campaignBanner h3 {
display: flex;
flex-wrap: wrap;
align-items: center;
margin-bottom: 11px;
font-weight: 400;
font-size: 21px;
line-height: 1;
letter-spacing: 0;
color: #553322;
}
.campaignBanner .period {
display: flex;
flex-wrap: wrap;
align-items: center;
margin-bottom: 17px;
font-weight: 400;
font-size: 36px;
line-height: 1;
color: #553322;
}
.campaignBanner .period strong {
font-weight: 400;
margin-right: 15px;
}
.campaignBanner .period i {
display: flex;
justify-content: center;
align-items: center;
background-color: #553322;
border-radius: 50%;
margin: 0 5px;
width: 30px;
height: 30px;
font-weight: 400;
font-style: normal;
font-size: 16px;
color: #fff;
}
.campaignBanner .button {
display: block;
}
.campaignBanner .button a {
position: relative;
box-sizing: border-box;
display: flex;
justify-content: center;
align-items: center;
background-color: #ffee77;
border-radius: 6px;
padding-right: 16px;
width: 280px;
height: 50px;
font-weight: 500;
font-size: 20px;
letter-spacing: 0;
text-decoration: none;
color: #664433;
}
.campaignBanner .button a:hover {
background-color: #ff8800;
color: #fff;
}
.campaignBanner .button a img {
position: absolute;
left: -32px;
top: -14px;
}
.campaignBanner .button a span {
transform: translateY(-50%);
position: absolute;
right: 16px;
top: 50%;
}



/****************************************
#SCT1-5
*****************************************/
.section .item {
position: relative;
padding-bottom: 50px;
}
.section .item .list {
margin: 0 auto;
width: 330px;
text-align: left;
}
.section .item .block {
margin-bottom: 40px;
}
#LINEUP .item .block {
margin: 0 auto 0 auto;
width: 330px;
}
.section .item .block:last-child {
margin-bottom: 0;
}
.section .itm .pack,
.section .item .pack {
margin-left: 72px;
float: left;
}
.section .itm h4,
.section .item h4 {
margin-bottom: 0;
font-weight: 400;
font-size: 16px;
line-height: 1.44;
}
.section .itm h4 span,
.section .item h4 span {
font-size: 12px;
font-weight: normal;
}
.section .itm .cnt,
.section .item .cnt {
font-size: 12px;
line-height: 1.68;
}
.section .itm .price,
.section .item .price {
padding-top: 6px;
font-size: 14px;
line-height: 1.35;
font-weight: bold;
}
.section .itm .price strong,
.section .item .price strong {
font-size: 14px !important;
font-weight: bold;
}
.section .itm .price span,
.section .item .price span {
font-weight: bold;
}
.section .itm .special,
.section .item .special {
padding-top: 4px;
}
.section .itm .special .price,
.section .item .special .price {
padding-top: 0;
font-size: 12px;
font-weight: bold;
line-height: 1.45;
color: #cc0000;
}
.section .itm .special .price strong,
.section .item .special .price strong {
font-size: 22px !important;
font-weight: bold;
}
.section .itm .special .price span,
.section .item .special .price span {
font-weight: bold;
}
.section .itm .special .normal,
.section .item .special .normal {
font-size: 12px;
}
.section .itm .more,
.section .item .more {
margin-top: 17px;
display: flex;
align-items: center;
}
.section .itm .link,
.section .item .link {
font-family: dnp-shuei-mgothic-std, sans-serif;
font-weight: 600;
font-style: normal;
font-size: 14px;
line-height: 30px;
letter-spacing: 0;
text-align: center;
}
.section .itm .link a,
.section .item .link a {
box-sizing: border-box;
display: block;
position: relative;
background-color: #ffcc33;
border-radius: 15px;
padding-right: 9px;
width: 140px;
height: 30px;
color: #000;
}
.section .itm .link a::after,
.section .item .link a::after {
transform: translateY(-50%);
content: "\f054";
position: absolute;
right: 9px;
top: 50%;
font-family: "Font Awesome 5 Free";
font-weight: 900;
font-size: 12px;
color: #ff6600;
}
.section .itm .link a:hover,
.section .item .link a:hover {
background-color: #ff8800;
color: #fff;
text-decoration: none;
}
.section .itm .link a:hover::after,
.section .item .link a:hover::after {
color: #fff;
}
.section .itm .number,
.section .item .number {
display: flex;
flex-wrap: wrap;
margin: 0 0 12px 0;
line-height: 21px;
text-align: center;
}
.section .itm .number dt,
.section .item .number dt {
background-color: #000;
border-right: none;
border: solid 1px #000;
border-radius: 3px 0 0 3px;
width: 60px;
font-size: 11px;
color: #fff;
}
.section .itm .number dd,
.section .item .number dd {
background-color: #fff;
border: solid 1px #000;
border-radius: 0 3px 3px 0;
border-left: none;
padding: 0 4px;
min-width: 42px;
font-size: 12px;
}
.section .item .note {
margin: 20px auto 0 auto;
width: 285px;
font-size: 11px;
line-height: 1.83;
text-align: left;
}
.section .item .btn {
box-sizing: border-box;
background-color: #f5c8cc;
border-radius: 12px;
margin: 40px auto 0 auto;
padding: 18px 15px 18px 15px;
width: 330px;
text-align: center;
}
.section .item .btn a {
display: block;
background-color: #fff588;
border-radius: 8px;
margin-top: 15px;
font-size: 24px;
font-weight: bold;
line-height: 60px;
color: #664444;
}

/* #Explan
================================================== */
#Explan {}
#Explan .cont {
}
#Explan .head {
position: relative;
margin: 0 auto;
padding: 48px 0 47px 0;
width: 330px;
text-align: center;
}
#Explan .head::before {
content: '';
display: block;
position: absolute;
left: -6px;
top: 58px;
background: url("../img/icn_mint1.png") no-repeat center center;
background-size: cover;
width: 336px;
height: 104px;
}
#Explan h2 {
margin-bottom: 23px;
font-weight: 400;
font-size: 34px;
line-height: 1.41;
}
#Explan h2 span {
display: inline-block;
margin-bottom: 3px;
font-family: 'Noto Serif JP', serif;
font-size: 24px;
line-height: 1.38;
color: #009999;
}
#Explan p {
font-size: 15px;
line-height: 2;
text-align: left;
}
#Explan .recommend {
position: relative;
background: url("../img/exp_reco_bg.png") repeat center center;
background-size: 30px auto;
margin: 0 0 48px 0;
padding: 38px 37px 28px 37px;
}
#Explan .recommend::before {
content: '';
display: block;
position: absolute;
left: 0;
top: 5px;
bottom: 5px;
right: 0;
border-top: solid 1px #669900;
border-bottom: solid 1px #669900;
}
#Explan .recommend::after {
content: '';
display: block;
position: absolute;
right: 17px;
top: 143px;
background: url("../img/icn_mint2.png") no-repeat center center;
background-size: cover;
width: 80px;
height: 52px;
}
#Explan .recommend h3 {
margin-bottom: 15px;
font-weight: 400;
font-size: 16px;
line-height: 30px;
text-align: center;
}
#Explan .recommend h3 span {
display: inline-block;
background-color: #fff;
margin-right: 5px;
padding: 0 5px;
font-size: 24px;
color: #009999;
}
#Explan .recommend li {
margin-bottom: 11px;
padding: 0 0 0 27px;
position: relative;
font-size: 16px;
line-height: 1.5;
text-align: left;
}
#Explan .recommend li::before {
content: '';
display: block;
position: absolute;
left: 0;
top: 4px;
background: url("../img/exp_reco_icn.png") no-repeat center center;
background-size: cover;
width: 18px;
height: 16px;
}
#Explan .list {
margin: 0 auto;
padding-bottom: 5px;
width: 330px;
text-align: left;
}
#Explan .list .block {
margin-bottom: 60px;
}
#Explan .block:nth-of-type(3) {
margin-bottom: 50px;
}
#Explan .list p.point {
position: relative;
display: inline-block;
border: solid 1px #ee8866;
border-radius: 99999px;
margin-bottom: 12px;
padding: 0 20px; 
font-size: 12px;
line-height: 28px;
letter-spacing: 0;
color: #ee8866;
}
#Explan .list p.point::before {
content: '';
display: block;
position: absolute;
left: 40px;
top: 30px;
background: url("../img/bln_lin.png") no-repeat center center;
background-size: cover;
width: 10px;
height: 10px;
}
#Explan .list p.point span {
font-weight: 600;
font-size: 16px;
}
#Explan .list h3 {
margin-bottom: 25px;
white-space: nowrap;
font-weight: 400;
font-size: 19px;
line-height: 32px;
letter-spacing: 0;
color: #009999;
}
#Explan .list h3 strong {
font-weight: 600;
font-size: 28px;
}
#Explan .block:nth-of-type(1) h3 strong:nth-of-type(1) {
background: url("../img/exp_marker1-1.png") no-repeat center bottom;
background-size: 100% auto;
}
#Explan .block:nth-of-type(1) h3 strong:nth-of-type(2) {
background: url("../img/exp_marker1-2.png") no-repeat center bottom;
background-size: 100% auto;
}
#Explan .block:nth-of-type(2) h3 strong {
background: url("../img/exp_marker2.png") no-repeat center bottom;
background-size: 100% auto;
}
#Explan .block:nth-of-type(3) h3 strong {
background: url("../img/exp_marker3.png") no-repeat center bottom;
background-size: 100% auto;
}
#Explan .list p {
margin-bottom: 17px;
font-size: 15px;
line-height: 1.89;
}
#Explan .block:nth-of-type(2) ul {
display: flex;
flex-wrap: wrap;
margin-bottom: -5px;
padding-top: 6px;
gap: 0 30px;
}
#Explan .block:nth-of-type(2) li {
display: block;
font-size: 13px;
text-align: center;
}
#Explan .block:nth-of-type(2) img {
display: block;
margin-bottom: 8px;
}
#Explan .block .image {
text-align: center;
}
#Explan .block .image figure {
position: relative;
margin: 0 auto;
width: 214px;
}
#Explan .block .image figure figcaption {
position: absolute;
right: 0;
bottom: -27px;
font-size: 10px;
}
#Explan .block .image p {
margin: 16px 0 6px 0;
font-size: 12px;
line-height: 1.67;
text-align: center;
}
#Explan .block:last-child .image p {
text-align: left;
}
#Explan .block:nth-of-type(3) .image {
padding-top: 16px;
}

/* .itemSCT
================================================== */
#Item1 {
margin-bottom: 55px;
}
#Item2 {
margin-bottom: 55px;
}
#Item1 .hed {
position: relative;
background: url("../img/itm1_bg.jpg") no-repeat center top;
background-size: 375px auto;
margin-bottom: 40px;
height: 690px;
text-align: left;
}
#Item2 .hed {
position: relative;
background: url("../img/itm2_bg.jpg") no-repeat center center;
background-size: 375px auto;
margin-bottom: 40px;
height: 690px;
text-align: left;
}
#Item2 .hed h2,
#Item1 .hed h2 {
z-index: 1;
box-sizing: border-box;
position: absolute;
left: 35px;
top: 47px;
background-color: #fff;
border: solid 1px #009999;
padding: 11px 15px;
font-weight: 500;
font-family: 'Noto Serif JP', serif;
font-size: 15px;
line-height: 1.2;
letter-spacing: 0;
}
#Item2 .hed h2 {
top: 60px;
padding: 12px 15px;
}
#Item2 .hed h2::before,
#Item1 .hed h2::before {
content: '';
display: block;
position: absolute;
left: 2px;
top: 2px;
bottom: 2px;
right: 2px;
border: solid 1px #009999;
}
#Item1 .hed h2::after {
content: '';
display: block;
position: absolute;
left: -13px;
top: -27px;
background: url("../img/itm1_tcg.png") no-repeat center center;
background-size: cover;
width: 96px;
height: 47px;
}
#Item2 .hed h2::after {
content: '';
display: block;
position: absolute;
left: -13px;
top: -42px;
background: url("../img/itm2_tcg.png") no-repeat center center;
background-size: cover;
width: 107px;
height: 52px;
}
#Item2 .hed .catch,
#Item1 .hed .catch {
z-index: 1;
position: absolute;
left: 40px;
top: 122px;
box-sizing: border-box;
font-weight: 600;
font-size: 22px;
line-height: 1.6;
letter-spacing: 0;
}
#Item2 .hed .catch {
left: 33px;
}
#Item2 .hed .compo,
#Item1 .hed .compo {
z-index: 1;
box-sizing: border-box;
position: absolute;
left: 12.5px;
right: 12.5px;
bottom: 15px;
background-color: #fff;
padding: 11px 12px;
font-size: 12px;
line-height: 1.59;
letter-spacing: 0;
}

.section .component .box {
background-color: #d9ddbe;
padding: 34px 20px 2px 20px;
}
.section .component .list {}
.section .component .blk {
margin-bottom: 9px;
}
.section .component h3 {
margin-bottom: 26px;
font-weight: 400;
font-family: 'Noto Serif JP', serif;
font-size: 24px;
line-height: 1.34;
text-align: center;
}
.section .component h4 {
background-color: #fff;
margin-bottom: 24px;
font-weight: 700;
font-size: 16px;
line-height: 28px;
text-align: center;
}
#Item1 .component ul,
#Item2 .component ul {
display: flex;
flex-wrap: wrap;
gap: 0 30px;
margin: 0 auto;
width: 270px;
}
.section .component li {
margin-bottom: 22px;
font-size: 13px;
line-height: 18px;
letter-spacing: 0;
text-align: center;
}
.section .component li span {
font-size: 11px;
}
.section .component img {
display: block;
margin-bottom: 8px;
}
.section .component p {
border-bottom: solid 1px #ccc;
padding: 17px;
font-size: 13px;
letter-spacing: 0.05em;
text-align: center;
}
#Item1 .explan .block {
margin: 0 auto;
padding: 50px 0 0 0;
width: 330px;
}
#Item1 .block .image {
margin-bottom: 52px;
text-align: center;
}
#Item1 .block .image img {
display: block;
margin: 0 auto;
}
#Item1 .block .img {
position: relative;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
#Item1 .block .img::before {
content: '';
display: block;
position: absolute;
left: 161px;
top: 58px;
border-left: solid 8px #009999;
border-bottom: solid 6px transparent;
border-top: solid 6px transparent;
}
#Item1 .explan .block h3 {
margin-bottom: 21px;
font-weight: 600;
font-size: 20px;
line-height: 1.5;
text-align: center;
color: #009999;
}
#Item1 .block .img p {
position: relative;
width: 150px;
font-size: 13px;
line-height: 1.70;
text-align: left;
}
#Item1 .block .img p::before {
content: 'Before';
position: absolute;
left: -5px;
top: -12px;
background-color: #666;
border-radius: 50%;
width: 52px;
height: 52px;
font-weight: 700;
font-family: 'Lato','Noto Sans JP', sans-serif;
font-size: 12px;
line-height: 52px;
text-align: center;
color: #fff;
}
#Item1 .block .img p:nth-of-type(1)::before {
content: 'Before';
background-color: #666;
}
#Item1 .block .img p:nth-of-type(2)::before {
content: 'After';
background-color: #000;
}
#Item1 .block .img img {
display: block;
margin-bottom: 10px;
}
#Item2 .explan .block {
margin: 0 auto;
padding: 40px 0 0 0;
width: 330px;
text-align: left;
}
#Item2 .explan .block h3 {
margin-bottom: 13px;
font-weight: 600;
font-size: 20px;
line-height: 1.5;
text-align: center;
color: #009999;
}
#Item2 .explan .block p {
margin-bottom: 23px;
font-size: 15px;
line-height: 1.87;
}
#Item2 .explan .block .image p {
margin: 20px 0 0 0;
font-size: 12px;
line-height: 1.67;
}

/* .Story
================================================== */
#Story {
box-sizing: border-box;
position: relative;
background: url("../img/sty_bg.jpg") repeat center center;
background-size: 375px auto;
}
#Story .cont {
margin: 0 auto;
padding: 33px 0 40px 0;
width: 330px;
}
#Story .ctg {
position: relative;
margin-bottom: 14px;
font-weight: 600;
font-family: 'Noto Serif JP', serif;
font-size: 12px;
line-height: 1.2;
text-align: center;
}
#Story .ctg span {
position: relative;
background: url("../img/sty_bg.jpg") repeat center center;
background-size: 375px auto;
padding: 0 2px;
z-index: 1;
}
#Story .ctg::before {
transform: translateY(-50%);
content: '';
position: absolute;
left: 0;
top: 50%;
border-top: double #000;
width: 100%;
}
#Story h2 {
margin-bottom: 17px;
font-weight: 600;
font-family: 'Noto Serif JP', serif;
font-size: 30px;
line-height: 1.2;
color: #009999;
text-align: center;
}
#Story .catch {
margin-bottom: 28px;
font-weight: 600;
font-family: 'Noto Serif JP', serif;
font-size: 16px;
line-height: 24px;
text-align: center;
}
#Story .catch span {
background-color: #fff;
padding: 0 12px;
}
#Story .credit {
position: absolute;
left: 94px;
top: 81px;
width: 135px;
font-size: 14px;
line-height: 1.43;
text-align: center;
}
#Story .exp {
font-size: 15px;
line-height: 1.87;
text-align: left;
}
#Story .exp img {
position: relative;
left: -3px;
margin: -11px 0 10px 20px;
float: right;
}
#Story .exp p {
margin-bottom: 20px;
}
#Story .exp p:last-child {
margin-bottom: 15px;
}

#LINEUP {
background-color: #d1eded;
padding-bottom: 0;
}
#LINEUP .head {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
margin: 0 auto;
padding: 58px 0 18px 0;
width: 330px;
}
#LINEUP .head .bubble {
position: relative;
margin-bottom: 4px;
font-weight: 500;
font-size: 18px;
line-height: 1.2;
}
#LINEUP .head .bubble::before {
transform: rotate(-30deg);
content: '';
position: absolute;
left: -15px;
bottom: 0;
background-color: #009999;
width: 1px;
height: 30px;
}
#LINEUP .head .bubble::after {
transform: rotate(30deg);
content: '';
position: absolute;
right: -15px;
bottom: 0;
background-color: #009999;
width: 1px;
height: 30px;
}
#LINEUP .head h2 {
margin-bottom: 10px;
font-weight: 500;
font-size: 28px;
line-height: 1.2;
color: #009999;
}
#LINEUP .head .lead {
font-size: 15px;
line-height: 1.8;
}
#LINEUP .item {
display: flex;
flex-direction: column;
gap: 36px;
margin-top: 56px;
padding-bottom: 60px;
}
#LINEUP .item::after {
display: none;
}
#LINEUP .item .block {
display: flex;
}
#LINEUP .item .image {
width: 115px;
}
#LINEUP .item .text {
flex: 1;
}
#LINEUP .item .text h3 {
margin-bottom: 2px;
font-weight: 500;
font-size: 16px;
line-height: 1.38;
}
#LINEUP .item .text p {
font-size: 14px;
line-height: 1.72;
}
#LINEUP .item .text p span {
font-size: 12px;
}


#contents .banner {
background-color: #f5c8cc;
text-align: center;
}
#contents .banner a {
display: block;
}