@charset "utf-8";
/* CSS Document */

/****************************************
clearfix
*****************************************/
.cf:before,
.cf:after {
display: table;
content: "";
}
.cf:after {
clear: both;
}
.cf {
zoom: 1;
}
.section .component:after,
.section .item:after,
.cols:after {
content: ".";
display: block;
height: 0;
clear: both;
visibility: hidden;
}
.section .component,
.section .item,
.cols {
zoom: 1;
}

.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;
font-feature-settings: "palt";
-webkit-font-feature-settings: "palt";
letter-spacing: 0.05em;
text-align: left;
}
#pageBody {
background: none;
zoom: 100%;
overflow: hidden;
}

.section .item {
position: relative;
display: flex;
flex-direction: column;
gap: 40px;
margin-bottom: 35px;
}
.section .item::after {
display: none;
}
.section .item h4 {
margin-bottom: 8px;
width: 100%;
font-size: 16px;
font-weight: 700;
line-height: 1.38;
}
.section .item h4 span {
display: inline-block;
margin: 7px 0 -5px 0;
font-size: 13px;
font-weight: 400;
}
.section .item .cnt {
margin-bottom: 4px;
font-size: 13px;
line-height: 1.35;
}
.section .item p.price {
padding-top: 4px;
font-weight: 600;
font-size: 14px;
line-height: 1.35;
letter-spacing: 0;
}
.section .item p.price strong {
font-size: 20px !important;
}
.section .item div.price {
position: relative;
}
.section .item div.price .special {
margin-bottom: 5px;
font-weight: 600;
font-size: 15px;
line-height: 1.30;
color: #ee0000;
}
.section .item div.price .special span {
font-size: 24px;
}
.section .item div.price .normal {
margin-top: -3px;
font-size: 13px;
}
.section .item .more {
display: flex;
flex-wrap: wrap;
align-items: center;
margin-top: 16px;
}
.section .item .lnk {
font-family: dnp-shuei-mgothic-std, sans-serif;
font-weight: 500;
font-style: normal;
font-size: 13px;
line-height: 30px;
letter-spacing: 0;
text-align: center;
}
.section .item .lnk a {
box-sizing: border-box;
display: block;
position: relative;
background-color: #ffcc33;
border-radius: 9999px;
padding-right: 9px;
width: 130px;
height: 30px;
color: #000;
}
.section .item .lnk a::after {
transform: translateY(-50%);
content: "\f054";
position: absolute;
right: 10px;
top: 50%;
font-family: "Font Awesome 5 Free";
font-weight: 900;
font-size: 10px;
color: #ff6600;
}
.section .item .lnk a:hover {
background-color: #ff8800;
color: #fff;
text-decoration: none;
}
.section .item .lnk a:hover::after {
color: #fff;
}
.section .item .number {
display: flex;
flex-wrap: wrap;
margin: 0 0 11px 0;
line-height: 21px;
text-align: center;
}
.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 .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 .off {
box-sizing: border-box;
position: absolute;
right: 14px;
top: -10px;
background-color: #ee0000;
border-radius: 50%;
padding-top: 19px;
width: 80px;
height: 80px;
letter-spacing: 0;
line-height: 1.1;
font-size: 16px;
text-align: center;
color: #fff;
}
.section .item .off span {
font-weight: 500;
font-size: 27px;
}
.section .item .btn {
position: absolute;
right: 30px;
bottom: 30px;
box-sizing: border-box;
background-color: #f58811;
border-radius: 10px;
padding: 20px 0 20px 0;
width: 320px;
text-align: center;
}
.section .item .btn a {
display: block;
margin: 18px auto 0 auto;
background-color: #fff588;
border-radius: 5px;
width: 280px;
height: 54px;
font-family: dnp-shuei-mgothic-std, sans-serif;
font-weight: 600;
font-style: normal;
font-size: 24px;
line-height: 54px;
letter-spacing: 0;
text-align: center;
color: #553322;
}
.section .item .btn a:hover {
background-color: #553322;
color: #fff;
text-decoration: none;
}

/* #mainVisual
================================================== */
#mainVisual {
position: relative;
margin: 0 auto 0 auto;
width: 375px;
font-size: 0;
line-height: 0;
}
#mainVisual .title {}
#mainVisual .btn img {
display: block;
width: 100%;
height: auto;
}

/* mainContents section
================================================== */
#contents .banner a:hover img,
#mainVisual a:hover img {
filter: alpha(opacity=100);
-moz-opacity:1.0;
opacity:1.0;
}

/* #LEAD
================================================== */
#LEAD .cont {}
#LEAD .pack {
padding: 50px 0;
text-align: center;
}
#LEAD p {
font-weight: 200;
font-family: 'Noto Serif JP', serif;
font-size: 16px;
line-height: 3.44;
letter-spacing: 0.3em;
color: #644734;
}

/* #CATCH
================================================== */
#CATCH {
background-color: #dad2c8;
}
#CATCH .cont {
margin: 0 auto;
padding: 65px 0 60px 0;
width: 330px;
}
#CATCH h2 {
margin-bottom: 45px;
}
#CATCH .list {
display: flex;
flex-direction: column;
gap: 25px;
width: 100%;
}
#CATCH .list::after {
display: none;
}
#CATCH h4 {
margin-bottom: 10px;
font-weight: 400;
font-size: 18px;
text-align: center;
}
#CATCH ul {
display: flex;
gap: 5px;
}
#CATCH li {
flex: 1;
display: flex;
justify-content: center;
align-items: center;
background-color: #ece7e1;
border-radius: 4.5px;
height: 55px;
font-size: 15px;
}
#CATCH .block:nth-of-type(2) li {
height: 60px;
}

