T@charset "utf-8";
/* CSS Document */

/* これはいらないかも */
html,body { height:100%; }
*{ font-family: "Montserrat", "Roboto", "Myriad Pro", Arial, Meiryo, sans-serif; }
*, *:before, *:after {
box-sizing: border-box;  /* paddingやborderに依存しないwidth,height指定 */
}
html { font-size: 62.5%; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; } /* スマホで勝手に文字が大きくなるのを制御　-webkit-text-size-adjust:100% scroll-behavior:簡易的なスムーズスクロール */
body {
position: relative;
margin: 0;
padding: 0;
font-size: 1.5rem; /* 15px */
font-weight: 500;
color: #180d0a;
line-height: 1.65em;
background: #fff;
letter-spacing: 0.02em;
overflow-x: hidden;
}
@media screen and (max-width: 767px) {
  body {
  line-height: 1.6em;
  font-size: 1.4rem; /* 14px */
  }
}
/* 自動生成リンクを無効に設定 */
.tel-link-none { pointer-events: none; }
/* 	ふわっと切り替え */
a {
text-decoration: none;
color: #1c1416;
transition: 0.5s;
}
a:hover {
text-decoration: none;
color: #1c1416;
opacity: 0.7;
}
dt, dd {
line-height: 1.7em;
}
ul, ol, ul li, ol li {
list-style: none;
}
p {
margin: 0px;
padding: 0px;
}

/* Pタグで改行するとlightheightが効かないのを防ぐ */
br { line-height: 1; }
h1 { margin: 0px; }

/* パソコンで見たときは"pc"のclassがついた方が表示される */
.pc { display: block!important; }
.sp { display: none !important; }
/* スマートフォンで見たときは"sp"のclassがついた方が表示される */
@media screen and (max-width: 960px) {
  .pc { display: none !important; }
  .sp { display: block!important; }
}
.pc-head { display: block!important; }
.sp-head { display: none !important; width: 100%; }
/* スマートフォンで見たときは"sp"のclassがついた方が表示される */
@media screen and (max-width: 1279px) {
  body { margin-top: 80px; }
  .pc-head { display: none !important; }
  .sp-head { display: block!important; }
}
.br-pc { display: block; }
.br-sp { display: none; }
@media screen and (max-width: 520px) {
  .br-pc { display: none; }
  .br-sp { display: block; }
}
/* PCでは */
.notel {
pointer-events: none;
color: #292929;
}
.visual .notel,
.visual_dan .notel,
.visual_fresh .notel {
pointer-events: none;
color: #fff;
}
.foot_area .notel {
pointer-events: none;
color: #a1a1a1;
}

/*************************************************/
/*    header
/*************************************************/

header {
margin: 0px auto;
width: 100%;
background: #1c1416;
}
.h_number {
margin: 0px auto;
padding-top: 6px;
height: 47px;
font-size: 1.3rem;
font-weight: 300;
color: #c6c6c6;
text-align: center;
line-height: 135%;
}
.h_number span.eigyo {
display: block;
font-size: 1.2rem;
}
.h_number a {
position: relative;
padding: 0px 0px 0px 10px;
color: #eacaaf;
font-size: 1.25rem;
font-weight: 400;
letter-spacing: 0.1em;
text-decoration: underline;
transition: 0.5s;
}
.h_number a:hover {
text-decoration: none;
}
@media screen and (min-width: 1280px) {
  .h_number {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  }
  .h_number a {
  padding: 0px 22px 0px 10px;
  }
  .h_number a:after {
  content: "|";
  position: absolute;
  top: 0;
  right: 2px;
  padding-right: 5px;
  color: #c6c6c6;
  }
}

/*************************************************/
/*    navi
/*************************************************/

.head {
display: flex;
justify-content: center;
align-items: center;
margin: 0px  auto;
width: 100%;
height: 50px;
max-width: 1460px;
}
.logo a {
display: flex;
align-items: center;
}
.logo a:hover {
opacity: 1;
}
/* sp */
@media screen and (max-width: 1279px) {
  .sp-head {
  position: fixed;
  top: 0px;
  left: 0px;
  background-color: #fff;
  height: 97px;
  z-index: 1000;
  }
  .logo {
  display: flex;
  justify-content: center;
  width: 50%;
  }
  .logo img {
  width: 100%;
  max-width: 290px;
  text-align: center;
  }
  .logo img {
  width: 100%;
  max-width: 290px;
  text-align: center;
  }
  .nav_right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 22%;
  }
  .mail {
  margin-right: 13px;
  width: 20px;
  }
  .cart {
  width: 22px;
  }
  .mail a,
  .cart {
  display: flex;
  align-items: center;
  }
  .mail img,
  .cart img {
  width: 100%;
  height: auto;
  }
  .nav_area {
  display: flex;
  align-items: center;
  width: 18%;
  }
  /*ハンバーガーメニュー*/
  .hamburger {
  width: 40px;
  height: 40px;
  position: relative;
  top: 0px;
  left: 0px;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  }
  .hamburger__container {
  display: block;
  }
  .hamburger__top,
  .hamburger__middle,
  .hamburger__bottom {
  display: block;
  width: 40px;
  height: 1px;
  background-color: #000;
  }
  .hamburger__middle {
  margin: 9px 0 9px 0;
  opacity: 1;
  transition: margin 300ms ease-in-out, opacity 0s ease-in-out;
  }
  .hamburger__top,
  .hamburger__bottom {
  transform: rotate(0);
  transition: transform 300ms ease-in-out, background-color 300ms ease-in-out;
  }
  /*ハンバーガーをクリックしたら起こる処理*/
  .hamburger.js-menu-open {
  transition-delay: 300ms;
  }
  .hamburger.js-menu-open .hamburger__top,
  .hamburger.js-menu-open .hamburger__middle,
  .hamburger.js-menu-open .hamburger__bottom {
  background-color: #fff;
  }
  .hamburger.js-menu-open .hamburger__middle {
  margin: -1px 0 -1px 0;
  opacity: 0;
  transition: margin 300ms ease-in-out, opacity 0s ease-in-out;
  }
  .hamburger.js-menu-open .hamburger__top,
  .hamburger.js-menu-open .hamburger__bottom {
  transition-delay: 300ms;
  }
  .hamburger.js-menu-open .hamburger__top {
  transform: rotate(45deg);
  }
  .hamburger.js-menu-open .hamburger__bottom {
  transform: rotate(-45deg);
  }
  /*スマホナビメニュー*/
  .sp__menu {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -10;
  background-color: #506d53;
  visibility: hidden;
  opacity: 0;
  transition: .3s cubic-bezier(.11,.24,.64,1);
  }
  .sp__menu.js-open {
  z-index: 100;
  opacity: 1;
  visibility: visible;
  transition: .3s cubic-bezier(.11,.24,.64,1);
  }
  .sp__menu__container {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  }
  .sp__menu__nav ul li {
  text-align: center;
  overflow: hidden;
  padding-bottom: 3px;
  }
  .sp__menu__nav ul li:nth-child(even) {
  margin: 35px 0;
  }
  .sp__menu__nav ul li:nth-child(1) a {
  transition-delay: 50ms;
  }
  .sp__menu__nav ul li:nth-child(1) a::before {
  transition-delay: 130ms;
  }
  .sp__menu__nav ul li:nth-child(2) a {
  transition-delay: 100ms;
  }
  .sp__menu__nav ul li:nth-child(2) a::before {
  transition-delay: 260ms;
  }
  .sp__menu__nav ul li:nth-child(3) a {
  transition-delay: 150ms;
  }
  .sp__menu__nav ul li:nth-child(3) a::before {
  transition-delay: 390ms;
  }
  .sp__menu__nav ul li:nth-child(4) a {
  transition-delay: 200ms;
  }
  .sp__menu__nav ul li:nth-child(4) a::before {
  transition-delay: 520ms;
  }
  .sp__menu__nav ul li:nth-child(5) a {
  transition-delay: 250ms;
  }
  .sp__menu__nav ul li:nth-child(5) a::before {
  transition-delay: 650ms;
  }
  .sp__menu__nav ul li:nth-child(6) a {
  transition-delay: 300ms;
  }
  .sp__menu__nav ul li:nth-child(6) a::before {
  transition-delay: 780ms;
  }
  .sp__menu__nav ul li:nth-child(7) a {
  transition-delay: 350ms;
  }
  .sp__menu__nav ul li:nth-child(7) a::before {
  transition-delay: 910ms;
  }
  .sp__menu__nav ul li a {
  font-size: 1.8rem;
  color: #fff;
  text-decoration: none;
  display: inline-block;
  letter-spacing: 1.3px;
  opacity: 0;
  transform: translate3d(0, 100%, 0);
  transition: all .3s cubic-bezier(0.25, 0.1, 0.25, 1);
  position: relative;
  }
  .sp__menu__nav ul li a:before {
  content: '';
  position: absolute;
  z-index: -1;
  bottom: -3px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #fff;
  transform-origin: 100% 0;
  transform: scaleX(0);
  transition: transform 0.6s cubic-bezier(0.55, 0.05, 0.22, 0.99);
  }
  .sp__menu__nav ul li a.js-menu-open {
  opacity: 1;
  transform: translate3d(0,0,0);
  }
  .sp__menu__nav ul li a.js-menu-open:before {
  transform-origin: 0 0;
  transform: scaleX(1);
  }
  .sp__menu__nav ul li.first {
  padding-bottom: 10px;
  }
  .sp__menu__nav ul li.first a {
  font-size: 1.6rem;
  }
  .sp__menu__nav ul li.first a.vi {
  position: relative;
  margin-right: 30px;
  }
  .sp__menu__nav ul li.first a.vi:after {
  content: "|";
  position: absolute;
  top: 0px;
  right: -19px;
  }
}
@media screen and (min-width: 1280px) {
  .head {
  width: 90%;
  height: 100px;
  }
  .logo {
  width: 20%;
  }
  ul.navi {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 35%;
  margin-right: 5%;
  }
  ul.navi li a,
  ul.f_nav li a {
  display: block;
  position: relative;
  font-size: 1.7rem;
  color: #1c1416;
  text-align: center;
  letter-spacing: 0.05em;
  line-height: 125%;
  }
  ul.navi li a:after,
  ul.f_nav li a:after {
  position: absolute;
  left: 0;
  content: '';
  width: 100%;
  height: 2px;
  background: #000;
  bottom: -8px;
  transform: scale(0, 1);
  transform-origin: center top; /*変形（アンダーラインの伸長）の原点がaタグ（各メニュー）の右端*/
  transition: transform 0.3s;   /*変形の時間*/
  }
  ul.f_nav li a:after {
  background: #d7d7d7;
  }
  ul.navi li a:hover:after,
  ul.f_nav li a:hover:after {
  transform: scale(1, 1); /*ホバー後、x軸方向に1（相対値）伸長*/
  }
  .nav_right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 40%;
  }
  .h_online,
  .h_contact {
  margin: 0px 0px 0px 22px;
  padding: 16px 0px;
  width: 100%;
  max-width: 150px;
  font-size: 1.7rem;
  color: #1c1416;
  text-align: center;
  line-height: 100%;
  letter-spacing: 0.1em;
  background: #ffea21;
  transition: background 1s;
  border-radius: 3px;
  cursor :pointer;
  }
  .h_online {
  padding: 9px 0px;
  max-width: 150px;
  font-size: 1.5rem;
  }
  .h_online:hover,
  .h_contact:hover {
  color: #fff;
  opacity: 1;
  background: #1c1416;
  }
  .h_online:hover a {
  color: #fff;
  opacity: 1;
  }
  .h_lang span {
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  color: #605a5b;
  }
  .h_lang span.first {
  position: relative;
  padding-right: 25px;
  }
  .h_lang span.first:after {
  content: "|";
  position: absolute;
  padding: 0px 10px 0px 12px;
  color: #6d6467;
  }
  .h_lang a {
  position: relative;
  color: #1c1416;
  }
  .h_lang a:hover {
  color: #1c1416;
  opacity: 0.7;
  }
  .h_lang a:after {
  position: absolute;
  left: 0;
  content: '';
  width: 100%;
  height: 2px;
  background: #605a5b;
  bottom: -8px;
  transform: scale(1, 1);
  transform-origin: center top; /*変形（アンダーラインの伸長）の原点がaタグ（各メニュー）の右端*/
  transition: transform 0.3s;   /*変形の時間*/
  }
  .h_lang a:hover:after {
  transform: scale(0, 1); /*ホバー後、x軸方向に1（相対値）伸長*/
  }
}

