@charset "UTF-8";
/*@import "variables";*/
/* デバイスサイズ */
/* ====================================================================== */
/* ベースの値 */
/* ====================================================================== */
/*1.5px*/
/* デバイス */
/* ====================================================================== */
/* フォント */
/* ====================================================================== */
/* flex */
/* ====================================================================== */
/* absolute */
/* ====================================================================== */
/* filter */
/* ====================================================================== */
/* 基本的な共通クラス */
/* ====================================================================== */
body { font-family: "Noto Serif", serif; color: #5E5946; line-height: 1.6; letter-spacing: 1px; text-align: left; font-weight: 400; background-color: #FFFFFF; }

h2 { font-family: "Cormorant Garamond", serif; color: #5E5946; font-size: clamp(30px, 3.5vw, 50px); font-weight: 400; line-height: 1; }

p { font-size: 11px; font-weight: 500; }
@media (min-width: 768px) { p { font-size: min(1.5vw, 15px); } }

.jump { display: block; padding-top: 70px; margin-top: -70px; }

@media (min-width: 768px) { .sp_only { display: none; } }

.sp_none { display: none; }
@media (min-width: 768px) { .sp_none { display: inline-block; } }

/*kotei */
/* ====================================================================== */
.kotei { position: fixed; display: block; bottom: 16px; right: 20px; }
@media (min-width: 768px) { .kotei { bottom: 33px; right: 33px; } }
.kotei__btn { background-color: rgba(255, 255, 255, 0.3); border-radius: 50%; width: 30px; height: 30px; }
@media (min-width: 768px) { .kotei__btn { width: 50px; height: 50px; } }
.kotei__btn img { width: 100%; }

.slow { opacity: 0; transform: translateY(30px); transition: opacity 1.5s ease-out, transform 1.5s ease-out; }

.slow.is-show { opacity: 1; transform: translateY(0); }

.slow:nth-child(1) { transition-delay: 0s; }

.slow:nth-child(2) { transition-delay: 0.3s; }

.slow:nth-child(3) { transition-delay: 0.6s; }

.slow:nth-child(4) { transition-delay: 0.9s; }

.slow:nth-child(5) { transition-delay: 1.2s; }

.slow:nth-child(6) { transition-delay: 1.5s; }

.slow:nth-child(7) { transition-delay: 1.8s; }

.slow:nth-child(8) { transition-delay: 2.1s; }

.slow:nth-child(9) { transition-delay: 2.4s; }

.slow:nth-child(10) { transition-delay: 2.7s; }

/* ======================================================================  Header ====================================================================== */
.header { position: fixed; top: 0; left: 0; width: 100%; z-index: 9999; padding: 20px 30px; /* ロゴ・コンセプトエリア */ /* 共通ナビゲーション（ドロワー & PCメニュー） */ /* メニュー内のスマホ用ヘッダー（ロゴとCLOSEボタン） */ /* メニュー内の閉じるボタン（×） */ /* ナビゲーションリスト */ /* サブメニュー（face, head...） */ /* スマホ用下部インフォメーション */ /* 外側のハンバーガーボタン（MENU + 2本線） */ }
@media (min-width: 1080px) { .header { padding: 30px 50px; } }
.header__inner { display: flex; justify-content: space-between; align-items: flex-start; }
.header__logo-area { display: flex; align-items: center; gap: 7px; position: relative; }
@media (min-width: 1080px) { .header__logo-area { gap: 20px; } }
.header__logo-area::before { content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 230px; height: 60px; background-color: #8AAA6C; opacity: 0.2; border-radius: 30%; filter: blur(15px); z-index: 0; }
@media (min-width: 1080px) { .header__logo-area::before { width: 410px; height: 90px; filter: blur(30px); } }
.header__logo { margin: 0; }
.header__logo-sub { display: block; }
.header__logo-sub img { width: auto; height: 12px; }
@media (min-width: 1080px) { .header__logo-sub img { height: 17px; } }
.header__logo-main { margin-left: 50px; }
@media (min-width: 1080px) { .header__logo-main { margin-left: 75px; } }
.header__logo-main img { width: auto; height: 40px; position: relative; top: -9px; }
@media (min-width: 1080px) { .header__logo-main img { height: 80px; top: -15px; } }
.header__concept { display: block; text-align: center; }
.header__concept .en { display: block; font-size: 6px; font-family: "Cormorant Garamond", serif; }
@media (min-width: 1080px) { .header__concept .en { font-size: 13px; } }
.header__concept .jp { display: block; font-size: 6px; margin-top: 2px; }
@media (min-width: 1080px) { .header__concept .jp { font-size: 12px; } }
.header__nav { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: #89A073; color: #fff; z-index: 1000; padding: 20px 30px; overflow-y: auto; opacity: 0; visibility: hidden; transition: 0.4s ease; }
.header__nav.is-open { opacity: 1; visibility: visible; }
.header__nav.is-open .header__logo-sub, .header__nav.is-open .header__logo-main { filter: invert(100%) brightness(200%) contrast(100%); }
@media (min-width: 1080px) { .header__nav { position: static; width: auto; height: auto; background: none; color: #5E5946; padding: 0; opacity: 1; visibility: visible; overflow: visible; } }
.header__nav-inner { display: flex; flex-direction: column; min-height: 100%; }
@media (min-width: 1080px) { .header__nav-inner { min-height: auto; } }
.header__nav .header__logo-sub img { height: 10px; position: relative; left: -17px; }
.header__nav .header__logo-area { flex-direction: column; padding-left: 10px; }
.header__nav .header__logo-main { margin-left: 0px; }
.header__nav .header__logo-main img { height: 60px; top: 10px; }
.header__nav-sp-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 30px; }
@media (min-width: 1080px) { .header__nav-sp-top { display: none; } }
.header__nav-sp-top .header__logo-sub, .header__nav-sp-top .header__logo-main { color: #fff; }
.header__nav-close { background: none; border: none; color: #fff; text-align: center; cursor: pointer; }
.header__nav-close .close-label { font-size: 10px; font-family: "Cormorant Garamond", serif; display: block; margin-bottom: 5px; }
.header__nav-close .close-lines { width: 30px; height: 12px; position: relative; margin: 0 auto; }
.header__nav-close .close-lines span { display: block; width: 100%; height: 1px; background-color: #fff; position: absolute; left: 0; top: 50%; }
.header__nav-close .close-lines span:nth-child(1) { transform: rotate(15deg); }
.header__nav-close .close-lines span:nth-child(2) { transform: rotate(-15deg); }
.header__nav-list { margin-bottom: 60px; width: 70%; margin: auto; }
@media (min-width: 1080px) { .header__nav-list { display: flex; width: 100%; gap: 40px; margin-bottom: 0; font-family: "Cormorant Garamond", serif; } }
.header__nav-list li { margin-bottom: 20px; }
@media (min-width: 1080px) { .header__nav-list li { margin-bottom: 0; position: relative; } }
.header__nav-list li a { font-size: 22px; font-family: "Cormorant Garamond", serif; }
@media (min-width: 1080px) { .header__nav-list li a { font-size: 20px; } }
.header .sub-menu { margin-top: 10px; border-left: 1px solid rgba(255, 255, 255, 0.5); padding-left: 20px; }
@media (min-width: 1080px) { .header .sub-menu { position: absolute; top: 100%; left: 0; border-left: 1px solid #ccc; padding: 0px 0 0 10px; margin-top: 0; opacity: 0; visibility: hidden; transition: 0.3s; margin-top: 5px; } }
.header .sub-menu li { margin-bottom: 2px; }
.header .sub-menu li a { font-size: 20px; font-family: "Cormorant Garamond", serif; }
@media (min-width: 1080px) { .header .sub-menu li a { font-size: 18px; } }
@media (min-width: 1080px) { .header .has-child:hover .sub-menu { opacity: 1; visibility: visible; } }
.header .sub-menu a:hover { opacity: .5; position: relative; top: -2px; }
.header__nav-info { margin-top: auto; padding-bottom: 40px; line-height: 1.8; font-weight: 500; }
@media (min-width: 1080px) { .header__nav-info { display: none; } }
.header__nav-info .address { font-size: 13px; }
.header__nav-info .map-link { display: inline-block; text-decoration: underline; margin: 5px 0 20px; font-size: 11px; }
.header__nav-info .business-hours { font-size: 11px; }
.header__nav-info .copy { margin-top: 20px; font-family: "Cormorant Garamond", serif; font-weight: 400; font-size: 13px; }
.header__menu-btn { display: block; background: none; border: none; cursor: pointer; padding: 0; }
@media (min-width: 1080px) { .header__menu-btn { display: none; } }
.header__menu-btn .header__menu-label { display: block; font-size: 10px; font-family: "Cormorant Garamond", serif; margin-bottom: 5px; color: #5E5946; transition: opacity 0.3s; }
.header__menu-btn .header__menu-lines { width: 30px; height: 10px; position: relative; margin: 0 auto; }
.header__menu-btn .header__menu-lines span { display: block; width: 100%; height: 1px; background-color: #5E5946; position: absolute; left: 0; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); }
.header__menu-btn .header__menu-lines span:nth-child(1) { top: 0; }
.header__menu-btn .header__menu-lines span:nth-child(2) { bottom: 0; }
.header__menu-btn.is-active .header__menu-label { opacity: 0; }
.header__menu-btn.is-active .header__menu-lines span { background-color: #fff; top: 50%; }
.header__menu-btn.is-active .header__menu-lines span:nth-child(1) { transform: rotate(15deg); }
.header__menu-btn.is-active .header__menu-lines span:nth-child(2) { transform: rotate(-15deg); }

.pc-only { display: none; }
@media (min-width: 1080px) { .pc-only { display: inline-block; transform: rotate(180deg); vertical-align: middle; transition: .3s; } }

@media (min-width: 1080px) { .has-child:hover .pc-only { transform: none; } }

/* ======================================================================  First View ====================================================================== */
.fv { position: relative; height: 100vh; width: 100%; overflow: hidden; background-image: url("../img/fv_bg.png"); background-repeat: no-repeat; background-size: cover; background-position: left; padding-top: min(25vw, 132px); background-attachment: fixed; }
.fv__bg { width: 100%; height: 100%; }
.fv__bg img { width: 100%; height: 72%; object-fit: cover; object-position: top; }
@media (min-width: 1080px) { .fv__bg img { width: 90%; height: 100%; } }
.fv__cta { position: fixed; right: 20px; bottom: 30px; width: 110px; height: 110px; background: transparent; backdrop-filter: none; color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; text-align: center; transition: 0.3s; z-index: 500; }
@media (min-width: 1080px) { .fv__cta { width: 200px; height: 200px; right: 75px; bottom: 50px; } }
.fv__cta::before { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(165, 190, 140, 0.9); border-radius: 50%; filter: blur(5px); box-shadow: 0 0 30px 3px rgba(165, 190, 140, 0.9); z-index: -1; transition: 0.3s; }
.fv__cta:hover { transform: scale(1.02); }
.fv__cta:hover::before { filter: blur(8px); background: #a5be8c; }
.fv__cta-inner { position: relative; top: -5px; }
.fv__cta-img { display: block; width: 30px; margin: auto; }
@media (min-width: 1080px) { .fv__cta-img { width: 40px; } }
.fv__cta-en { display: block; font-family: "Cormorant Garamond", serif; font-size: 8px; }
@media (min-width: 1080px) { .fv__cta-en { font-size: 11px; } }
.fv__cta-jp { display: block; font-size: 13px; }
@media (min-width: 1080px) { .fv__cta-jp { font-size: 22px; margin: 2px 0; } }
.fv__cta-line { display: block; font-size: 6px; }
@media (min-width: 1080px) { .fv__cta-line { font-size: 8px; } }
.fv__scroll { display: none; }
@media (min-width: 1080px) { .fv__scroll { display: block; position: absolute; right: 30px; bottom: 0; writing-mode: vertical-rl; font-size: 11px; padding-bottom: 80px; font-family: "Cormorant Garamond", serif; }
  .fv__scroll::after { content: ""; position: absolute; bottom: 0; left: 50%; width: 1px; height: 60px; background: #5E5946; } }

/* ======================================================================  OWWNER ====================================================================== */
.owner { padding: 60px 30px; margin-top: -140px; position: relative; z-index: 1; /* 資格リストの2段組み制御 */ }
@media (min-width: 768px) { .owner { padding: 100px 50px; margin-top: 0px; } }
.owner__inner { max-width: 1000px; margin: auto; }
.owner__title-area { margin-bottom: 40px; }
.owner__title-area .en { font-size: 30px; font-family: "Cormorant Garamond", serif; margin-right: 15px; }
@media (min-width: 768px) { .owner__title-area .en { font-size: 50px; } }
.owner__title-area .jp { font-size: 11px; font-weight: normal; }
@media (min-width: 768px) { .owner__title-area .jp { font-size: 15px; } }
@media (min-width: 768px) { .owner__content { display: flex; align-items: flex-start; gap: 60px; } }
.owner__image { width: 100%; margin-bottom: 30px; }
@media (min-width: 768px) { .owner__image { width: 40%; margin-bottom: 0; } }
.owner__image img { width: 80%; height: auto; object-fit: cover; margin: auto; display: block; }
@media (min-width: 768px) { .owner__image img { width: 100%; } }
@media (min-width: 768px) { .owner__text-area { width: 60%; } }
.owner__sub-title { font-size: 11px; color: #707070; margin-bottom: 10px; font-family: "Cormorant Garamond", serif; }
@media (min-width: 768px) { .owner__sub-title { font-size: 13px; } }
.owner__name { font-size: 25px; margin-bottom: 30px; letter-spacing: 0.1em; }
@media (min-width: 768px) { .owner__name { font-size: 30px; } }
.owner__name .en { font-size: 13px; color: #707070; margin-left: 15px; font-weight: normal; font-family: "Cormorant Garamond", serif; }
@media (min-width: 768px) { .owner__name .en { font-size: 15px; } }
.owner__license-list { display: flex; flex-wrap: wrap; border-left: 1px solid #ABB2A6; margin-bottom: 40px; }
.owner__license-list li { width: 100%; font-size: 11px; line-height: 1.8; color: #666; padding-left: 20px; }
@media (min-width: 768px) { .owner__license-list li { font-size: min(1.2vw, 13px); width: 50%; } }
@media (min-width: 768px) { .owner__license-list { position: relative; }
  .owner__license-list::after { content: ""; position: absolute; left: 50%; top: 0; height: 100%; width: 1px; background-color: #ABB2A6; display: block; } }
.owner__description p { font-family: "Shippori Mincho B1", serif; font-size: 13px; line-height: 2; margin-bottom: 1.5em; }
.owner__description p:last-child { margin-bottom: 0; }

/* ======================================================================  CONXEPT ====================================================================== */
.concepts { background-color: #F7F9F6; padding: 80px 30px; /* 数字の背後のぼかし演出 */ /* view all と繊細なライン */ }
@media (min-width: 768px) { .concepts { padding: 120px 50px; } }
.concepts__inner { max-width: 1000px; margin: auto; }
.concepts h2 { text-align: center; font-size: 13px; margin-bottom: 60px; letter-spacing: 0.1em; color: #666; font-family: "Noto Serif", serif; }
@media (min-width: 1080px) { .concepts h2 { font-size: 18px; margin-bottom: 80px; } }
.concepts h2 .en { font-family: "Cormorant Garamond", serif; font-size: 30px; margin-right: 5px; }
@media (min-width: 768px) { .concepts h2 .en { font-size: 45px; } }
@media (min-width: 1080px) { .concepts__list { display: flex; justify-content: space-between; gap: 60px; } }
.concepts__item { margin-bottom: 80px; }
@media (min-width: 1080px) { .concepts__item { width: 31%; margin-bottom: 0; } }
.concepts__item:last-child { margin-bottom: 0; }
.concepts__header { position: relative; display: flex; align-items: flex-start; flex-direction: column; }
@media (min-width: 768px) { .concepts__header { margin-bottom: 30px; } }
.concepts__number { font-size: 52px; font-weight: 300; color: #B0BAAA; position: relative; z-index: 1; }
@media (min-width: 768px) { .concepts__number { margin-bottom: 60px; } }
.concepts__item-title { font-size: 35px; font-family: "Cormorant Garamond", serif; color: #516244; margin-bottom: 5px; position: relative; }
.concepts__item-title::before { content: ""; position: absolute; top: 50%; left: 25%; transform: translate(-50%, -50%); width: 60px; height: 60px; background-color: #A5BE8C; opacity: 0.2; border-radius: 50%; filter: blur(15px); z-index: 0; }
@media (min-width: 768px) { .concepts__item-title::before { width: 120px; height: 120px; } }
.concepts__item-title .jp { font-size: 23px; margin-left: 5px; font-family: "Noto Serif", serif; }
.concepts__icon { position: absolute; right: 0; bottom: 0; width: 130px; }
@media (min-width: 768px) { .concepts__icon { width: 150px; } }
.concepts__icon img { width: 100%; height: auto; position: relative; }
.concepts__icon::before { content: ""; position: absolute; top: 50%; left: 47%; transform: translate(-50%, -50%); width: 150px; height: 150px; background-color: #FFFFFF; border-radius: 50%; filter: blur(15px); z-index: 0; }
.concepts__sub-copy { font-size: 20px; color: #77876B; font-family: "Cormorant Garamond", serif; margin-bottom: 20px; }
.concepts__text { font-size: 13px; line-height: 2; color: #666; margin-bottom: 20px; text-align: justify; }
@media (min-width: 768px) { .concepts__text { font-size: 14px; } }
.concepts__link { display: flex; align-items: center; justify-content: flex-end; font-size: 20px; font-family: "Cormorant Garamond", serif; color: #666; text-decoration: none; width: 100%; position: relative; }
.concepts__link::before { content: ""; position: absolute; bottom: 8px; left: 0; right: 85px; height: 1px; background: #ABB2A6; transition: right 0.4s ease; }
.concepts__link::after { content: ""; position: absolute; bottom: 8px; right: 85px; width: 12px; height: 8px; border-right: 1px solid #ABB2A6; transform: skewX(45deg); transform-origin: bottom right; transition: right 0.4s ease; }
.concepts__link:hover { opacity: 0.8; }
.concepts__link:hover::before { right: 75px; }
.concepts__link:hover::after { right: 75px; }

/* ======================================================================  モーダルウィンドウ ====================================================================== */
.modal { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 1000; }
.modal__bg { position: absolute; width: 100%; height: 100%; background: rgba(89, 94, 86, 0.8); }
.modal__content { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 85%; max-width: 800px; background: #fff; padding: 60px 25px; border-radius: 20px; max-height: 90vh; overflow-y: auto; }
@media (min-width: 768px) { .modal__content { padding: 60px; } }
@media (min-width: 1080px) { .modal__content { padding: 70px 100px; } }
.modal__close { position: absolute; top: 20px; right: 20px; width: 21px; height: 21px; background: #ABB2A6; border-radius: 50%; border: none; cursor: pointer; z-index: 10; }
@media (min-width: 768px) { .modal__close { width: 27px; height: 27px; } }
.modal__close span { position: absolute; top: 50%; left: 50%; width: 12px; height: 1px; background: #fff; }
.modal__close span:nth-child(1) { transform: translate(-50%, -50%) rotate(45deg); }
.modal__close span:nth-child(2) { transform: translate(-50%, -50%) rotate(-45deg); }
.modal__inner { position: relative; }
.modal__sub { font-size: 11px; color: #95A38A; margin-bottom: 10px; }
.modal__title { font-size: 20px; color: #77876B; font-family: "Cormorant Garamond", serif; margin-bottom: 30px; }
.modal__title span { font-size: 15px; margin-left: 10px; }
@media (min-width: 768px) { .modal__title { font-size: 25px; margin-bottom: 50px; } }
.modal__text { font-size: 11px; line-height: 2; color: #5E5946; }
@media (min-width: 768px) { .modal__text { font-size: 14px; } }
.modal__plant { position: absolute; top: -24px; right: 8px; width: 80px; pointer-events: none; }
@media (min-width: 768px) { .modal__plant { top: -10px; right: -12px; width: 120px; } }
@media (min-width: 1080px) { .modal__plant { top: -16px; right: -32px; width: 150px; } }

/* ======================================================================  MENU ====================================================================== */
.menu { padding: 80px 0px; }
@media (min-width: 768px) { .menu { padding: 120px 0px; } }
.menu__title-area, .menu__subtitle-area { width: 90%; max-width: 1000px; margin: auto; }
.menu__title-area { margin-bottom: 40px; }
.menu .en { font-size: 30px; font-family: "Cormorant Garamond", serif; margin-right: 15px; }
@media (min-width: 768px) { .menu .en { font-size: 50px; } }
.menu .jp { font-size: 11px; font-weight: normal; }
@media (min-width: 768px) { .menu .jp { font-size: 15px; } }
.menu__subtitle-area { border-bottom: solid 1px #ABB2A6; }
@media (min-width: 768px) { .menu__subtitle-area { margin-bottom: 10px; } }
@media (min-width: 768px) { .menu__subtitle-area .en { font-size: 40px; } }
.menu img { width: 100%; max-width: 600px; display: block; margin: auto; }
@media (min-width: 768px) { .menu img { max-width: 1440px; } }
@media (min-width: 768px) { .menu__face { padding-bottom: 50px; } }
.menu__head { background-color: #F7F9F6; padding: 40px 0px; }
.menu__face-head { padding: 40px 0px; }
.menu__heart { background-color: #F7F9F6; padding: 40px 0px; }
.menu__lesson { padding: 40px 0px; }

/* ======================================================================  Q&A ====================================================================== */
.qa { background-color: #F7F9F6; padding: 80px 30px; /* Contact セクション */ }
@media (min-width: 1080px) { .qa { padding: 120px 0; } }
.qa__title { text-align: center; margin-bottom: 60px; }
.qa__title .en { font-size: 30px; font-family: "Cormorant Garamond", serif; display: block; }
@media (min-width: 1080px) { .qa__title .en { font-size: 40px; line-height: 20px; } }
.qa__title .jp { font-size: 11px; font-weight: normal; color: #666; }
.qa__container { max-width: 800px; margin: 0 auto; }
.qa__item { border-bottom: 1px solid #ccc; }
.qa__item:first-child { border-top: 1px solid #ccc; }
.qa__question { padding: 20px 0 20px 0px; display: flex; align-items: center; cursor: pointer; position: relative; /* アコーディオンの ＋ マーク */ }
.qa__question .q-icon { font-size: 25px; font-family: "Cormorant Garamond", serif; margin-right: 20px; }
@media (min-width: 1080px) { .qa__question .q-icon { font-size: 40px; } }
.qa__question .q-text { font-size: 13px; flex: 1; padding-right: 40px; }
@media (min-width: 1080px) { .qa__question .q-text { font-size: 20px; } }
.qa__question .q-toggle { position: absolute; right: 0; width: 20px; height: 20px; }
.qa__question .q-toggle::before, .qa__question .q-toggle::after { content: ""; position: absolute; background-color: #999; top: 50%; left: 50%; transform: translate(-50%, -50%); transition: 0.3s; }
.qa__question .q-toggle::before { width: 100%; height: 1px; }
.qa__question .q-toggle::after { width: 1px; height: 100%; }
.qa__question.is-open .q-toggle::after { transform: translate(-50%, -50%) rotate(90deg); opacity: 0; }
.qa__answer { display: none; padding: 0 0 20px 4px; font-size: 14px; line-height: 1.8; }
.qa__answer.is-open { display: flex; }
@media (min-width: 1080px) { .qa__answer { padding: 0 0 25px 7px; } }
.qa__answer .a-icon { font-size: 20px; font-family: "Cormorant Garamond", serif; margin-right: 20px; position: relative; top: -10px; }
@media (min-width: 1080px) { .qa__answer .a-icon { font-size: 30px; } }
.qa__answer .a-text { font-size: 11px; line-height: 1.8; display: inline-block; vertical-align: top; width: 85%; }
@media (min-width: 1080px) { .qa__answer .a-text { font-size: 13px; width: 85%; } }
.qa .contact { margin-top: 100px; text-align: center; }
.qa .contact__title { margin-bottom: 30px; }
.qa .contact__title .en { font-size: 30px; font-family: "Cormorant Garamond", serif; display: block; }
@media (min-width: 1080px) { .qa .contact__title .en { font-size: 40px; line-height: 20px; } }
.qa .contact__title .jp { font-size: 11px; font-weight: normal; }
.qa .contact__text { font-size: 11px; line-height: 2; margin-bottom: 30px; }
@media (min-width: 1080px) { .qa .contact__text { font-size: 15px; } }
.qa .contact__btn { display: inline-flex; align-items: center; justify-content: center; background-color: #7C9A64; color: #fff; text-decoration: none; width: 90%; max-width: 255px; padding: 18px 0; border-radius: 12px; font-size: 13px; transition: 0.3s; box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); letter-spacing: 3px; font-weight: 300; }
@media (min-width: 1080px) { .qa .contact__btn { font-size: 25px; letter-spacing: 4px; padding: 25px 0; border-radius: 25px; max-width: 543px; } }
.qa .contact__btn .line-icon { width: 29px; margin-right: 12px; }
@media (min-width: 1080px) { .qa .contact__btn .line-icon { width: 51px; margin-right: 22px; } }
.qa .contact__btn:hover { opacity: 0.8; transform: translateY(-2px); }

/* ======================================================================  INSTAGRAM ====================================================================== */
.instagram { background-color: #fff; padding: 60px 30px; /* タイトルとアカウント名 */ /* --- 画像グリッドエリア --- */ }
@media (min-width: 768px) { .instagram { padding: 100px 0; } }
.instagram__inner { max-width: 616px; margin: auto; }
.instagram__title-area { text-align: center; margin-bottom: 50px; }
.instagram__title { font-size: 32px; font-family: "Cormorant Garamond", serif; color: #333; margin-bottom: 10px; }
.instagram__account { font-size: 11px; color: #5E5946; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; transition: 0.3s; font-family: "Cormorant Garamond", serif; /* FontAwesomeのアイコン色を調整 */ }
@media (min-width: 1080px) { .instagram__account { font-size: 14px; } }
.instagram__account i { color: #89A073; font-size: 1.2em; }
.instagram__account:hover { opacity: 0.7; text-decoration: underline; }
.instagram .insta-icon { width: 12px; }
@media (min-width: 1080px) { .instagram .insta-icon { width: 14px; } }
.instagram__list { display: flex; flex-wrap: wrap; width: 65%; margin: auto; gap: 10px; }
@media (min-width: 768px) { .instagram__list { width: 100%; gap: 20px; } }
.instagram__item { width: 100%; aspect-ratio: 1 / 1; /* 【重要】4枚目以降をスマホでは非表示にする */ }
.instagram__item:nth-of-type(n + 4) { display: none; }
@media (min-width: 768px) { .instagram__item { width: calc((100% - 40px) / 3); /* 4枚目以降も表示する */ }
  .instagram__item:nth-of-type(n + 4) { display: block; } }
.instagram__item a { display: block; width: 100%; height: 100%; overflow: hidden; }
.instagram__item img { width: 100%; height: 100%; object-fit: cover; transition: 0.5s ease; }
.instagram__item:hover img { transform: scale(1.1); opacity: 0.8; }

/* ======================================================================  FOOTER ====================================================================== */
.footer { background-color: #89A073; color: #fff; padding: 60px 30px 30px; position: relative; z-index: 999; /* 下部エリア（コピーライト & ナビ） */ }
@media (min-width: 768px) { .footer { padding: 100px 60px 20px; } }
.footer__inner { max-width: 1100px; margin: auto; }
@media (min-width: 768px) { .footer__top { display: flex; justify-content: flex-start; gap: 120px; margin-bottom: 80px; } }
.footer__logo { width: 144px; margin-bottom: 50px; }
@media (min-width: 1080px) { .footer__logo { width: 213px; margin-bottom: 0; } }
.footer__logo img { width: 100%; height: auto; }
.footer__info p { font-size: 13px; line-height: 1.8; letter-spacing: 0.05em; }
@media (min-width: 1080px) { .footer__info p { font-size: 20px; } }
.footer__address { margin-bottom: 5px; }
.footer__map-link { margin-bottom: 30px; }
.footer__map-link a { font-size: 15px; color: #fff; text-decoration: none; border-bottom: 1px solid #fff; font-family: "Cormorant Garamond", serif; padding-bottom: 2px; }
.footer__map-link a:hover { opacity: 0.7; }
.footer__business-hours { margin-bottom: 25px; }
.footer__notes { font-size: 11px; opacity: 0.9; }
@media (min-width: 1080px) { .footer__notes { font-size: 15px; } }
.footer__notes li { margin-bottom: 5px; }
.footer__notes li::before { content: "・"; }
.footer__bottom { margin-top: 60px; }
@media (min-width: 768px) { .footer__bottom { margin-top: 0; display: flex; justify-content: space-between; align-items: flex-end; } }
.footer__copy { font-size: 11px; font-family: "Cormorant Garamond", serif; margin-bottom: 30px; }
@media (min-width: 768px) { .footer__copy { margin-bottom: 0; } }
@media (min-width: 1080px) { .footer__copy { font-size: 18px; } }
.footer__nav { display: none; }
@media (min-width: 1080px) { .footer__nav { display: block; } }
.footer__nav-list { display: flex; flex-wrap: wrap; gap: 20px 30px; }
@media (min-width: 1080px) { .footer__nav-list { gap: 0 40px; } }
.footer__nav-list li a { color: #fff; text-decoration: none; font-family: "Cormorant Garamond", serif; font-size: 11px; transition: 0.3s; }
@media (min-width: 1080px) { .footer__nav-list li a { font-size: 18px; } }
.footer__nav-list li a:hover { opacity: 0.7; }