/* #ITEM
================================================== */
#ITEM {
background-color: #e5dfd7;
}
#ITEM .btn {
text-align: center;
}
#ITEM .cont {
}
#ITEM .itemBlock {
margin: 0 auto;
padding: 60px 0 50px 0;
width: 330px;
}
#ITEM .itemBlock .head {
margin-bottom: 37px;
text-align: center;
}
#ITEM .itemBlock .head img {
display: block;
margin: 0 auto;
}
#ITEM .itemBlock .head .shoulder {
margin-bottom: 39px;
}
#ITEM .itemBlock .head p {
margin: 36px auto 0 auto;
width: 300px;
font-size: 15px;
line-height: 1.8;
text-align: left;
}
#ITEM .itemBlock .item {
box-sizing: border-box;
padding: 160px 0 0 170px;
height: 400px;
text-align: left;
}
#ITEM1 .item {
background: url("../img/itm1_main.jpg") no-repeat left top;
background-size: 330px auto;
}
#ITEM2 .item {
background: url("../img/itm2_main.jpg") no-repeat left top;
background-size: 330px auto;
}
#ITEM3 .item {
background: url("../img/itm3_main.jpg") no-repeat left top;
background-size: 330px auto;
}
#ITEM .itemBlock .component {
margin-bottom: 70px;
}
#ITEM .itemBlock .component ul {
position: relative;
display: flex;
flex-wrap: wrap;
gap: 18px 0;
justify-content: space-between;
z-index: 1;
}
#ITEM .itemBlock .component h3 {
margin-bottom: 25px;
font-weight: 500;
font-size: 20px;
text-align: center;
color: #553322;
}
#ITEM .itemBlock .component li {
width: 155px;
font-size: 13px;
line-height: 22px;
text-align: center;
}
#ITEM .itemBlock .component li span {
font-weight: 500;
font-size: 15px;
}
#ITEM .itemBlock .component img {
display: block;
margin: 0 auto 9px auto;
border-radius: 50%;
}
#ITEM .itemBlock .component .wide {
padding-top: 12px;
width: 100%;
}
#ITEM .itemBlock .component .wide img {
position: relative;
display: block;
margin: -16px auto 0 auto;
border-radius: 0;
z-index: -1;
}
#ITEM .itemBlock .voice {
position: relative;
background-color: #ece7e1;
border-radius: 7.5px;
padding: 24px 25px 24px 25px;
}
#ITEM .itemBlock .voice h4 {
display: flex;
justify-content: center;
align-items: center;
position: absolute;
left: -5px;
top: -53px;
background-color: #fff;
border-radius: 50%;
width: 70px;
height: 70px;
font-weight: 400;
font-family: 'Inter', sans-serif;
font-size: 15px;
line-height: 18px;
letter-spacing: 0;
text-align: center;
color: #553322;
}
#ITEM .itemBlock .voice h4::before {
transform: translate(-15px,-20px) rotate(-45deg);
content: "";
position: absolute;
top: 100%;
left: 100%;
border: 9px solid transparent;
border-top: 17px solid #fff;
}
#ITEM .itemBlock .voice p {
font-size: 15px;
line-height: 1.8;
text-align: left;
}
#ITEM .newItem {
background-color: #fff;
padding: 60px 0 55px 0;
}
#ITEM .newItem .head {
margin-bottom: 28px;
text-align: center;
}
#ITEM .newItem .head p {
margin-top: 18px;
font-weight: 600;
font-size: 20px;
line-height: 1.6;
}
#ITEM .newItem .image {
margin: 0 auto 34px auto;
width: 330px;
}
#ITEM .newItem .item {
margin: 0 auto;
width: 330px;
text-align: left;
}
#ITEM .newItem .set {
text-align: left;
font-size: 14px;
line-height: 1.72;
}
#ITEM .newItem .item {
flex-direction: column;
align-items: flex-end;
gap: 23px;
}

/* #Quality
================================================== */
#Quality  {
background: url("../img/pow_bg.png") repeat center center;
background-size: 30px auto;
}
#Quality .cont {
box-sizing: border-box;
position: relative;
margin: 0 auto;
padding: 51px 0 56px 0;
width: 330px;
}
#Quality .cont::after {
display: none !important;
}
#Quality h2 {
margin-bottom: 19px;
font-weight: 300;
font-family: 'Noto Serif JP', serif;
font-size: 30px;
line-height: 1.4;
white-space: nowrap;
letter-spacing: -0.05em;
color: #ee6600;
text-align: center;
}
#Quality p {
margin-bottom: 31px;
font-size: 15px;
line-height: 1.87;
text-align: left;
}
#Quality ol {
display: flex;
flex-direction: column;
gap: 57px;
margin: 0 auto;
width: 270px;
font-size: 14px;
}
#Quality li {
position: relative;
white-space: nowrap;
text-align: center;
}
#Quality li::after {
transform: translateX(-50%);
content: '';
display: block;
position: absolute;
left: 50%;
bottom: -37px;
background: url("../img/icn_arw.png") no-repeat center center;
background-size: 35px auto;
width: 35px;
height: 21px;
}
#Quality li:last-child::after {
display: none;
}
#Quality li img {
display: block;
border-radius: 7px;
margin-bottom: 11px;
}


.campaignBanner_middle {
position: relative;
margin: -92px auto;
width: 345px;
}

#contents a:hover,
#contents a:hover img {
opacity: 1 !important;
}