/*************************************************/
/*    slider
/*************************************************/

.slider {
position: absolute;
display: flex;
top: 0px;
left: 0px;
width: 100%;
margin-bottom: 30px;
}
ul.slider li {
display: flex !important;
flex-direction: column-reverse;
}
ul.slider .slider01 {
background: #fbeddd;
}
ul.slider .slider02 {
background: #ffe921;
}
.slider_img,
.slider_cont {
width: 100%;
}
.slider_cont {
padding: 20px 20px 30px;
}
.slider_img img {
width: 100%;
height: auto;
object-fit: cover;
}
h1.h1_visual,
.visual_txt {
font-family: "EB Garamond", system-ui;
height: 140px;
font-size: 2.8rem;
font-weight: 500;
line-height: 110%;
}
span.h1_read {
display: block;
padding-bottom: 5px;
font-family: "Amatic SC", sans-serif;
font-size: 2.5rem;
font-weight: 400;
line-height: 110%;
}
h1.h1_visual span.h1_read {
padding-bottom: 10px;
}
.slick-prev,
.slick-next {
display: none !important;
}
@media screen and (min-width: 961px) {
  h1.h1_visual,
  .visual_txt {
  margin: 0px auto;
  width: 80%;
  height: 260px;
  font-size: 5.5rem;
  }
  span.h1_read {
  font-size: 4.5rem;
  }
}
@media screen and (min-width: 1280px) {
  .slider {
  margin-bottom: 100px;
  }
  ul.slider li {
  align-items: center;
  flex-direction: row;
  height: 720px;
  }
  .slider_img,
  .slider_cont {
  width: 50%;
  }
  .slider_cont {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin: -30px 0px 0px;
  width: 50%;
  }
  .slider_txt {
  padding: 0px 60px;
  width: 100%;
  max-width: 780px;
  }
  .slider_img img {
  width: auto;
  height: 100%;
  }
  h1.h1_visual,
  .visual_txt {
  display: flex;
  flex-direction: column;
  padding: 0px;
  width: 100%;
  height: auto;
  font-size: 7.0rem;
  line-height: 110%;
  }
  h1.h1_visual span.h1_read {
  padding-bottom: 20px;
  }
  span.h1_read {
  font-size: 5.5rem;
  line-height: 100%;
  }
}
@media screen and (min-width: 1500px) {
  h1.h1_visual,
  .visual_txt {
  font-size: 8.0rem;
  line-height: 120%;
  }
  span.h1_read {
  font-size: 6.5rem;
  line-height: 110%;
  }
}

@media screen and (min-width: 1650px) {
  .slider_img img {
  width: 100%;
  height: auto;
  }
}

/*************************************************/
/*    modal window
/*************************************************/

.js_modalWrap {
display: none;
z-index: 1000;
position: fixed;
left: 0;
top: 0;
width: 100%;
height: 100%;
}
.js_modalBG {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.6);
}
.modal_content {
position: absolute;
top: 50%;
left: 50%;
padding: 50px 30px;
width: 60%;
max-width: 900px;
background: #fff;
line-height: 1.4em;
transition: 0.5s;
border-radius: 10px;
transform: translateX(-50%) translateY(-50%);
}
.modal_content .cart_area {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
margin: 0px auto;
width: 75%;
}
.modal_content .cart_area a.cart_logo {
display: flex;
align-items: center;
padding: 30px;
width: 46%;
border: 1px solid #1c1416;
border-radius: 8px;
}
.modal_content .cart_area a.cart_logo img {
width: 100%;
height: auto;
}
.modal_content .cart_message {
margin: 0px auto;
padding: 20px 0px 0px;
font-size: 1.3rem;
font-weight: 500;
}
.js_modalClose {
display: block;
position: absolute;
top: 15px;
right: 15px;
width: 20px;
height: 20px;
overflow: hidden;
cursor: pointer;
z-index: 1001;
}
.js_modalClose::before,
.js_modalClose::after {
content: "";
background-color: #222;
position: absolute;
top: -5px;
right: 10px;
width: 1px;
height: 30px;
}
.js_modalClose::before {
transform: rotate(45deg);
}
.js_modalClose::after {
transform: rotate(-45deg);
}

/* ==========================
  コンテンツの中身
========================== */

.md_linkBtnWrap {
width: 300px;
max-width: 100%;
margin: 10px auto 0;
text-align: center;
}
.md_linkBtnCont {
display: block;
color: #222;
border: 1px solid #222;
padding: 15px 5px;
transition: 0.3s;
}
.md_linkBtnCont:hover,
.md_linkBtnCont:focus {
color: #fff;
background-color: #222;
}
@media (max-width: 960px) {
  .modal_content {
  width: 60%;
  max-height: 400px;
  padding: 20px 20px 15px;
  }
  .modal_content {
  width: 80%;
  }
  .modal_content .cart_area {
  width: 100%;
  }
  .modal_content .cart_area a.cart_logo {
  padding: 0px;
  margin: 0px 10px;
  width: 42%;
  border: none;
  }
  .js_modalClose {
  top: -35px;
  right: 0px;
  }
  .js_modalClose::before,
  .js_modalClose::after {
  background-color: #fff;
  }
  .modal_content .cart_message {
  padding: 5px 5px 0px;
  font-size: 1.2rem;
  line-height: 130%;
  }
}

/*************************************************/
/*    visual
/*************************************************/

h1.h1_cate {
font-family: "EB Garamond", system-ui;
position: absolute;
top: 55%;
left: 6%;
font-size: 3.3rem;
font-weight: 400;
text-shadow: #fff 0px 0 5px;
z-index: 30;
transform: translate(0%,-50%); /* positionに対して要素を中央に配置させる */
}
h1.h1_cate.nigyo {
top: 57%;
line-height: 130%;
}
.cate_visual_cont {
position: relative;
display: flex;
margin-bottom: 25px;
width: 100%;
height: 150px;
}
.cate_visual_line {
position: relative;
top: 0px;
left: 0px;
width: 27%;
height: 100%;
background: #ffe921;
}
.cate_visual_line:before {
content: "";
position: absolute;
top: 0px;
left: 0px;
width: 33%;
height: 100%;
background: #f7ece0;
z-index: 20;
}
.cate_visual_line:after {
content: "";
position: absolute;
top: 0px;
right: 0px;
width: 33%;
height: 100%;
background: #b6aca2;
z-index: 10;
}
.cate_visual {
width: 73%;
background-position: center center;
background-image: url("../images/visual_feature_sp.webp");
background-size: cover;
background-repeat: no-repeat;
border-left: 10% solid #b6aca2;
}
.cate_visual.how_to { background-image: url("../images/visual_howto_sp.webp"); }
.cate_visual.lineup { background-image: url("../images/visual_lineup_sp.webp"); }
.cate_visual.aboutus { background-image: url("../images/visual_aboutus_sp.webp"); }

/* webp対応 */
.webp .cate_visual { background-image: url("../images/visual_feature_sp.webp"); }
.webp .cate_visual.how_to { background-image: url("../images/visual_howto_sp.webp"); }
.webp .cate_visual.lineup { background-image: url("../images/visual_lineup_sp.webp"); }
.webp .cate_visual.aboutus { background-image: url("../images/visual_aboutus_sp.webp"); }
/* webp非対応 */
.no-webp .cate_visual { background-image: url("../images/visual_feature_sp.jpg"); }
.no-webp .cate_visual.how_to { background-image: url("../images/visual_howto_sp.jpg"); }
.no-webp .cate_visual.lineup { background-image: url("../images/visual_lineup_sp.jpg"); }
.no-webp .cate_visual.aboutus { background-image: url("../images/visual_aboutus_sp.jpg"); }

/* visual contact */
.cate_visual_cont02 {
position: relative;
margin-bottom: 25px;
width: 100%;
height: 150px;
}
.cate_visual02 {
position: relative;
width: 100%;
height: 100%;
background-position: center center;
background-image: url("../images/visual_contact_sp.webp");
background-size: cover;
background-repeat: no-repeat;
}
/* webp対応 */
.webp .cate_visual02 { background-image: url("../images/visual_contact_sp.webp"); }
/* webp非対応 */
.no-webp .cate_visual02 { background-image: url("../images/visual_contact_sp.jpg"); }

@media screen and (min-width: 961px) {
  h1.h1_cate {
  top: 48%;
  font-size: 7.3rem;
  }
  h1.h1_cate.nigyo {
  top: 50%;
  }
  h1.h1_cate.contact {
  top: 26%;
  }
  .cate_visual_cont,
  .cate_visual_cont02 {
  margin-bottom: 90px;
  height: 450px;
  }
  .cate_visual { background-image: url("../images/visual_feature.webp"); }
  .cate_visual.how_to { background-image: url("../images/visual_howto.webp"); }
  .cate_visual.lineup { background-image: url("../images/visual_lineup.webp"); }
  .cate_visual.aboutus { background-image: url("../images/visual_aboutus.webp"); }
  /* webp対応 */
  .webp .cate_visual { background-image: url("../images/visual_feature.webp"); }
  .webp .cate_visual.how_to { background-image: url("../images/visual_howto.webp"); }
  .webp .cate_visual.lineup { background-image: url("../images/visual_lineup.webp"); }
  .webp .cate_visual.aboutus { background-image: url("../images/visual_aboutus.webp"); }
  /* webp非対応 */
  .no-webp .cate_visual { background-image: url("../images/visual_feature.jpg"); }
  .no-webp .cate_visual.how_to { background-image: url("../images/visual_howto.jpg"); }
  .no-webp .cate_visual.lineup { background-image: url("../images/visual_lineup.jpg"); }
  .no-webp .cate_visual.aboutus { background-image: url("../images/visual_aboutus.jpg"); }
  .pc.hei100 {
  height: 100%;
  }
  .cate_visual02 {
  background-position: center bottom;
  background-image: url("../images/visual_contact.webp");
  }
  /* webp対応 */
  .webp .cate_visual02 { background-image: url("../images/visual_contact.webp"); }
  /* webp非対応 */
  .no-webp .cate_visual02 { background-image: url("../images/visual_contact.jpg"); }
}

/*************************************************/
/*    top
/*************************************************/

h2.h2_ttl {
font-family: "EB Garamond", system-ui;
padding: 0px 30px 20px;
font-size: 2.7rem;
font-weight: 500;
text-align: center;
line-height: 120%;
}
h2.h2_ttl.cate02 {
padding: 30px 0px 30px;
}
p.normal {
margin: 0px auto;
padding: 0px;
width: 80%;
font-size: 1.4rem;
line-height: 140%;
}
p span.block {
display: block;
padding-bottom: 10px;
}
p span.block:last-of-type {
padding-bottom: 0px;
}
.top_img {
margin: 0px auto;
width: 100%;
max-width: 970px;
}
.top_img img {
width: 100%;
height: auto;
}
@media screen and (min-width: 961px) {
  h2.h2_ttl {
  padding: 0px 30px 30px;
  font-size: 7.0rem;
  line-height: 125%;
  }
  h2.h2_ttl.cate {
  font-size: 6.5rem;
  line-height: 115%;
  }
  h2.h2_ttl.cate02 {
  padding: 100px 0px 0px;
  }
  p.normal {
  font-size: 1.7rem;
  text-align: center;
  line-height: 180%;
  }
  p.normal span.block {
  padding-bottom: 0px;
  }
  .top_img {
  margin: 20px auto 80px;
  }
}
/*--------------------------------------
  beige background
--------------------------------------*/
.beige_bg {
margin: 0px auto;
padding: 40px 0px 15px;
width: 100%;
background: #fff0e3;
}
.beige_bg.about {
margin: 30px 0px 20px;
padding: 25px 0px 10px;
}
.beige_bg h2.h2_ttl {
padding: 0px 30px 15px;
font-size: 2.7rem;
line-height: 110%;
}
.t_ballon {
display: flex;
justify-content: center;
width: 80%;
max-width: 550px;
margin: 0px auto;
}
.t_ball {
position: relative;
display: inline-block;
margin-bottom: 20px;
padding: 7px 30px;
width: 100%;
color: #fff;
font-size: 1.4rem;
text-align: center;
background: #1c1416;
border-radius: 30px;
}
.t_ball:before {
content: "";
position: absolute;
top: 100%;
left: 50%;
margin-left: -7px;
border: 7px solid transparent;
border-top: 7px solid #1c1416;
}
.t_ball p.read {
margin: 0;
padding: 0;
line-height: 120%;
}
.t_youtube {
margin: 0px auto;
width: 90%; /* 任意の横幅を指定 */
max-width: 710px;
aspect-ratio: 16/9;
}
.t_youtube iframe {
width: 100%;
height: 100%;
}
.t_icon {
display: flex;
justify-content: center;
justify-content: space-between;
flex-wrap: wrap;
width: 85%;
max-width: 1090px;
margin: 10px auto;
}
.t_icon .icon {
margin: 0px;
width: 49%;
font-size: 1.4rem;
text-align: center;
line-height: 120%;
}
.t_icon .icon .mt {
display: block;
padding-top: 15px;
}
.t_icon .icon img {
display: block;
margin: 0px auto;
width: 100%;
max-width: 80px;
height: auto;
}

@media screen and (min-width: 768px) {
  .t_icon {
  margin-top: 40px;
  }
  .t_icon .icon {
  width: 25%;
  }
}
@media screen and (min-width: 961px) {
  .beige_bg {
  padding: 90px 0px 50px;
  }
  .beige_bg.about {
  padding: 0px 0px 30px;
  }
  .beige_bg h2.h2_ttl {
  padding: 0px 30px 40px;
  font-size: 6.0rem;
  }
  .t_ball {
  margin-bottom: 40px;
  padding: 8px 30px;
  }
  .t_icon .icon {
  font-size: 1.7rem;
  }
  .t_icon .icon img {
  max-width: 102px;
  }
}
/*--------------------------------------
  product
--------------------------------------*/
.t_prod {
display: block;
border-top: 1px solid #ccc;
margin-top: 35px;
}
.t_prod.first {
margin: 0px;
border: none;
}
.t_prod .txt_area {
width: 100%;
text-align: center;
}
.t_prod .h2_tprod {
padding: 30px 0px 15px;
font-size: 2.6rem;
}
.t_prod .prod_txt {
padding: 0px 20px;
font-size: 1.4rem;
color: #502b00;
line-height: 130%;
}
.t_prod .pro_detail_waku {
margin: 15px auto 0px;
padding: 15px 18px 15px 20px;
width: 85%;
max-width: 445px;
background: #fffde9;
border: 1px solid #e5d43a;
border-radius: 5px;
}
.t_prod ul.pro_detail li {
position: relative;
padding: 0px 0px 10px 18px;
font-size: 1.3rem;
text-align: left;
color: #502b00;
line-height: 135%;
}
.t_prod ul.pro_detail li:before {
content: "";
position: absolute;
top: 0px;
left: -6px;
width: 20px;
height: 15px;
background-image: url("../images/t_check mark.png");
background-size: 100% 100%;
}
.t_prod ul.pro_detail li:last-child {
padding-bottom: 0px;
}
.prod_color {
margin: 0px auto;
}
.prod_color .clr_n {
font-size: 1.7rem;
font-weight: 600;
color: #502b00;
text-align: center;
}
.clr_n span.name {
display: block;
font-size: 1.3rem;
color: #502b00;
}
.prod_color .cor_img {
display: flex;
justify-content: center;
margin-top: 5px;
}
.cor_img .circle { /* 正円を描く */
position: relative;
display: block;
margin: 0px 5px;
padding: 8%;
border-radius: 50%;
box-shadow: 2px 2px 5px #b9a576;
}
.circle:before { /* 正円を描く */
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 7em;
height: 1em;
margin-top: -.5em;
margin-left: -3.5em;
line-height: 1;
}
.circle.black {
background-color: #000;
}
.circle.dark_brown {
background-color: #3a0000;
}
.circle.light_brown {
background-color: #643f31;
}
.prod_color .cor_img.lineup {
justify-content: flex-start;
}
.cor_img.lineup .circle {
padding: 6.5%;
}
.cor_img.lineup .circle:first-child {
margin: 0px 5px 0px 0px;
}
.t_prod .image_area {
position: relative;
margin: 20px auto;
width: 80%;
}
.image_area .pro_point {
position: absolute;
top: -5px;
right: 10px;
width: 30%;
z-index: 10;
}
.image_area .pro_point img {
width: 100%;
max-width: 133px;
height: auto;
}
.image_area.second .pro_point img {
max-width: 149px;
}
.image_area .pro_img {
width: 100%;
text-align: center;
}
.image_area .pro_img img {
width: 100%;
max-width: 500px;
height: auto;
}
.cart_cont {
display: flex;
justify-content: center;
align-items: center;
margin: 0px auto;
padding: 15px 20px;
width: 75%;
font-size: 1.7rem;
font-weight: 600;
color: #502b00;
background: #ffce59;
border-radius: 4px;
transition: 0.6s;
cursor: pointer;
}
.cart_cont:hover,
.cart_cont.about_bn:hover {
color: #fff;
background: #180d0a;
opacity: 1;
}
.cart_cont.aboutus {
margin: 0px auto;
background: #fff;
border: 1px solid #b79372;
}
.cart_cont.aboutus:hover {
color: #fff;
background: #b79372;
border: 1px solid #b79372;
}
.cart_cont.feature {
margin: 20px auto 15px;
text-align: center;
border: 1px solid #ffce59;
}
.cart_cont.feature:hover {
color: #502b00;
background: #fff;
border: 1px solid #b79372;
}
.cart_cont.lineup {
flex-wrap: wrap;
padding: 12px 20px;
width: 90%;
font-size: 1.8rem;
}
.cart_cont.about_bn {
color: #180d0a;
background: #ffea21;
}
.t_cart_icon { /* SVG mask-image */
display: inline-block;
margin-left: 5px;
width: 23px;
height: 21.63px;
mask-position: center center;
mask-repeat: no-repeat;
mask-size: contain;
mask-image: url(../images/shopping-basket_brown.svg);
background: #502b00; /* 背景色でSVGの色を指定 */
}
.cart_cont:hover .t_cart_icon {
background: #fff;
transition: 0.6s;
}
.t_arrow_icon { /* SVG mask-image */
display: inline-block;
margin-left: 5px;
width: 18px;
height: 15.75px;
mask-position: center center;
mask-repeat: no-repeat;
mask-size: contain;
mask-image: url(../images/arrow.svg);
background: #180d0a; /* 背景色でSVGの色を指定 */
}
.cart_cont:hover .t_arrow_icon {
transform: translateX(5px);
transition: 0.6s;
}
.t_arrow_icon img {
width: 100%;
height: auto;
}

@media screen and (min-width: 521px) {
  .cor_img .circle {
  padding: 4%;
  }
}
@media screen and (min-width: 961px) {
  .t_prod,
  .t_prod.first {
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
  margin: 150px auto 0px;
  width: 90%;
  max-width: 1066px;
  border: none;
  }
  .t_prod.first {
  flex-direction: row;
  }
  .t_prod .h2_tprod {
  font-size: 5.5rem;
  text-align: left;
  }
  .t_prod .txt_area,
  .t_prod .image_area {
  width: 49%;
  }
  .t_prod.first .image_area {
  margin-top: 70px;
  }
  .image_area.second {
  margin-top: -10px;
  }
  .t_prod .txt_area.second {
  width: 45%;
  margin-left: 8%;
  }
  .t_prod .prod_txt {
  padding: 0px;
  font-size: 1.7rem;
  text-align: left;
  line-height: 140%;
  }
  .t_prod .pro_detail_waku {
  margin: 20px 0px;
  padding: 20px 20px 20px 30px;
  }
  .t_prod .txt_area.second .pro_detail_waku {
  width: 95%;
  }
  .t_prod ul.pro_detail li {
  padding: 0px 10px 15px 25px;
  font-size: 1.5rem;
  line-height: 140%;
  }
  .t_prod ul.pro_detail li:before {
  left: -12px;
  width: 26px;
  height: 20px;
  }
  .image_area .pro_img {
  left: 51%;
  text-align: inherit;
  }
  .image_area.second .pro_img {
  left: 52%;
  }
  .image_area.second .pro_point {
  top: 0px;
  right: auto;
  left: -10px;
  }
  .prod_color {
  display: flex;
  justify-content: space-between;
  margin-left: -10px;
  }
  .prod_color .clr_n {
  font-size: 1.8rem;
  text-align: left;
  }
  .clr_n span.name {
  font-size: 1.4rem;
  }
  .prod_color .cor_img {
  justify-content: flex-end;
  margin-right: -10px;
  }
  .cor_img .circle {
  margin: 0px 3px;
  padding: 125%;
  }
  .circle:before { /* 正円を描く */
  width: 5em;
  height: 1em;
  margin-top: -.5em;
  margin-left: -2.5em;
  }
  .t_prod .image_area:before { /* 正円を描く */
  width: 5em;
  height: 1em;
  margin-top: -.5em;
  margin-left: -2.5em;
  }
  .cart_cont {
  justify-content: center;
  margin: 15px 0px 0px 0px;
  max-width: 240px;
  padding: 18px 20px;
  font-size: 2.0rem;
  }
  .cart_cont.aboutus {
  font-size: 2.0rem;
  }
  .cart_cont.about_bn {
  margin: 0px auto;
  }
  .cart_cont.feature {
  margin: 15px auto 10px;
  }
  .cart_cont.prod_btm {
  flex-wrap: wrap;
  justify-content: center;
  margin: 20px auto 0px;
  padding: 10px 0px;
  width: 30%;
  max-width: 75px;
  max-height: 75px;
  font-size: 1.1rem;
  text-align: center;
  line-height: 110%;
  background: #f0c358;
  }
  .cart_cont.prod_btm:hover {
  color: #fff;
  background: #180d0a;
  opacity: 1;
  }
  .t_cart_icon.prod_btm_icon {
  margin: 3px 0px 0px;
  width: 100%;
  }
  .t_cart_icon.prod_btm_icon img {
  margin: 5px auto 0px;
  width: 23px;
  }
  .t_cart_icon {
  margin-left: 8px;
  width: 26px;
  height: 24.44px;
  }
  a.pro_btm:hover {
  opacity: 1;
  }
}
/*--------------------------------------
  about us
--------------------------------------*/
.about_us {
margin: 35px 0px;
padding-bottom: 40px;
width: 100%;
background: #fff0e3;
}
h2.h2_ttl.about_ttl {
padding-top: 30px;
}
.about_us_txt {
margin: 0px 30px 10px;
font-size: 1.4rem;
}
.t_iso {
margin: 20px auto;
width: 60%;
max-width: 150px;
}
.t_iso img {
text-align: center;
width: 100%;
height: auto;
}
@media screen and (min-width: 961px) {
  .about_us {
  margin: 120px 0px 100px;
  padding-bottom: 100px;
  }
  .about_us.before {
  margin: 100px 0px;
  }
  h2.h2_ttl.about_ttl {
  padding-top: 95px;
  font-size: 6.5rem;
  line-height: 115%;
  }
  .about_us_txt {
  margin: 20px 40px 20px;
  font-size: 1.7rem;
  text-align: center;
  line-height: 160%;
  }
  .t_iso {
  margin: 30px auto 25px;
  }
}
/*--------------------------------------
  how to use
--------------------------------------*/
.how_to_bg {
margin: 0px auto;
padding: 15px 20px 30px 20px;
width: 85%;
max-width: 1144px;
background: #e4ebf1;
border-radius: 5px;
}
.howto {
display: block;
margin: 15px auto 0px;
width: 90%;
}
.howto .how_img {
margin: 0px 20px;
}
.howto .how_img img {
width: 100%;
height: auto;
}
.howto_txt {
padding: 0px 0px 15px;
font-size: 1.4rem;
font-weight: 600;
text-align: center;
line-height: 125%;
}
.cart_cont.aboutus.howtoc {
width: 90%;
border-color: #a1bad0;
}
.cart_cont.aboutus.howtoc:hover {
color: #fff;
background: #a1bad0;
}
@media screen and (min-width: 961px) {
  .how_to_bg {
  margin: 30px auto 45px;
  padding-bottom: 60px;
  }
  .howto {
  display: flex;
  justify-content: space-between;
  margin: 45px auto 0px;
  }
  .howto .how_img {
  width: 33%;
  text-align: center;
  }
  .howto .how_img img {
  max-width: 243px;
  }
  .howto_txt {
  padding: 10px 0px 20px;
  font-size: 1.6rem;
  }
}
/*--------------------------------------
  before after
--------------------------------------*/
h3.h3_be_af {
position: absolute;
left: 16%;
margin-top: -44px;
margin-bottom: 20px;
padding: 6px 0px;
width: 70%;
font-size: 1.7rem;
font-weight: 500;
color: #fff;
text-align: center;
background: #643f31;
border-radius: 50px;
z-index: 10;
}
h3.h3_be_af.h3_dark_brown {
background: #592929;
}
h3.h3_be_af.h3_black {
background: #363636;
}
h4.h4_before {
padding: 5px 0px 5px;
font-size: 1.7rem;
font-weight: 600;
color: #592e1e;
text-align: center;
}
h4.h4_before.h4_black {
color: #180d0a;
}
h4.h4_before.h4_dark_brown {
color: #3a0000;
}
.be_af {
display: block;
margin: 15px auto;
width: 83%;
}
.be_af .brown,
.be_af .dark_brown,
.be_af .black {
position: relative;
margin-bottom: 40px;
padding: 25px 0px 0px;
width: 100%;
background: #e5d3cd;
border: 2px solid #643f31;
border-radius: 10px;
}
.be_af .black {
margin-bottom: 30px;
background: #dadada;
border: 2px solid #363636;
}
.be_af .dark_brown {
margin-bottom: 30px;
background: #f0e1e1;
border: 2px solid #573213;
}
.be_af .brown img,
.be_af .dark_brown img,
.be_af .black img {
text-align: center;
}
.be_af .brown_left,
.be_af .brown_right,
.be_af .dark_brown_left,
.be_af .dark_brown_right,
.be_af .black_left,
.be_af .black_right {
position: relative;
padding: 0px 0px 45px;
text-align: center;
}
.be_af .brown_right,
.be_af .dark_brown_right,
.be_af .black_right {
margin-top: -20px;
padding: 20px 0px 15px;
background: #fff;
border-bottom-left-radius: 10px;
border-bottom-right-radius: 10px;
}
.be_af .brown_left:after,
.be_af .dark_brown_left:after,
.be_af .black_left:after { /* SVG mask-image */
content: "";
position: absolute;
bottom: -21px;
left: 48.5%;
width: 47px;
height: 38.47px;
mask-position: center center;
mask-repeat: no-repeat;
mask-size: contain;
mask-image: url(../images/arrow02.svg);
background: #643f31; /* 背景色でSVGの色を指定 */
transform: rotate(90deg) translate(-50%,50%); /* positionに対して要素を中央に配置させる */
z-index: 10;
}
.be_af .dark_brown_left:after {
background: #8c4444; /* 背景色でSVGの色を指定 */
}
.be_af .black_left:after {
background: #363636; /* 背景色でSVGの色を指定 */
}
@media screen and (min-width: 961px) {
  h3.h3_be_af {
  font-size: 2.0rem;
  }
  h4.h4_before {
  padding: 3px 0px 10px;
  font-size: 1.9rem;
  }
  .be_af {
  position: relative;
  display: flex;
  justify-content: space-between;
  margin-top: 55px;
  max-width: 1144px;
  }
  .be_af .brown,
  .be_af .black {
  display: flex;
  justify-content: space-between;
  width: 48%;
  margin-bottom: 25px;
  }
  .be_af .brown_left,
  .be_af .brown_right,
  .be_af .black_left,
  .be_af .black_right {
  padding: 15px 0px 25px;
  width: 50%;
  }
  .be_af .brown_right,
  .be_af .black_right {
  margin-top: -25px;
  padding: 40px 0px 25px;
  border-top-right-radius: 10px;
  border-bottom-left-radius: 0px;
  }
  .be_af .brown_left:after,
  .be_af .black_left:after { /* SVG mask-image */
  top: 45%;
  left: auto;
  right: -9%;
  width: 51px;
  height: 41.75px;
  transform: rotate(0deg);
  }
}
/*--------------------------------------
  voice
--------------------------------------*/
.voice_read {
position: relative;
margin: -10px auto 0px;
width: 60%;
text-align: center;
}
.voice_read:before {
border-top: 1px solid;
content: "";
position: absolute;
top: 50%;
left: 0;
width: 100%;
}
.voice_read span.line {
position: relative;
font-family: "EB Garamond", system-ui;
display: inline-block;
padding: 0 10px; /*ラインとテキストの間を調整*/
font-size: 2.0rem;
background-color: white;
}
.voice_waku {
position: relative;
display: block;
margin: 30px auto 0px;
padding-bottom: 20px;
width: 85%;
background: #fffde9;
border: 1px solid #e5d43a;
border-radius: 10px;
}
.voice_waku:before {
content: "";
position: absolute;
top: -5px;
left: 50%;
width: 85%;
height: 10px;
background: #f0c358;
border-top-left-radius: 8px;
border-top-right-radius: 8px;
transform: translate(-50%,-50%); /* positionに対して要素を中央に配置させる */
}
.voice_txt {
padding: 15px 20px 10px;
font-size: 1.4rem;
color: #502b00;
line-height: 145%;
}
.voice_age {
margin: 0px 0px 0px 20px;
padding: 3px 10px;
font-size: 1.4rem;
font-weight: 600;
background: #f0c358;
border-radius: 3px;
}
@media screen and (min-width: 961px) {
  .voice_read {
  margin-top: 0px;
  width: 40%;
  }
  .voice_read span.line {
  font-size: 4.5rem;
  }
  .voice_cont {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 10px auto 0px;
  width: 80%;
  max-width: 1144px;
  }
  .voice_waku {
  margin: 55px auto 0px;
  padding-bottom: 40px;
  width: 30%;
  }
  .voice_txt {
  padding: 35px 30px 20px;
  font-size: 1.6rem;
  }
  .voice_age {
  margin: 0px 0px 30px 30px;
  }
}
@media screen and (min-width: 1190px) {
  .voice_read {
  width: 25%;
  }
  .voice_read span.line {
  padding: 0 15px; /*ラインとテキストの間を調整*/
  }
}

/*************************************************/
/*    feature
/*************************************************/

h2.h2_cate {
font-family: "EB Garamond", system-ui;
padding-bottom: 10px;
font-size: 2.6rem;
font-weight: 500;
line-height: 110%;
}
h3.h3_cate {
padding: 0px;
font-size: 1.7rem;
line-height: 130%;
}
h3.h3_fea_before {
position: relative;
margin: 13px auto 10px;;
padding-left: 18px;
width: 100%;
font-size: 1.5rem;
font-weight: 600;
line-height: 130%;
}
h3.h3_fea_before:after {
content: "";
position: absolute;
bottom: -6px;
left: 0px;
width: 100%;
height: 5px;
border-bottom: 1px solid #000;
}
h3.h3_fea_before span.beforenum {
padding-right: 5px;
font-size: 1.3rem;
}
h3.h3_color_else {
padding-bottom: 5px;
font-size: 1.2rem;
font-weight: 600;
text-align: center;
line-height: 110%;
}
h3.h3_color_else span.color_num {
display: block;
font-size: 1.1rem;
font-weight: 500;
line-height: 120%;
}
h4.h4_video {
display: none;
}
.feature_read,
h3.h3_feature_read {
position: relative;
margin-bottom: 7px;
padding-left: 18px;
font-size: 1.5rem;
font-weight: 700;
color: #502b00;
}
h3.h3_feature_read {
font-size: 1.5rem;
text-align: center;
}
.feature_read.read_center {
margin: 15px auto;
text-align: center;
}
.feature_read span.fread {
font-weight: 500;
color: #502b00;
}
.feature_read:before,
h3.h3_fea_before:before,
h3.h3_feature_read:before {
content: "";
position: absolute;
top: 50%;
left: 6px;
border: 6px solid #ffe921;
border-radius: 200px;
transform: translate(-50%,-50%); /* positionに対して要素を中央に配置させる */
}
h3.h3_feature_read:before {
left: 50%;
margin-left: -84px;
}
.feature_read.read_center:before {
left: 50%;
margin-left: -87px;
}
.feature_cont {
margin: 0px auto;
padding-top: 30px;
width: 90%;
max-width: 1144px;
}
.feature_cont_blue,
.feature_cont_beige {
margin-top: 20px;
padding-bottom: 10px;
width: 100%;
background: #ecf3f8;
}
.feature_cont_beige {
background: #fff0e3;
}
.feature_txt {
padding: 8px 0px 0px;
font-size: 1.3rem;
line-height: 140%;
}
.feature_img {
margin: 20px auto 0px;
width: 80%;
max-width: 618px;
}
.feature_img img {
width: 100%;
height: auto;
}
.feature_img02 {
display: flex;
justify-content: space-between;
margin: 18px auto;
width: 100%;
max-width: 525px;
}
.feature_img02 .fea_image {
width: 47%;
max-width: 226px;
}
.feature_img02 .fea_image .image_txt {
padding: 0px;
font-size: 1.2rem;
font-weight: 400;
text-align: center;
line-height: 120%;
}
.feature_img02 .fea_image img {
width: 100%;
height: auto;
}
.feature_video {
width: 100%;
}
.fea_youtube {
margin: 0px auto 8px;
padding: 0px 6%;
width: 95%; /* 任意の横幅を指定 */
max-width: 550px;
aspect-ratio: 16/9;
background: #333;
border-radius: 10px;
}
.fea_youtube iframe {
width: 100%;
height: 100%;
}
.fea_youtube_ttl {
padding: 0px 15px 15px;
font-size: 1.2rem;
font-weight: 400;
text-align: center;
line-height: 120%;
}
.fea_before_cont {
width: 100%;
}
.fea_before_img {
margin: 10px auto;
width: 50%;
max-width: 175px;
}
.fea_before_img img {
width: 84%;
height: auto;
}
.fea_color_cont {
position: relative;
margin: 20px auto 15px;
padding: 100px 0px;
width: 100%;
background: #fff;
border-top: 6px solid #3a0000;
box-shadow: 0px 0px 10px #c9b79e;
}
.fea_color_cont:last-of-type {
position: inherit;
padding: 20px 0px 10px;
border: none;
}
.fea_color_cont:before,
.fea_color_cont:after {
content: "";
position: absolute;
top: -6px;
left: 0px;
width: 33%;
height: 6px;
background: #000;
border-left: 6px solid #fff;
border-right: 6px solid #fff;
}
.fea_color_cont:after {
left: auto;
right: 0px;
background: #5c381b;
}
.fea_color_cont .color_wrp {
margin: 0px 0px 0px;
}
.color_wrp.left_01 {
position: absolute;
left: 19%;
top: 48%;
}
.color_wrp.middle_01 {
position: absolute;
left: 50%;
top: 30%;
transform: translate(-50%,-50%); /* positionに対して要素を中央に配置させる */
}
.color_wrp.right_01 {
position: absolute;
right: 19%;
top: 48%;
}
.fea_color_cont .color,
.fea_color_cont .color_small {
/*position: relative;*/
margin: 0px auto 3px;
padding: 0px;
width: 70px;
height: 70px;
border-radius: 100%;
box-shadow: 2px 2px 5px #717171;
}
.fea_color_cont .color_small {
width: 40px;
height: 40px;
}
.fea_color_cont .color01 { background: #000; }
.fea_color_cont .color02 { background: #3a0000; }
.fea_color_cont .color03 { background: #5c381b; }
.fea_color_cont .color04 { background: #523c32; }
.fea_color_cont .color05 { background: #7e422c; }
.fea_color_cont .color06 { background: #5c3d1e; }
.fea_color_cont .color07 { background: #7e6b2e; }
.fea_color_cont .color08 { background: #ebc883; }
.fea_color_cont .color09 { background: #7b5c32; }
.fea_color_cont .color10 { background: #a68044; }
.fea_color_cont .color11 { background: #a25741; }
.fea_color_cont .color12 { background: #9f9fa0; }
.fea_color_cont .color13 { background: #e5e5e6; }
.fea_color_cont .color14 { background: #fff; }

.fea_color_cont .colorname {
font-family: "EB Garamond", system-ui;
font-size: 1.8rem;
font-weight: 600;
text-align: center;
}
.fea_color_cont .colorname.dark_brown {
color: #3a0000;
}
.fea_color_cont .colorname.brown {
color: #5c381b;
}
.fea_txt {
padding: 0px 30px;
font-size: 1.3rem;
text-align: center;
line-height: 145%;
}
.fea_color_else {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
margin: 0px auto;
width: 90%;
}
.fea_color_gray {
position: relative;
margin: 15px 0px 10px;
padding: 8px 10px 8px;
width: 32%;
background: #eee;
box-shadow: 0px 0px 8px #bebcba;
}
.fea_color_gray:before {
content: "";
position: absolute;
top: -5px;
left: 10%;
width: 80%;
height: 5px;
background: #525252;
}
.fea_cont_04 {
position: relative;
width: 100%;
max-width: 1140px;
}
.fea_cont_04:last-of-type {
margin-top: 30px;
}
.fea_cont_04:last-of-type:after {
content: "";
position: absolute;
top: -15px;
left: 0px;
width: 100%;
height: 2px;
background: #d4c7bb;
}
.fea_cont_yellow,
.fea_cont_yellow02 {
margin-bottom: 13px;
padding: 13px 20px;
width: 100%;
text-align: center;
background: #fff;
border: 3px solid #ffce59;
}
.fea_cont_yellow .yellow_txt,
.fea_cont_yellow02 .yellow_txt {
font-size: 1.4rem;
text-align: center;
}
.fea_cont_yellow02 .yellow_txt {
text-align: left;
}
.fea_cont_yellow02 img {
margin: 10px auto 0px;
text-align: center;
}
@media screen and (max-width: 960px) {
  h3.h3_color_name {
  display: none;
  }
  .be_af.feature {
  margin-top: 40px;
  width: 100%;
  }
  .be_af.feature .brown_left,
  .be_af.feature .dark_brown_left,
  .be_af.feature .black_left {
  padding-bottom: 30px;
  }
  .fea_haire {
  display: flex;
  justify-content: center;
  width: 95%;
  margin: 0px auto;
  }
  .fea_haire img {
  width: 88%;
  }
  h4.h4_before.feature {
  padding: 0px;
  }
  .be_af.feature .dark_brown {
  margin-bottom: 40px;
  }
  .be_af.feature .black {
  margin-bottom: 25px;
  }
  .be_af.feature .brown_left:after,
  .be_af.feature .dark_brown_left:after,
  .be_af.feature .black_left:after { /* SVG mask-image */
  bottom: -15px;
  }
}
@media screen and (min-width: 961px) {
  h2.h2_cate {
  padding: 10px 0px 15px;
  font-size: 6.5rem;
  line-height: 100%;
  }
  h3.h3_cate {
  font-size: 4.3rem;
  font-weight: 400;
  }
  h3.h3_fea_before {
  margin: 25px 0px 10px;
  width: 91%;
  font-size: 2.3rem;
  }
  h3.h3_fea_before:first-child {
  margin-top: 30px;
  }
  h3.h3_fea_before.dark_brown {
  color: #3a0000;
  }
  h3.h3_fea_before.brown {
  color: #573213;
  }
  h3.h3_fea_before span.beforenum {
  padding-right: 8px;
  font-size: 2.0rem;
  }
  h3.h3_fea_before:after {
  bottom: -11px;
  border-bottom: 3px solid #000;
  }
  h3.h3_fea_before.dark_brown:after {
  border-bottom: 3px solid #3a0000;
  }
  h3.h3_fea_before.brown:after {
  border-bottom: 3px solid #5c381b;
  }
  h3.h3_color_name {
  font-family: "EB Garamond", system-ui;
  padding: 3px 0px 13px;
  text-align: center;
  font-size: 2.5rem;
  font-weight: 500;
  }
  h3.h3_color_name.dark_brown {
  color: #3a0000;
  }
  h3.h3_color_name.brown {
  color: #5c381b;
  }
  h3.h3_color_else {
  padding: 3px 0px 9px;
  line-height: 140%;
  }
  h3.h3_color_else,
  h3.h3_color_else span.color_num {
  font-family: "EB Garamond", system-ui;
  font-size: 1.7rem;
  }
  h3.h3_feature_read {
  margin: 0px auto;
  font-size: 2.2rem;
  line-height: 120%;
  }
  h3.h3_feature_read:before {
  margin-left: -124px;
  }
  .fea_cont_yellow02 h3.h3_feature_read {
  margin-top: 15px;
  margin-bottom: 20px;
  }
  h4.h4_fea_before, h4.h4_fea_after {
  margin: 18px auto 0px;
  padding: 1px 0px;
  width: 85%;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  background: #e7e7e7;
  border: 1px solid #9d9d9d;
  border-bottom-left-radius: 15px;
  }
  h4.h4_fea_after {
  color: #fff;
  background: #180d0a;
  border: 1px solid #180d0a;
  border-bottom-right-radius: 15px;
  border-bottom-left-radius: 0px;
  }  
  h4.h4_fea_before.dark_brown {
  color: #3a0000;
  background: #eedcdc;
  border: 1px solid #caabab;
  }
  h4.h4_fea_after.dark_brown {
  background: #3a0000;
  border: 1px solid #3a0000;
  }
  h4.h4_fea_before.brown {
  color: #573213;
  background: #edded1;
  border: 1px solid #cabdab;
  }
  h4.h4_fea_after.brown {
  background: #573213;
  border: 1px solid #573213;
  }
  h4.h4_video {
  display: block;
  margin-right: 40px;
  padding: 50px 0px 25px;
  text-align: center;
  }
  h4.h4_video span.videottl {
  position: relative;
  margin: 0px auto;
  padding: 0px;
  font-size: 1.8rem;
  color: #fff;
  text-align: center;
  }
  h4.h4_video span.videottl:after {
  content: "";
  position: absolute;
  top: 50%;
  right: -95px;
  width: 53px;
  height: 36px;
  background-size: 100% 100%;
  background-image: url("../images/fea_video_wind.png");
  transform: translate(-50%, -50%); /* positionに対して要素を中央に配置させる */
  }
  h4.h4_video span.videottl.water:after {
  right: -57px;
  width: 30px;
  height: 38px;
  background-image: url("../images/fea_video_water.png");
  }
  .feature_cont_blue {
  margin-top: 100px;
  padding-bottom: 100px;
  }
  .feature_cont_blue.last {
  padding-bottom: 50px;
  }
  .feature_cont_beige {
  padding-bottom: 100px;
  }
  .feature_cont {
  padding-top: 110px;
  }
  .feature_read {
  padding-left: 23px;
  padding-bottom: 0px;
  font-size: 2.4rem;
  }
  .feature_read:before, h3.h3_fea_before:before, h3.h3_feature_read:before {
  top: 43%;
  }
  .feature_read.read_center {
  margin-top: 50px;
  margin-bottom: 30px;
  }
  .feature_read.read_center:before {
  margin-left: -136px;
  }
  .feature_txt {
  padding: 20px 0px 0px;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 170%;
  }
  .feature_img {
  margin: 30px auto 5px;
  }
  .feature_img02 {
  margin: 35px auto 45px;
  }
  .feature_img02 .fea_image .image_txt {
  padding-top: 5px;
  font-size: 1.8rem;
  }
  .feature_video {
  display: flex;
  justify-content: center;
  background: #333;
  border-radius: 10px;
  }
  .feature_video_cont {
  width: 48%;
  }
  .fea_youtube_ttl {
  margin-left: 50px;
  padding: 10px 15px 60px;
  }
  .fea_youtube_ttl span.youttl_icon {
  position: relative;
  font-size: 1.6rem;
  color: #fff;
  }
  .fea_youtube_ttl span.youttl_icon:before {
  content: "";
  position: absolute;
  top: 50%;
  left: -30px;
  width: 44px;
  height: 44px;
  background-size: 100% 100%;
  background-image: url("../images/youtube_icon.png");
  transform: translate(-50%, -50%); /* positionに対して要素を中央に配置させる */
  }
  .fea_before_area {
  display: flex;
  justify-content: space-between;
  margin: 0px;
  width: 91%;
  }
  .fea_before_area:last-of-type {
  margin-bottom: 90px;
  }
  .fea_before_cont {
  display: flex;
  width: 47%;
  }
  .fea_beaf {
  width: 50%;
  }
  .fea_beaf:first-child {
  position: relative;
  }
  .fea_beaf:after {
  content: "";
  position: absolute;
  top: 60%;
  right: -20.5%;
  width: 51px;
  height: 41.75px;
  mask-position: center center;
  mask-repeat: no-repeat;
  mask-size: contain;
  mask-image: url(../images/arrow02.svg);
  background: #363636; /* 背景色でSVGの色を指定 */
  transform: translate(-50%, -50%); /* positionに対して要素を中央に配置させる */
  }
  .fea_beaf.brown:after {
  background: #643f31;
  }
  .fea_beaf.dark_brown:after {
  background: #8c4444;
  }
  .fea_before_img {
  width: 70%;
  }
  .fea_before_img img {
  margin: 0px auto;
  width: 100%;
  }
  .fea_color_cont {
  display: flex;
  position: inherit;
  margin: 0px;
  padding: 40px 0px 30px;
  width: 80%;
  max-width: 880px;
  background: none;
  border: none;
  box-shadow: none;
  }
  .fea_color_cont:before,
  .fea_color_cont:after {
  content: none;
  }
  .fea_color_cont:last-of-type {
  display: block;
  padding-bottom: 25px;
  width: 100%;
  max-width: 1124px;
  background: #fff;
  box-shadow: 0px 0px 10px #c9b79e;
  }
  .color_wrp {
  background: #fff;
  box-shadow: -2px -2px 10px #c9b79e;
  }
  .color_wrp.left_01,
  .color_wrp.middle_01,
  .color_wrp.right_01 {
  position: relative;
  margin-right: 4%;
  padding: 20px;
  width: 30%;
  transform: none;
  top: auto;
  left: auto;
  right: auto;
  }
  .color_wrp:before {
  content: "";
  position: absolute;
  top: -8px;
  left: 5%;
  width: 90%;
  height: 8px;
  background: #000;
  }
  .color_wrp.middle_01:before {
  background: #3a0000;
  }
  .color_wrp.right_01:before {
  background: #5c381b;
  }
  .fea_color_cont .colorname {
  margin-top: 15px;
  padding-top: 13px;
  width: 100%;
  font-size: 2.2rem;
  border-top: 1px solid #8c8c8c;
  }
  .fea_color_cont .colorname.dark_brown {
  border-top: 1px solid #9d8c8c;
  }
  .fea_color_cont .colorname.brown {
  border-top: 1px solid #a1918b;
  }
  .fea_txt {
  margin: 0px auto;
  padding: 10px 0px;
  width: 92%;
  font-size: 1.5rem;
  text-align: left;
  }
  .fea_color_else {
  justify-content: flex-start;
  width: 94%;
  }
  .fea_color_gray {
  margin: 15px 12px;
  padding: 8px 10px 25px;
  width: 17%;
  max-width: 148px;
  box-shadow: -2px -2px 5px #dbdbdb;
  }
  .fea_color_cont .color_small {
  width: 50px;
  height: 50px;
  }
  .fea_cont_04 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  }
  .fea_cont_04:last-of-type {
  margin-top: 50px;
  }
  .fea_cont_04:last-of-type:after {
  top: -39px;
  }
  .fea_cont_yellow,
  .fea_cont_yellow02 {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 29px;
  padding-top: 30px;
  padding-bottom: 30px;
  width: 32%;
  font-size: 1.8rem;
  }
  .fea_cont_yellow02 {
  display: block;
  padding: 30px 40px;
  width: 49%;
  }
  .fea_cont_yellow .yellow_txt {
  font-size: 1.8rem;
  }
  .fea_cont_yellow02 .yellow_txt {
  padding-bottom: 25px;
  font-size: 1.5rem;
  line-height: 170%;
  }
}

/*************************************************/
/*    how to use
/*************************************************/

h2.h2_stepttl {
font-family: "EB Garamond", system-ui;
padding: 13px 20px;
font-size: 2.1rem;
font-weight: 500;
color: #180d0a;
}
h3.h3_point {
padding: 0px 0px 10px 33%;
font-size: 1.6rem;
font-weight: 600;
line-height: 130%;
}
.point_cont.point02 h3.h3_point,
.point_cont.point03 h3.h3_point {
padding-left: 36%;
}
.howto_marker {
margin: 0px auto;
padding: 10px 0px;
width: 80%;
font-size: 1.8rem;
line-height: 150%;
text-decoration: underline;
text-decoration-thickness: 8px; /* 黄色マーカーの太さ */
text-decoration-color: #ffe921; /* マーカーの色 */
text-underline-offset: -4px; /* マーカーの位置 */
text-decoration-skip-ink: none; /*線がテキストと重なっても途切れさせない */
}
.howto_txt01 {
margin: 0px auto;
padding: 0px;
width: 80%;
font-size: 1.4rem;
line-height: 140%;
}
.howto_txt02 {
font-size: 1.4rem;
line-height: 140%;
}
.how_step {
display: flex;
justify-content: space-between;
margin: 8px auto 20px;
width: 80%;
max-width: 910px;
}
.how_step .step_cont {
width: 31%;
max-width: 268px;
font-size: 1.2rem;
text-align: center;
line-height: 110%;
}
.how_step .step_cont img {
display: block;
margin-bottom: 8px;
width: 100%;
height: auto;
}
.step_wrp {
margin: 20px 0px 25px;
width: 100%;
background: #fff;
border: 1px solid #c6c6c6;
}
.step_cont01,
.step_cont02 {
padding: 10px;
border-top: 1px solid #c6c6c6;
}
.step_cont02 {
padding-bottom: 0px;
}
.step_waku_wrp {
position: relative;
margin-bottom: 20px;
padding: 20px 20px 10px 20px;
width: 100%;
background: #fff0e3;
}
.step_waku_wrp:last-of-type {
margin-bottom: 0px;
}
.step_waku_wrp:after {
content: "";
position: absolute;
bottom: -10px;
left: 0px;
width: 100%;
height: 1px;
background: #c6c6c6;
}
.step_waku_wrp:last-of-type:after {
content: none;
}
.step_waku_wrp.third_step {
margin-bottom: 0px;
}
.step_waku_wrp.third_step:after {
content: none;
}
.step_waku_wrp .step02 {
margin: 10px auto 0px;
width: 55%;
max-width: 322px;
}
.step_waku_wrp03 {
margin: 10px;
width: 100%;
}
.step_waku_wrp .step02 img,
.step_waku_wrp .step03 img {
width: 100%;
height: auto;
}
.step_wrp_btm {
position: relative;
margin: 0px 10px 10px;
padding: 0px 0px 7%;
background: #a8a694;
}
.step_wrp_btm:before {
content: "";
position: absolute;
bottom: 0px;
left: 13%;
width: 62.9%;
height: 30.7%;
background: #f8e438;
}
.step_wrp_btm.step02_btm {
padding: 0px 0px 10%;
}
.step_wrp_btm.step02_btm:before {
height: 100%;
}
.step_wrp_btm img {
width: 100%;
height: auto;
}
.howto_video {
margin: 20px auto;
padding-bottom: 10px;
width: 90%;
max-width: 1140px;
background: #333;
}
.how_youtube {
margin: 0px auto 8px;
padding: 0px 5%;
width: 95%; /* 任意の横幅を指定 */
max-width: 580px;
aspect-ratio: 16/9;
}
.how_youtube_ttl {
margin: 0px auto;
padding: 17px 0px 17px;
width: 95%;
max-width: 475px;
font-size: 1.35rem;
font-weight: 400;
text-align: center;
color: #fff;
line-height: 150%;
text-decoration: underline;
text-decoration-thickness: 2px; /* 黄色マーカーの太さ */
text-decoration-color: #ffe921; /* マーカーの色 */
text-underline-offset: 9px; /* マーカーの位置 */
text-decoration-skip-ink: none; /*線がテキストと重なっても途切れさせない */
}
.how_youtube iframe {
width: 100%;
height: 100%;
}
.point_circle .point_cont {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
margin: -55px auto;
padding: calc(12em * (1.41421356237 - 1) / 2 );
width: 22em;
height: 22em;
border-radius: 50%;
font-size: 1vw;
text-align: left;
background-image: url("../images/how_point01.svg");
background-size: 85% auto;
background-position: center;
background-repeat: no-repeat;
}
.point_circle .point_cont.point02 { background-image: url("../images/how_point02.svg"); }
.point_circle .point_cont.point03 { background-image: url("../images/how_point03.svg"); }

.point_cont .point_txt {
padding-left: 33%;
line-height: 140%;
}
.point_cont.point02 .point_txt,
.point_cont.point03 .point_txt {
padding-left: 36%;
}
.how_insert {
margin-top: 45px;
width: 100%;
}
.how_insert img {
width: 100%;
height: auto;
}
.accordion {
margin: 0px auto;
width: 90%;
max-width: 1084px;
border-top: 1px solid #000;
}
.accordion-item {
width: 100%;
border-bottom: 1px solid #000;
}
.accordion-header {
position: relative;
padding: 20px 40px 20px 10px;
font-weight: 500;
line-height: 130%;
cursor: pointer;
}
.accordion-header:hover {
opacity: 0.7;
transition: all 0.3s;
}
.accordion-content {
display: none;
padding: 10px;
color: #c24827;
}
.accordion-header:before, .accordion-header:after {
position: absolute;
content: "";
top: 0;
bottom: 0;
right: 10px;
width: 25px;
height: 2px;
margin: auto 0;
background-color: #221d1c;
transition: all 0.3s;
}
.accordion-header:after {
transform: rotate(90deg);
}
.accordion-header.active::before {
transform: rotate(180deg);
}
.accordion-header.active::after {
transform: rotate(180deg);
opacity: 0;
}
@media screen and (max-width: 374px) {
  .how_youtube_ttl {
  font-size: 1.2rem;
  }
}
@media screen and (max-width: 1083px){
  .point_circle .point_cont {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 961px) {
  h2.h2_stepttl {
  padding: 30px 35px;
  font-size: 5.0rem;
  }
  .howto_marker {
  padding: 20px 0px;
  font-size: 4.0rem;
  font-weight: 400;
  text-align: center;
  line-height: 140%;
  text-decoration-thickness: 12px; /* 黄色マーカーの太さ */
  text-underline-offset: -5px; /* 黄色マーカーの位置 */
  }
  .howto_txt01 {
  margin-top: -25px;
  font-size: 2.5rem;
  text-align: center;
  }
  .howto_txt02 {
  padding: 15px 0px 0px;
  font-size: 1.7rem;
  line-height: 160%;
  }
  .step_waku_wrp.second_step .howto_txt02 {
  height: 220px;
  }
  .how_step {
  margin: 20px auto 40px;
  }
  .how_step .step_cont {
  margin: 0px 18px;
  justify-content: center;
  font-size: 1.7rem;
  font-weight: 400;
  }
  .how_step .step_cont img {
  margin-bottom: 15px;
  }
  .step_wrp {
  margin: 90px 0px 0px;
  }
  .step_wrp:first-of-type {
  margin-top: 70px;
  }
  .step_cont01,
  .step_cont02 {
  display: flex;
  justify-content: space-between;
  }
  .step_cont02 {
  position: relative;
  }
  .step_cont02.arrow:before {
  content: "";
  position: absolute;
  top: 53.5%;
  left: 50%;
  width: 80%;
  max-width: 776px;
  height: 17px;
  background-image: url("../images/how_step02_arrow.svg");
  background-size: 100% auto;
  background-position: center;
  background-repeat: no-repeat;
  transform: translate(-50%, -50%); /* positionに対して要素を中央に配置させる */
  z-index: 10;
  }
  .step_waku_wrp {
  margin: 0px 12px 0px 12px;
  padding: 55px 60px;
  width: 50%;
  }
  .step_waku_wrp.first_step {
  height: 222px;
  }
  .step_waku_wrp.second_step {
  padding: 55px 30px 10px;
  }
  .step_waku_wrp.third_step {
  padding-bottom: 10px;
  width: 80%;
  }
  .step_waku_wrp.third_step:after {
  content: none;
  }
  .step_waku_wrp:first-of-type {
  margin-left: 0px;
  }
  .step_waku_wrp:last-of-type {
  margin-right: 0px;
  }
  .step_waku_wrp:after {
  bottom: 0px;
  left: auto;
  right: -12px;
  width: 1px;
  height: 100%;
  }
  .step_wrp_btm {
  padding: 0px 0px 5%;
  }
  .step_wrp_btm:before {
  left: 9%;
  width: 75.5%;
  height: 32.5%;
  }
  .step_waku_wrp .step02 {
  margin-left: -12px;
  width: 110%;
  }
  .step_wrp_btm.step02_btm {
  padding-bottom: 5.5%;
  }
  .howto_video {
  margin-top: 90px;
  }
  .how_youtube_waku {
  margin: 0px auto 30px;
  padding: 50px 0px 35px;
  width: 80%;
  max-width: 580px;
  background: #000;
  border-radius: 13px;
  }
  .how_youtube {
  padding: 0px;
  width: 100%;
  }
  .how_youtube_ttl {
  position: relative;
  padding: 40px 15px 40px;
  font-size: 2.0rem;
  text-decoration: none;
  }
  .how_youtube_ttl:after {
  content: "";
  position: absolute;
  bottom: 28px;
  right: -26px;
  width: 100%;
  height: 45px;
  background-image: url("../images/how_video_line.svg");
  background-repeat: no-repeat;
  }
  .accordion {
  margin: 55px auto 100px;
  }
  .accordion-header {
  padding: 40px 95px 40px 25px;
  font-size: 1.7rem;
  }
  .accordion-header:before, .accordion-header:after {
  right: 25px;
  width: 40px;
  }
  .accordion-content {
  padding: 0px;
  }
  .accordion-content {
  padding: 0px 80px 40px 25px;
  }
}
@media screen and (min-width: 1084px){
  h3.h3_point {
  padding: 0px 10px 10px 33%;
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 130%;
  }
  .point_cont.point02 h3.h3_point,
  .point_cont.point03 h3.h3_point {
  padding: 0px 15px 10px 38%;
  }
  .point_circle {
  display: flex;
  justify-content: space-between;
  margin: 55px auto 130px;
  width: 100%;
  max-width: 1084px;
  }
  .point_circle .point_cont {
  margin: 0px auto;
  padding: 40px 35px 40px 40px;
  width: 352px;
  height: 280px;
  background-size: 319px auto;
  }
  .point_circle .point_cont.point02 {
  background-size: 312px auto;
  }
  .point_circle .point_cont.point03 {
  background-size: 311px auto;
  }
  .point_cont .point_txt {
  padding: 0px 15px 0px 33%;
  font-size: 1.5rem;
  }
  .point_cont.point02 .point_txt,
  .point_cont.point03 .point_txt {
  padding: 0px 15px 0px 38%;
  }
}
@media screen and (min-width: 1190px) {
  .step_cont02.arrow:before {
  top: 47.5%;
  left: 50%;
  }
  .step_wrp_btm:before {
  height: 31%;
  }
}

/*************************************************/
/*    line up
/*************************************************/

h2.h2_lineup {
font-family: "EB Garamond", system-ui;
padding: 3px 0px 7px;
font-size: 2.5rem;
font-weight: 500;
line-height: 110%;
}
.lineup_wrp {
margin-top: 50px;
max-width: 1140px;
}
.lineup_wrp.firstwrp {
margin-top: 30px;
}
.lineup_cont {
text-align: center;
}
.lineup_read {
font-size: 1.4rem;
font-weight: 600;
color: #8a7867;
}
.lineup_price {
margin: 0px auto;
width: 90%;
font-size: 1.4rem;
font-weight: 500;
line-height: 130%;
}
.lineup_price:first-of-type {
padding-bottom: 3px;
}
ul.lineyup_detial {
margin: 15px auto 10px;
width: 90%;
border-top: 1px solid #d0b9a1;
}
ul.lineyup_detial li {
padding: 12px 20px 12px 15px;
color: #502b00;
text-align: left;
line-height: 130%;
border-bottom: 1px solid #d0b9a1;
}
ul.lineyup_detial h3.h3_lineup {
padding-bottom: 3px;
font-size: 1.5rem;
font-weight: 600;
}
ul.lineyup_detial p.li_de {
font-size: 1.3rem;
font-weight: 500;
}
.lineup_img {
margin: 20px auto 15px;
padding: 20px 23% 15px;
width: 90%;
background: #f7ece0;
border-radius: 5px;
}
.lineup_img img {
margin-left: 22%;
width: 100%;
height: auto;
}
.lineup_img.set {
padding: 20px 14% 15px;
}
.lineup_img.set img {
margin-left: 9%;
}
.cart_price {
display: block;
width: 100%;
font-size: 1.7rem;
text-align: center;
}
@media screen and (min-width: 465px) {
  .color_lineup {
  display: flex;
  align-items: center;
  padding-right: 5%;
  }
  .color_lineup .prod_color {
  margin: -20px 0px 0px 0px;
  }
  .cor_img.lineup .circle {
  padding: 80%;
  }
  ul.lineyup_detial p.li_de {
  margin: 0px 25px 0px 0px;
  font-size: 1.45rem;
  }
}
@media screen and (min-width: 961px) {
  h2.h2_lineup {
  font-size: 4.8rem;
  }
  .lineup_wrp {
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
  margin: 0px auto;
  padding: 85px 0px;
  width: 95%;
  border-bottom: 1px solid #d0b9a1;
  }
  .lineup_wrp.firstwrp {
  margin-top: 0px;
  padding-top: 0px;
  }
  .lineup_wrp.btmwrp {
  padding-bottom: 0px;
  border-bottom: none;
  }
  .lineup_cont {
  display: flex;
  align-items: center;
  width: 42%;
  text-align: left;
  }
  .lineup_cont02 {
  width: 100%;
  }
  .lineup_read {
  font-size: 1.7rem;
  }
  .lineup_img {
  display: flex;
  align-items: center;
  margin: 0px;
  padding: 80px 0px;
  width: 50%;
  height: 650px;
  }
  .lineup_img.set {
  padding: 40px 0px;
  }
  .lineup_img img.pauder {
  margin-left: 51%;
  max-width: 348px;
  }
  .lineup_img img.spray {
  margin-left: 74%;
  max-width: 294px;
  }
  .lineup_img.set img {
  margin-left: 10%;
  max-width: 541px;
  }
  .lineup_price {
  margin: 0px;
  padding: 8px 0px;
  width: 95%;
  font-size: 1.6rem;
  }
  .lineup_price:first-of-type {
  padding-top: 15px;
  }
  ul.lineyup_detial {
  width: 100%;
  }
  ul.lineyup_detial li {
  padding: 15px 20px 15px 15px;
  }
  ul.lineyup_detial h3.h3_lineup {
  padding-bottom: 6px;
  font-size: 1.7rem;
  }
  .cor_img.lineup .circle {
  padding: 122%;
  }
  .cart_cont.lineup {
  flex-wrap: nowrap;
  margin: 37px 0px 0px;
  padding: 23px 20px 23px 28px;
  width: 100%;
  max-width: none;
  font-size: 2.0rem;
  font-weight: 500;
  }
  .cart_price {
  display: inline-block;
  margin-top: 3px;
  width: auto;
  font-size: 2.0rem;
  font-weight: 500;
  text-align: left;
  }
}
@media screen and (min-width: 1164px) {
  .t_cart_icon.lineup { /* SVG mask-image */
  margin-left: 18%;
  padding: 13px 20px;
  }
}

/*************************************************/
/*    about us
/*************************************************/

h2.h2_about {
font-family: "EB Garamond", system-ui;
margin: 0px 0px 10px;
font-size: 2.6rem;
font-weight: 500;
line-height: 115%;
text-align: center;
}
h2.h2_about.wid {
margin-top: 35px;
padding: 20px 0px 5px;
width: 100%;
border-top: 1px solid #e6e1db;
}
h3.h3_about {
font-family: "EB Garamond", system-ui;
margin: 0px 0px 10px;
font-size: 2.2rem;
font-weight: 500;
line-height: 125%;
text-align: center;
}
.about_txt {
margin: 0px auto 15px;
width: 85%;
font-size: 1.2rem;
line-height: 150%;
}
.about_img {
margin: 10px auto;
width: 35%;
text-align: center;
}
.about_img img {
width: 100%;
height: auto;
}
.abimg01 {
max-width: 166px;
}
.abimg02 {
width: 70%;
max-width: 528px;
}
.abimg03 {
max-width: 158px;
}

/* slider */
.slider_about {
margin: 0px auto;
width: 60%;
max-width: 475px;
margin-bottom: 30px;
}
.slider_ab_img {
width: 100%;
}
.slider_ab_img img {
width: 100%;
height: auto;
object-fit: cover;
}
.slick-dots li {
margin: 0px !important;
}
.slick-dots li button:before {
font-size: 10px !important;
top: 3px !important;
}
dl.about_company {
display: flex;
flex-wrap: wrap;
margin: 0px auto;
width: 90%;
max-width: 955px;
border-top: 1px solid #332c2b;
border-left: 1px solid #332c2b;
}
dl.about_company dt {
display: flex;
align-items: center;
padding: 9px 10px 9px 15px;
width: 40%;
font-size: 1.4rem;
line-height: 130%;
font-weight: 600;
border-bottom: 1px solid #332c2b;
border-right: 3px solid #332c2b;
}
dl.about_company dd {
display: flex;
align-items: center;
padding: 9px 10px 9px 15px;
width: 60%;
font-size: 1.3rem;
line-height: 130%;
border-bottom: 1px solid #332c2b;
border-right: 3px solid #332c2b;
}
.about_contact {
margin: 25px auto;
padding: 25px 30px 23px;
width: 90%;
max-width: 770px;
background: #fff0e3;
}
.about_contact .abcont_read {
padding-bottom: 12px;
font-size: 1.4rem;
font-weight: 600;
line-height: 150%;
text-align: center;
}
@media screen and (min-width: 961px) {
  h2.h2_about {
  padding-top: 90px;
  font-size: 6.5rem;
  }
  h2.h2_about.wid {
  margin-top: 95px;
  padding: 65px 0px 5px;
  }
  h3.h3_about {
  margin: 0px 0px 20px;
  padding-top: 60px;
  font-size: 4.0rem;
  }
  .about_txare h2.h2_about {
  padding-top: 0px;
  text-align: left;
  width: 100%;
  }
  .about_txare.right h2.h2_about {
  padding-top: 0px;
  text-align: right;
  }
  .about_txcont {
  margin: 0px auto;
  padding: 0px 30px;
  width: 100%;
  max-width: 1140px;
  }
  .about_txare .about_txt {
  text-align: left;
  line-height: 190%;
  }
  .about_txare.right .about_txt {
  margin-bottom: 80px;
  text-align: right;
  }
  .about_txare.right {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  }
  .about_txt {
  margin: 20px 0px 30px;
  width: auto;
  font-size: 1.7rem;
  font-weight: 400;
  line-height: 170%;
  text-align: center;
  }
  .about_img {
  padding-bottom: 30px;
  }
  .slick-dotted.slick-slider {
  margin-bottom: 70px !important;
  }
  dl.about_company {
  margin-top: 40px;
  }
  dl.about_company dt {
  padding: 25px 10px 25px 40px;
  width: 28%;
  font-size: 2.0rem;
  border-right: 10px solid #332c2b;
  }
  dl.about_company dd {
  padding: 25px 10px 25px 40px;
  width: 72%;
  font-size: 1.9rem;
  font-weight: 400;
  border-right: 1px solid #332c2b;
  }
  .about_contact {
  margin: 70px auto 50px;
  padding: 45px 25px;
  }
  .about_contact .abcont_read {
  padding-bottom: 25px;
  font-size: 2.0rem;
  }
}

/*************************************************/
/*    bottom product
/*************************************************/

h2.h2_btm_product {
font-family: "EB Garamond", system-ui;
margin: 30px 0px 0px;
padding: 25px 30px 20px;
width: 100%;
font-size: 3.3rem;
font-weight: 500;
text-align: center;
line-height: 120%;
border-top: 1px solid #e6e1db;
}
h3.h3_btm_product {
padding: 0px 30px 15px;
font-size: 1.5rem;
font-weight: 500;
text-align: center;
line-height: 120%;
}
h3.h3_btm_product span.cost_pc {
display: none;
}
.scroll_product_btm {
white-space: nowrap;
overflow-x: auto;
margin: 0px 0px 0px 15px;
}
.product_item {
display: flex;
width: 900px;
}
.product_item .item {
margin: 0px 10px;
padding-bottom: 20px;
width: 240px;
background: #fff0e3;
border-radius: 5px;
}
.product_item .item#menu6 {
width: 320px;
}
.product_item .item .image {
margin: 0px auto;
text-align: center;
cursor: pointer;
}
.product_item .item .image:hover {
opacity: 0.7;
}
.product_item .image img {
width: 100%;
height: auto;
}

@media screen and (min-width: 961px) {
  h2.h2_btm_product {
  margin-top: -55%;
  padding: 0px 30px 20px;
  font-size: 5.5rem;
  text-align: left;
  line-height: 140%;
  border: none;
  }
  h3.h3_btm_product {
  margin: 20px 0px 0px 0px;
  padding: 0px 5px 0px;
  width: 75%;
  font-size: 1.6rem;
  color: #502b00;
  text-align: left;
  line-height: 120%;
  white-space: break-spaces;
  }
  h3.h3_btm_product:hover {
  opacity: 0.7;
  }
  h3.h3_btm_product span.h3_small {
  font-size: 1.45rem;
  }
  h3.h3_btm_product span.cost_pc {
  display: block;
  padding-top: 5px;
  font-size: 1.4rem;
  font-weight: 600;
  }
  .scroll_product_btm {
  position: relative;
  margin: 80px 0px 0px;
  }
  .scroll_product_btm_line {
  margin-top: 80px;
  width: 100%;
  height: 1px;
  border-top: 1px solid #e6e1db;
  }
  .pc_ttl {
  display: flex !important;
  align-items: center;
  margin: 0px;
  }
  .product_item {
  width: 1350px;
  }
  .product_item .item {
  margin: 0px 15px;
  width: inherit;
  background: #fff;
  }
  .product_item .item .image {
  margin: 0px auto;
  width: 320px;
  height: 380px;
  }
  .product_item .image img {
  padding-bottom: 40px;
  }
  .prod_btm_txt {
  display: flex;
  cursor: pointer;
  }
}
@media screen and (min-width: 1330px) {
  .scroll_product_btm {
  margin: 80px auto 0px;
  max-width: 1350px;
  }
}

/*************************************************/
/*    contact
/*************************************************/

.contact_bg {
padding: 0px 20px 30px;
width: 100%;
background: #f7ece0;
}
.contact_txt {
margin: 0px auto;
padding: 35px 0px 10px;
width: 90%;
font-size: 1.5rem;
text-align: center;
}
.recaptcha_bg {
margin: 10px auto 0px;
padding: 15px 10px;
width: 100%;
min-width: 335px;
max-width: 500px;
font-size: 1.2rem;
text-align: center;
line-height: 140%;
color: #6f6f6f;
background: #e5e5e5;
border-radius: 3px;
}
.recaptcha_bg a {
color: #e60012;
text-decoration: underline;
}
.recaptcha_bg a:hover {
color: #fd404e;
text-decoration: none;
}
/* rechaptureロゴ非表示 */
.grecaptcha-badge { visibility: hidden; }

@media screen and (min-width: 1190px) {
  .contact_bg {
  padding: 90px 20px 10px;
  }
  .contact_txt {
  padding: 70px 0px 20px;
  font-size: 1.9rem;
  line-height: 180%;
  }
  .recaptcha_bg {
  margin: 35px auto 0px;
  padding: 20px 10px;
  font-size: 1.4rem;
  }
}

/*************************************************/
/*    footer
/*************************************************/

footer {
width: 100%;
margin: 30px 0px 0px;
padding: 25px 0px 20px;
color: #fff;
background: #180d0a;
}
.f_logo {
margin: 0px auto;
width: 100%;
max-width: 100px;
}
.f_logo img {
width: 100%;
height: auto;
}
.f_right {
display: none;
}
.address {
padding: 0px 30px 15px;
font-size: 1.1rem;
font-weight: 400;
text-align: center;
line-height: 130%;
}
.address span.company {
display: block;
padding: 5px 0px 8px;
font-size: 1.3rem;
font-weight: 500;
}
.copyright {
width: 100%;
font-size: 1.0rem;
font-weight: 400;
text-align: center;
line-height: 150%;
color: #f4efe9;
letter-spacing: 0.08em;
}
@media screen and (max-width: 1189px) {
  .sp_copyright {
  display: block;
  }
  .pc_copyright {
  display: none;
  }
}
@media screen and (min-width: 1280px) {
  footer {
  margin-top: 100px;
  padding: 40px 0px 30px;
  }
  .foot {
  display: flex;
  justify-content: space-between;
  margin: 35px auto;
  max-width: 1230px;
  }
  .f_left {
  width: 40%;
  }
  .f_logo {
  margin: 0px;
  max-width: 117px;
  }
  .address {
  padding: 5px 0px 10px;
  font-size: 1.35rem;
  text-align: left;
  line-height: 170%;
  letter-spacing: 0.09em;
  }
  .address span.company {
  font-size: 1.6rem;
  }
  .f_logo {
  width: 30%;
  }
  .f_right {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 20px;
  width: 60%;
  }
  ul.f_nav {
  display: flex;
  justify-content: space-between;
  width: 100%;
  }
  ul.f_nav li a {
  display: block;
  padding: 0px;
  font-size: 1.6rem;
  font-weight: 400;
  text-align: center;
  color: #fff;
  letter-spacing: 0.09em;
  }
  .h_contact.f_nav {
  position: relative;
  padding: 12px 54px;
  font-size: 1.8rem;
  font-weight: 600;
  border-radius: 3px;
  color: #1c1416;
  margin: -12px 0px 0px;
  max-width: 190px;
  }
  .h_contact.f_nav:hover {
  color: #d7d7d7;
  }
  .copyright {
  padding-top: 5px;
  font-size: 1.1rem;
  text-align: left;
  line-height: 140%;
  width: 100%;
  letter-spacing: 0.09em;
  }
  .sp_copyright {
  display: none;
  }
  .pc_copyright {
  display: block;
  }
}
