/* =========================================================
   家族葬 紀州メモリアル — style.css
   reference DNA: returntonature.jp (forest green / old-mincho / editorial)
   ========================================================= */

/* ---------- tokens ---------- */
:root{
  --paper:#f4f1f3;
  --paper-2:#ece7ee;
  --cream:#fbf9fc;
  --mist:#e6e0f0;
  --sage-pale:#dbd3ea;
  --sage:#b3a4d2;
  --forest:#574887;
  --forest-2:#463a6e;
  --forest-deep:#2b2146;
  --forest-deepest:#1b142f;
  --ink:#272230;
  --ink-soft:#574f64;
  --ochre:#9c7b45;
  --ochre-2:#b39055;
  --line:rgba(39,34,48,.14);
  --line-light:rgba(255,255,255,.18);

  --mincho:"Shippori Mincho B1","Hiragino Mincho ProN",serif;
  --gothic:"Zen Kaku Gothic New","Noto Sans JP","Hiragino Kaku Gothic ProN",sans-serif;
  --latin:"Fraunces",Georgia,serif;

  --ease:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);

  --pad:clamp(22px,5vw,90px);
  --maxw:1280px;
}

/* ---------- reset / base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:auto;
}
body{
  font-family:var(--gothic);
  color:var(--ink);
  background:var(--paper);
  line-height:1.9;
  font-weight:400;
  letter-spacing:.02em;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* kinsoku: 行頭禁則を有効化（word-break/overflow-wrapはkinsokuを壊すので付けない）*/
h1,h2,h3,h4,p,li,dt,dd,blockquote,summary,figcaption{
  line-break:strict;
  word-break:normal;
  overflow-wrap:normal;
}
/* 長いラテン文字列（メール/URL）だけは折り返しを許可 */
.cta__mail,.company-table a,.footer a,.bigtel__num{overflow-wrap:anywhere}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--sage);color:var(--forest-deepest)}
:focus-visible{outline:2px solid var(--ochre);outline-offset:3px;border-radius:2px}

.wrapper{position:relative;z-index:1}

/* mobile-only line break helper (desktop flows naturally) */
.br-sp{display:none}
@media (max-width:680px){.br-sp{display:inline}}

/* glue 「、」 to the following char so it is never left at a line end (笹川ルール 2a) */
.nb{white-space:nowrap}

/* ---------- reveal (failsafe: only hidden once JS marks ready) ---------- */
.anim-ready [data-reveal]{opacity:0;transform:translateY(24px)}
.anim-ready [data-reveal].is-in{opacity:1;transform:none;
  transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
.anim-ready .clipimg__img{clip-path:inset(0 0 100% 0);transform:scale(1.12)}
.anim-ready .clipimg.is-in .clipimg__img{clip-path:inset(0 0 0 0);transform:scale(1);
  transition:clip-path 1.25s var(--ease),transform 1.6s var(--ease)}

/* ---------- shared headings ---------- */
.sec-eyebrow{
  font-family:var(--latin);
  font-size:13px;letter-spacing:.18em;color:var(--ochre);
  display:flex;align-items:center;gap:14px;margin-bottom:26px;font-weight:500;
  font-style:italic;
}
.sec-eyebrow span{position:relative;padding-left:34px;text-transform:none}
.sec-eyebrow span::before{
  content:"";position:absolute;left:0;top:50%;width:24px;height:1px;background:var(--ochre)}
.sec-eyebrow--light{color:var(--sage)}
.sec-eyebrow--light span::before{background:var(--sage)}

.sec-head{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);text-align:center;
  display:flex;flex-direction:column;align-items:center}
.sec-head .sec-eyebrow{justify-content:center}
.sec-head--left{text-align:left;align-items:flex-start}
.sec-head--left .sec-eyebrow{justify-content:flex-start}

.sec-title{
  font-family:var(--mincho);font-weight:700;
  font-size:clamp(28px,4.6vw,52px);line-height:1.45;letter-spacing:.04em;
  color:var(--ink);text-wrap:balance;
}
.sec-title--light{color:var(--cream)}
.sec-lead{
  margin-top:28px;max-width:660px;font-size:clamp(14px,1.6vw,16px);
  color:var(--ink-soft);line-height:2.1;text-wrap:pretty;
}
.sec-lead--light{color:rgba(251,250,242,.78)}

/* ---------- buttons ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  gap:10px;padding:18px 38px;border-radius:999px;font-family:var(--gothic);
  font-weight:700;font-size:14px;letter-spacing:.06em;line-height:1;
  transition:transform .5s var(--ease),background .5s var(--ease),color .5s var(--ease),box-shadow .5s var(--ease);
  will-change:transform;overflow:hidden;
}
.btn span{position:relative;z-index:1}
.btn--solid{background:var(--forest);color:var(--cream);box-shadow:0 8px 22px rgba(43,33,70,.26)}
.btn--solid:hover{background:var(--ochre);transform:translateY(-3px);box-shadow:0 12px 30px rgba(156,123,69,.34)}
.btn--ghost{border:1px solid var(--forest);color:var(--forest)}
.btn--ghost:hover{background:var(--forest);color:var(--cream);transform:translateY(-3px)}
.btn--light.btn--ghost{border-color:rgba(251,250,242,.5);color:var(--cream)}
.btn--light.btn--ghost:hover{background:var(--cream);color:var(--forest-deep)}

/* big tel */
.bigtel{display:inline-flex;flex-direction:column;align-items:center;gap:8px;
  padding:24px 48px;border-radius:18px;background:var(--cream);border:1px solid var(--line);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.bigtel:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(43,33,70,.16)}
.bigtel__label{font-size:12px;letter-spacing:.14em;color:var(--ochre);font-weight:700}
.bigtel__num{font-family:var(--latin);font-size:clamp(34px,5vw,52px);font-weight:500;
  letter-spacing:.02em;color:var(--forest);line-height:1}
.bigtel--light{background:rgba(255,255,255,.06);border-color:var(--line-light)}
.bigtel--light .bigtel__num{color:var(--cream)}
.bigtel--light:hover{box-shadow:0 16px 40px rgba(0,0,0,.3)}

/* =========================================================
   LOADER
   ========================================================= */
.loader{position:fixed;inset:0;z-index:9999;background:var(--forest-deep);
  display:flex;align-items:center;justify-content:center;
  transition:opacity 1s var(--ease),visibility 0s linear 1s}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:14px}
.loader__kabu{font-family:var(--gothic);font-size:14px;letter-spacing:.5em;
  color:var(--sage);opacity:0;transform:translateY(10px);
  animation:loadIn .9s var(--ease) .2s forwards;padding-left:.5em}
.loader__name{font-family:var(--mincho);font-weight:700;font-size:clamp(30px,7vw,56px);
  letter-spacing:.16em;color:var(--cream);opacity:0;transform:translateY(14px);
  animation:loadIn 1s var(--ease) .4s forwards;padding-left:.16em}
.loader__line{width:0;height:1px;background:var(--sage);
  animation:loadLine 1.1s var(--ease) .8s forwards}
@keyframes loadIn{to{opacity:1;transform:none}}
@keyframes loadLine{to{width:120px}}
body.is-loaded .loader{opacity:0;visibility:hidden;pointer-events:none}

/* progress */
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:9998;
  background:linear-gradient(90deg,var(--forest),var(--ochre));transition:width .1s linear}

/* =========================================================
   HEADER
   ========================================================= */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),padding .5s var(--ease);
  padding:22px 0}
.header__inner{max-width:1440px;margin:0 auto;padding:0 var(--pad);
  display:flex;align-items:center;gap:24px}
.header.is-stuck{background:rgba(244,241,243,.9);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);padding:12px 0}
.header.is-hero{color:var(--cream)}
.header.is-hero:not(.is-stuck) .logo__mark{color:var(--cream)}
.header.is-hero:not(.is-stuck) .logo__kabu,
.header.is-hero:not(.is-stuck) .logo__name,
.header.is-hero:not(.is-stuck) .gnav__link{color:var(--cream)}
.header.is-hero:not(.is-stuck) .header__tel-label{color:var(--sage)}
.header.is-hero:not(.is-stuck) .header__tel-num{color:var(--cream)}

.logo{display:inline-flex;align-items:center;gap:12px;flex-shrink:0}
.logo__mark{color:var(--forest);display:inline-flex;transition:color .5s var(--ease)}
.logo__text{display:inline-flex;flex-direction:column;line-height:1.15}
.logo__kabu{font-size:10px;letter-spacing:.34em;color:var(--ochre);font-weight:700}
.logo__name{font-family:var(--mincho);font-size:20px;font-weight:700;letter-spacing:.14em;color:var(--ink)}

.gnav{margin-left:auto}
.gnav__list{display:flex;gap:clamp(14px,1.8vw,30px)}
.gnav__link{position:relative;font-size:13px;font-weight:500;letter-spacing:.04em;color:var(--ink);padding:4px 0;white-space:nowrap}
.gnav__link span{position:relative;display:inline-block}
.gnav__link span::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;
  background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.gnav__link:hover span::after{transform:scaleX(1);transform-origin:left}

.header__cta{display:flex;align-items:center;gap:18px;flex-shrink:0}
.header__tel{display:flex;flex-direction:column;line-height:1.1;text-align:right}
.header__tel-label{font-size:10px;letter-spacing:.1em;color:var(--ochre);font-weight:700}
.header__tel-num{font-family:var(--latin);font-size:20px;font-weight:500;color:var(--forest);letter-spacing:.01em}
.header__btn{padding:13px 24px;font-size:12.5px}

.burger{display:none;width:44px;height:44px;flex-direction:column;align-items:center;
  justify-content:center;gap:6px;margin-left:auto}
.burger span{width:24px;height:1.6px;background:currentColor;transition:transform .4s var(--ease),opacity .3s}
.header.is-hero:not(.is-stuck) .burger{color:var(--cream)}
.burger.is-open span:nth-child(1){transform:translateY(3.8px) rotate(45deg)}
.burger.is-open span:nth-child(2){transform:translateY(-3.8px) rotate(-45deg)}

/* ---------- drawer ---------- */
.drawer{position:fixed;inset:0;z-index:999;background:var(--forest-deep);
  padding:120px var(--pad) 48px;display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transform:translateY(-2%);
  transition:opacity .5s var(--ease),visibility 0s linear .5s,transform .6s var(--ease)}
.drawer.is-open{opacity:1;visibility:visible;transform:none;transition:opacity .5s var(--ease),transform .6s var(--ease)}
.drawer__nav{display:flex;flex-direction:column}
.drawer__link{font-family:var(--mincho);font-size:20px;font-weight:600;color:var(--cream);
  padding:15px 0;border-bottom:1px solid var(--line-light);display:flex;align-items:baseline;gap:16px}
.drawer__link em{font-family:var(--latin);font-style:italic;font-size:13px;color:var(--sage)}
.drawer__foot{margin-top:auto;padding-top:30px}
.drawer__tel{font-family:var(--latin);font-size:30px;color:var(--cream);display:flex;flex-direction:column;gap:4px}
.drawer__tel small{font-family:var(--gothic);font-size:12px;letter-spacing:.1em;color:var(--sage)}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  overflow:hidden;color:var(--cream)}
.hero__media{position:absolute;inset:-8% 0 -8% 0;z-index:0;will-change:transform}
.hero__img{position:absolute;inset:0;
  background:#241a3a url("../images/hero.jpg") center/cover no-repeat}
.hero__veil{position:absolute;inset:0;
  background:
    linear-gradient(95deg,rgba(18,11,33,.76) 0%,rgba(18,11,33,.48) 42%,rgba(18,11,33,.10) 72%,rgba(18,11,33,.24) 100%),
    linear-gradient(180deg,transparent 52%,rgba(18,11,33,.36) 100%)}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;
  padding:0 var(--pad);width:100%}
.hero__eyebrow{font-family:var(--latin);font-style:italic;font-size:14px;letter-spacing:.16em;
  color:var(--sage);margin-bottom:30px;display:flex}
.hero__eyebrow span{position:relative;padding-left:40px}
.hero__eyebrow span::before{content:"";position:absolute;left:0;top:50%;width:28px;height:1px;background:var(--sage)}
.hero__title{font-family:var(--mincho);font-weight:700;
  font-size:clamp(38px,7vw,86px);line-height:1.32;letter-spacing:.05em;
  text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero__title-line{display:block;overflow:hidden}
.hero__lead{margin-top:34px;font-size:clamp(14px,1.7vw,17px);line-height:2.2;
  color:rgba(251,250,242,.92);max-width:640px;text-wrap:pretty}
.hero__actions{margin-top:46px;display:flex;gap:16px;flex-wrap:wrap}
.hero__actions .btn--ghost{border-color:rgba(251,250,242,.6);color:var(--cream)}
.hero__actions .btn--ghost:hover{background:var(--cream);color:var(--forest-deep)}
.hero__scroll{position:absolute;left:50%;bottom:34px;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:10px}
.hero__scroll-txt{font-family:var(--latin);font-style:italic;font-size:12px;letter-spacing:.1em;color:var(--sage)}
.hero__scroll-line{width:1px;height:48px;background:linear-gradient(var(--sage),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:-50%;left:0;width:1px;height:50%;background:var(--cream);
  animation:scrollLine 2.2s var(--ease) infinite}
@keyframes scrollLine{0%{top:-50%}60%,100%{top:100%}}

/* =========================================================
   EMERGENCY
   ========================================================= */
.emergency{background:var(--cream);padding:clamp(70px,9vw,120px) 0;
  border-bottom:1px solid var(--line)}
.emergency__inner{max-width:980px;margin:0 auto;padding:0 var(--pad);text-align:center;
  display:flex;flex-direction:column;align-items:center}
.emergency .sec-eyebrow{justify-content:center}
.emergency__title{font-family:var(--mincho);font-weight:700;font-size:clamp(26px,4.4vw,46px);
  line-height:1.5;letter-spacing:.04em;color:var(--ink)}
.emergency__lead{margin-top:26px;color:var(--ink-soft);font-size:clamp(14px,1.6vw,16px);line-height:2.1}
.emergency__phone{margin-top:44px;display:flex;flex-direction:column;align-items:center;gap:20px}
.emergency__note{font-size:13px;color:var(--ink-soft);line-height:1.95;max-width:600px}

/* =========================================================
   ABOUT
   ========================================================= */
.about{padding:clamp(80px,11vw,160px) 0;background:var(--paper)}
.about__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,96px);align-items:center}
.clipimg{position:relative;overflow:hidden;border-radius:6px}
.clipimg__img{width:100%;aspect-ratio:4/5;background-size:cover;background-position:center}
.about__img{aspect-ratio:4/5;
  background:#dbd3ea url("../images/about.jpg") center/cover no-repeat}
.about__quote{font-family:var(--mincho);font-weight:700;font-size:clamp(26px,3.6vw,42px);
  line-height:1.62;letter-spacing:.05em;color:var(--ink)}
.about__text{margin-top:34px;display:flex;flex-direction:column;gap:22px;
  color:var(--ink-soft);font-size:clamp(14px,1.55vw,16px);line-height:2.15;max-width:520px}

/* =========================================================
   PLANS
   ========================================================= */
.plans{padding:clamp(80px,11vw,150px) 0;background:var(--paper-2)}
.plans .sec-head{margin-bottom:clamp(48px,6vw,80px)}
.plan-list{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,34px)}
.plan{background:var(--cream);border-radius:8px;overflow:hidden;border:1px solid var(--line);
  display:flex;flex-direction:column;transition:transform .6s var(--ease),box-shadow .6s var(--ease)}
.plan:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(43,33,70,.16)}
.plan__media{overflow:hidden}
.plan__img{aspect-ratio:3/2;background-size:cover;background-position:center}
.plan__img--a{background:#efeaf2 url("../images/plan-kasou.jpg") center/cover no-repeat}
.plan__img--b{background:#e7e1f0 url("../images/plan-ichinichi.jpg") center/cover no-repeat}
.plan__img--c{background:#efe6f0 url("../images/plan-kazoku.jpg") center/cover no-repeat}
.plan__body{padding:clamp(26px,3vw,40px);position:relative;display:flex;flex-direction:column;gap:8px}
.plan--feature{border-color:var(--forest);box-shadow:0 10px 30px rgba(43,33,70,.14)}
.plan__badge{position:absolute;top:-1px;right:24px;background:var(--forest);color:var(--cream);
  font-size:11px;letter-spacing:.1em;font-weight:700;padding:7px 14px;border-radius:0 0 6px 6px}
.plan__num{font-family:var(--latin);font-style:italic;font-size:14px;color:var(--ochre)}
.plan__name{font-family:var(--mincho);font-size:clamp(22px,2.6vw,30px);font-weight:700;
  letter-spacing:.06em;color:var(--ink);display:flex;align-items:baseline;gap:10px}
.plan__name small{font-size:14px;font-weight:500;color:var(--ink-soft);font-family:var(--gothic)}
.plan__price{display:flex;align-items:baseline;gap:6px;margin-top:6px;color:var(--forest)}
.plan__price-num{font-family:var(--latin);font-size:clamp(34px,4.4vw,52px);font-weight:500;line-height:1}
.plan__price-unit{font-size:13px;font-weight:700;color:var(--ink-soft)}
.plan__desc{margin-top:12px;font-size:13.5px;color:var(--ink-soft);line-height:2}

.plans__note{max-width:var(--maxw);margin:clamp(40px,5vw,60px) auto 0;padding:0 var(--pad);
  font-size:12.5px;color:var(--ink-soft);line-height:2;text-align:center}

/* =========================================================
   PRICE (明朗会計 / dark)
   ========================================================= */
.price{background:var(--forest-deep);color:var(--cream);padding:clamp(80px,11vw,150px) 0;
  position:relative;overflow:hidden}
.price::before{content:"";position:absolute;inset:0;
  background:radial-gradient(80% 60% at 85% 0%,rgba(179,164,210,.14),transparent 60%);pointer-events:none}
.price__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);position:relative}
.price .sec-head{margin-bottom:clamp(40px,5vw,64px)}
.price__cols{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(20px,3vw,40px)}
.price-card{background:rgba(255,255,255,.05);border:1px solid var(--line-light);
  border-radius:12px;padding:clamp(28px,3.4vw,48px)}
.price-card--out{background:rgba(156,123,69,.12);border-color:rgba(176,144,85,.36)}
.price-card__head{font-family:var(--mincho);font-size:clamp(18px,2.2vw,24px);font-weight:600;
  letter-spacing:.04em;color:var(--cream);display:flex;align-items:baseline;gap:12px;
  padding-bottom:20px;margin-bottom:24px;border-bottom:1px solid var(--line-light)}
.price-card__head small{font-size:12px;font-weight:400;color:var(--sage);font-family:var(--gothic)}
.price-card__list{display:grid;grid-template-columns:1fr 1fr;gap:14px 24px}
.price-card__list li{position:relative;padding-left:22px;font-size:14px;color:rgba(251,250,242,.9)}
.price-card__list li::before{content:"";position:absolute;left:0;top:.7em;width:9px;height:9px;
  border-radius:50%;background:var(--sage)}
.price-card__list--out{grid-template-columns:1fr;gap:18px}
.price-card__list--out li{display:flex;flex-direction:column;gap:2px;font-weight:600}
.price-card__list--out li span{font-size:12px;font-weight:400;color:var(--sage);padding-left:0}
.price-card__list--out li::before{background:var(--ochre-2)}
.price-card__assure{margin-top:26px;padding-top:22px;border-top:1px solid rgba(176,144,85,.32);
  font-family:var(--mincho);font-size:15px;color:var(--cream);letter-spacing:.03em}

/* =========================================================
   FLOW
   ========================================================= */
.flow{padding:clamp(80px,11vw,150px) 0;background:var(--paper)}
.flow .sec-head{margin-bottom:clamp(48px,6vw,80px)}
.flow-list{max-width:880px;margin:0 auto;padding:0 var(--pad);position:relative}
.flow-list::before{content:"";position:absolute;left:calc(var(--pad) + 27px);top:18px;bottom:18px;
  width:1px;background:var(--line)}
.flow-step{display:flex;gap:28px;padding:20px 0;align-items:flex-start;position:relative}
.flow-step__num{flex-shrink:0;width:56px;height:56px;border-radius:50%;background:var(--cream);
  border:1px solid var(--sage);display:flex;align-items:center;justify-content:center;
  font-family:var(--latin);font-size:18px;color:var(--forest);position:relative;z-index:1}
.flow-step__body{padding-top:6px}
.flow-step__body h3{font-family:var(--mincho);font-size:clamp(18px,2.2vw,24px);font-weight:600;
  letter-spacing:.04em;color:var(--ink)}
.flow-step__body p{margin-top:6px;font-size:14px;color:var(--ink-soft);line-height:1.9}

/* =========================================================
   HALL (自社斎場)
   ========================================================= */
.hall{position:relative;display:grid;grid-template-columns:1.05fr .95fr;min-height:80vh;
  background:var(--forest-deepest);color:var(--cream);overflow:hidden}
.hall__media{position:relative;overflow:hidden}
.hall__img{position:absolute;inset:-8% 0;
  background:#2b2146 url("../images/hall.jpg") center/cover no-repeat;will-change:transform}
.hall__panel{padding:clamp(56px,7vw,110px) var(--pad);display:flex;flex-direction:column;
  justify-content:center}
.hall__title{font-family:var(--mincho);font-weight:700;font-size:clamp(26px,3.6vw,44px);
  line-height:1.5;letter-spacing:.04em;color:var(--cream)}
.hall__lead{margin-top:26px;color:rgba(251,250,242,.8);font-size:clamp(14px,1.55vw,16px);line-height:2.1}
.hall__list{margin-top:34px;display:flex;flex-direction:column;gap:14px}
.hall__list li{position:relative;padding-left:28px;font-size:14.5px;color:rgba(251,250,242,.92);line-height:1.8}
.hall__list li::before{content:"";position:absolute;left:0;top:.55em;width:14px;height:14px;
  border:1px solid var(--sage);border-radius:50%}
.hall__list li::after{content:"";position:absolute;left:5px;top:calc(.55em + 5px);width:4px;height:4px;
  border-radius:50%;background:var(--sage)}

/* =========================================================
   STRENGTH
   ========================================================= */
.strength{padding:clamp(80px,11vw,150px) 0;background:var(--mist)}
.strength .sec-head{margin-bottom:clamp(40px,5vw,64px)}
.strength-list{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:flex;flex-direction:column;border-top:1px solid var(--line)}
.vblock{display:grid;grid-template-columns:90px minmax(200px,.9fr) 1.5fr;
  gap:clamp(16px,3.4vw,52px);align-items:start;
  padding:clamp(26px,3.1vw,40px) clamp(4px,1.2vw,20px);
  border-bottom:1px solid var(--line);transition:background .5s var(--ease)}
.vblock:hover{background:var(--cream)}
.vblock__index{font-family:var(--latin);font-style:italic;font-size:clamp(26px,3.3vw,42px);
  color:var(--ochre);line-height:1;padding-top:2px}
.vblock__title{font-family:var(--mincho);font-size:clamp(18px,2.1vw,24px);font-weight:700;
  letter-spacing:.04em;color:var(--ink);line-height:1.55}
.vblock__text{font-size:14px;color:var(--ink-soft);line-height:2.05}

/* =========================================================
   PREPARE / MEMBER
   ========================================================= */
.prepare{padding:clamp(80px,11vw,150px) 0;background:var(--paper)}
.prepare__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(36px,5vw,72px);align-items:start}
.prepare__title{font-family:var(--mincho);font-weight:700;font-size:clamp(26px,3.6vw,44px);
  line-height:1.5;letter-spacing:.04em;color:var(--ink)}
.prepare__lead{margin-top:24px;color:var(--ink-soft);font-size:clamp(14px,1.55vw,16px);line-height:2.1}
.prepare__list{margin-top:32px;display:flex;flex-direction:column;gap:16px}
.prepare__list li{position:relative;padding-left:30px;font-size:15px;color:var(--ink);font-weight:500;line-height:1.7}
.prepare__list li span{display:block;font-size:12.5px;font-weight:400;color:var(--ink-soft)}
.prepare__list li::before{content:"";position:absolute;left:2px;top:.4em;width:14px;height:14px;
  border-radius:50%;border:1px solid var(--ochre)}
.prepare__list li::after{content:"";position:absolute;left:6px;top:calc(.4em + 4px);width:6px;height:6px;
  border-radius:50%;background:var(--ochre)}
.prepare__quote{margin-top:34px;padding:24px 28px;background:var(--sage-pale);border-radius:8px;
  font-family:var(--mincho);font-size:16px;line-height:1.95;color:var(--forest-deep);letter-spacing:.03em}

.member{background:var(--forest-deep);color:var(--cream);border-radius:14px;
  padding:clamp(32px,3.6vw,48px);position:sticky;top:100px}
.member__eyebrow{font-size:12px;letter-spacing:.16em;color:var(--sage);font-weight:700}
.member__title{font-family:var(--mincho);font-size:clamp(22px,2.8vw,30px);font-weight:700;
  letter-spacing:.06em;margin-top:10px;color:var(--cream)}
.member__price{margin-top:18px;padding-bottom:22px;border-bottom:1px solid var(--line-light);
  display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.member__price span{font-size:13px;color:var(--sage)}
.member__price strong{font-family:var(--latin);font-size:40px;font-weight:500;color:var(--cream);line-height:1}
.member__price small{width:100%;font-size:12px;color:var(--sage);margin-top:2px}
.member__benefits{margin-top:24px;display:flex;flex-direction:column;gap:16px}
.member__benefits li{position:relative;padding-left:28px;font-size:14px;line-height:1.8;color:rgba(251,250,242,.92)}
.member__benefits b{color:#e7d3a0;font-weight:700}
.member__mark{position:absolute;left:0;top:.45em;width:16px;height:16px}
.member__mark::before,.member__mark::after{content:"";position:absolute;background:var(--ochre-2)}
.member__mark::before{left:7px;top:1px;width:2px;height:14px}
.member__mark::after{left:1px;top:7px;width:14px;height:2px}
.member__btn{margin-top:30px;width:100%;background:var(--ochre-2)}
.member__btn:hover{background:var(--cream);color:var(--forest-deep)}

/* =========================================================
   AFTERCARE (dark)
   ========================================================= */
.aftercare{background:var(--forest-deepest);color:var(--cream);padding:clamp(80px,11vw,150px) 0;
  position:relative;overflow:hidden}
.aftercare::before{content:"";position:absolute;inset:0;
  background:radial-gradient(70% 50% at 12% 100%,rgba(179,164,210,.12),transparent 60%);pointer-events:none}
.aftercare__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);position:relative}
.aftercare .sec-head{margin-bottom:clamp(40px,5vw,60px)}
.aftercare__list{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line-light);
  border:1px solid var(--line-light);border-radius:10px;overflow:hidden}
.aftercare__list li{background:var(--forest-deep);padding:clamp(26px,2.6vw,38px) clamp(18px,2vw,28px);
  min-height:170px;display:flex;align-items:flex-end;transition:background .5s var(--ease)}
.aftercare__list li:hover{background:var(--forest-2)}
.aftercare__list h3{font-family:var(--mincho);font-size:clamp(15px,1.7vw,18px);font-weight:600;
  line-height:1.7;letter-spacing:.03em;color:var(--cream)}
.aftercare__list h3 span{display:block;font-family:var(--gothic);font-size:11.5px;font-weight:400;
  color:var(--sage);margin-top:6px}

/* =========================================================
   VOICE
   ========================================================= */
.voice{position:relative;overflow:hidden;padding:clamp(80px,11vw,150px) 0;background:var(--paper)}
.voice::before{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(rgba(244,241,243,.82),rgba(244,241,243,.9)),url("../images/voice-bg.jpg") center/cover no-repeat}
.voice .sec-head,.voice-list{position:relative;z-index:1}
.voice .sec-head{margin-bottom:clamp(48px,6vw,72px)}
.voice-list{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,32px)}
.voice-card{background:var(--cream);border:1px solid var(--line);border-radius:10px;
  padding:clamp(28px,3vw,40px);display:flex;flex-direction:column;gap:20px}
.voice-card blockquote{font-family:var(--mincho);font-size:clamp(15px,1.7vw,17px);line-height:2.05;
  color:var(--ink);letter-spacing:.02em;position:relative;padding-top:26px}
.voice-card blockquote::before{content:"“";position:absolute;top:-6px;left:-4px;
  font-family:var(--latin);font-size:50px;color:var(--sage);line-height:1}
.voice-card figcaption{font-size:12.5px;color:var(--ink-soft);letter-spacing:.06em;
  padding-top:14px;border-top:1px solid var(--line)}

/* =========================================================
   FAQ
   ========================================================= */
.faq{padding:clamp(80px,11vw,150px) 0;background:var(--paper-2)}
.faq__head{max-width:var(--maxw);margin:0 auto clamp(40px,5vw,64px);padding:0 var(--pad);text-align:center;
  display:flex;flex-direction:column;align-items:center}
.faq__head .sec-eyebrow{justify-content:center}
.faq-list{max-width:860px;margin:0 auto;padding:0 var(--pad);display:flex;flex-direction:column;gap:14px}
.faq-item{background:var(--cream);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  gap:18px;padding:22px clamp(22px,2.6vw,32px)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item__q{font-family:var(--mincho);font-size:clamp(15px,1.8vw,18px);font-weight:600;
  letter-spacing:.02em;color:var(--ink);position:relative;padding-left:30px}
.faq-item__q::before{content:"Q";position:absolute;left:0;top:-1px;font-family:var(--latin);
  font-style:italic;color:var(--ochre);font-size:17px}
.faq-item__icon{position:relative;flex-shrink:0;width:18px;height:18px}
.faq-item__icon::before,.faq-item__icon::after{content:"";position:absolute;background:var(--forest);
  transition:transform .4s var(--ease)}
.faq-item__icon::before{left:8px;top:0;width:1.6px;height:18px}
.faq-item__icon::after{left:0;top:8px;width:18px;height:1.6px}
.faq-item[open] .faq-item__icon::before{transform:scaleY(0)}
.faq-item__a{padding:0 clamp(22px,2.6vw,32px) 26px calc(clamp(22px,2.6vw,32px) + 30px)}
.faq-item__a p{font-size:14px;color:var(--ink-soft);line-height:2.05;position:relative;padding-left:30px}
.faq-item__a p::before{content:"A";position:absolute;left:0;top:-1px;font-family:var(--latin);
  font-style:italic;color:var(--forest);font-size:17px}

/* =========================================================
   CTA (final / dark)
   ========================================================= */
.cta{background:var(--forest-deep);color:var(--cream);padding:clamp(80px,12vw,160px) 0;
  position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;
  background:radial-gradient(90% 70% at 50% 0%,rgba(179,164,210,.16),transparent 60%);pointer-events:none}
.cta__inner{max-width:900px;margin:0 auto;padding:0 var(--pad);text-align:center;position:relative;
  display:flex;flex-direction:column;align-items:center}
.cta .sec-eyebrow{justify-content:center}
.cta__title{font-family:var(--mincho);font-weight:700;font-size:clamp(30px,5vw,58px);
  line-height:1.45;letter-spacing:.05em;color:var(--cream)}
.cta__lead{margin-top:26px;color:rgba(251,250,242,.82);font-size:clamp(14px,1.6vw,16px);line-height:2.1}
.cta__actions{margin-top:46px;display:flex;flex-direction:column;align-items:center;gap:26px}
.cta__sub{display:flex;flex-direction:column;align-items:center;gap:12px}
.cta__mail{font-family:var(--latin);font-size:14px;letter-spacing:.04em;color:var(--sage)}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--forest-deepest);color:var(--cream);padding:clamp(60px,7vw,96px) 0 36px}
.footer__top{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(36px,5vw,72px)}
.footer__brand .logo__kabu{color:var(--ochre-2)}
.footer__brand .logo__name{color:var(--cream)}
.footer__tagline{margin-top:18px;font-size:13px;color:var(--sage);line-height:1.9}
.footer__company-head{font-family:var(--latin);font-style:italic;font-size:13px;letter-spacing:.12em;
  color:var(--sage);margin-bottom:18px}
.company-table{display:flex;flex-direction:column}
.company-table>div{display:grid;grid-template-columns:140px 1fr;gap:16px;padding:12px 0;
  border-bottom:1px solid var(--line-light);font-size:13px}
.company-table dt{color:var(--sage);letter-spacing:.04em}
.company-table dd{color:rgba(251,250,242,.92);line-height:1.8}
.company-table a{border-bottom:1px solid transparent;transition:border-color .3s}
.company-table a:hover{border-color:var(--sage)}
.footer__bottom{max-width:var(--maxw);margin:48px auto 0;padding:24px var(--pad) 0;
  border-top:1px solid var(--line-light);display:flex;justify-content:space-between;align-items:center;
  gap:20px;flex-wrap:wrap}
.footer__nav{display:flex;gap:24px;flex-wrap:wrap}
.footer__nav a{font-size:12.5px;color:var(--sage);transition:color .3s}
.footer__nav a:hover{color:var(--cream)}
.footer__copy{font-family:var(--latin);font-size:12px;letter-spacing:.06em;color:var(--sage)}

/* =========================================================
   MOBILE FIXED CTA BAR
   ========================================================= */
.mbar{position:fixed;left:0;bottom:0;width:100%;z-index:900;display:none;
  grid-template-columns:1fr 1fr;gap:0;background:var(--forest-deep);
  box-shadow:0 -8px 24px rgba(0,0,0,.18);transform:translateY(100%);
  transition:transform .5s var(--ease);padding-bottom:env(safe-area-inset-bottom)}
.mbar.is-show{transform:none}
.mbar__btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:15px 8px;
  font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--cream)}
.mbar__btn--tel{background:var(--ochre-2)}
.mbar__btn--tel span{display:flex;flex-direction:column;line-height:1.2}
.mbar__btn--tel small{font-size:10px;font-weight:400;letter-spacing:.06em;opacity:.85}
.mbar__btn--mail{background:var(--forest)}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1320px){
  .gnav__list{gap:clamp(11px,1.3vw,18px)}
  .gnav__link{font-size:12.5px}
  .header__tel-num{font-size:18px}
  .header__btn{padding:12px 18px;font-size:12px}
}
@media (max-width:1080px){
  .gnav,.header__tel{display:none}
  .burger{display:flex}
  .header__cta{margin-left:auto}
  .header__btn{display:none}
  .price__cols{grid-template-columns:1fr}
  .aftercare__list{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:880px){
  .about__grid{grid-template-columns:1fr;gap:40px}
  .about__img{aspect-ratio:16/10}
  .plan-list{grid-template-columns:1fr;max-width:480px}
  .plan{flex-direction:row}
  .plan__media{flex:0 0 42%}
  .plan__img{height:100%;aspect-ratio:auto}
  .vblock{grid-template-columns:auto 1fr;column-gap:18px;row-gap:7px;padding:24px 2px}
  .vblock__index{grid-column:1;grid-row:1 / span 2;font-size:26px;padding-top:1px}
  .vblock__title{grid-column:2;grid-row:1}
  .vblock__text{grid-column:2;grid-row:2;font-size:13.5px}
  .hall{grid-template-columns:1fr}
  .hall__media{min-height:54vh}
  .hall__img{position:absolute;inset:-6% 0}
  .prepare__grid{grid-template-columns:1fr;gap:44px}
  .member{position:static}
  .voice-list{grid-template-columns:1fr;max-width:520px}
  .price-card__list{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr;gap:40px}
  .mbar{display:grid}
  .main{padding-bottom:0}
}
@media (max-width:560px){
  .header{padding:16px 0}
  .header.is-stuck{padding:10px 0}
  .logo__name{font-size:17px}
  .hero__title{font-size:clamp(26px,8.2vw,34px);letter-spacing:.02em;line-height:1.42}
  .hero__lead{font-size:15px;line-height:2.05}
  .sec-title{font-size:clamp(22px,6.2vw,28px);line-height:1.5;letter-spacing:.02em}
  .cta__title{font-size:clamp(24px,6.6vw,30px);letter-spacing:.02em}
  .emergency__title{font-size:clamp(23px,6vw,30px);letter-spacing:.02em}
  .about__quote,.hall__title,.prepare__title{font-size:clamp(22px,6vw,28px);letter-spacing:.02em;line-height:1.55}
  .plan{flex-direction:column}
  .plan__media{flex:none}
  .plan__img{aspect-ratio:3/2}
  .aftercare__list{grid-template-columns:1fr}
  .aftercare__list li{min-height:0;padding:22px}
  .flow-list::before{left:calc(var(--pad) + 22px)}
  .flow-step__num{width:44px;height:44px;font-size:15px}
  .flow-step{gap:18px}
  .bigtel{padding:20px 28px;width:100%}
  .company-table>div{grid-template-columns:1fr;gap:2px}
  .company-table dt{font-size:11px}
  .footer__bottom{flex-direction:column;align-items:flex-start}
}

/* =========================================================
   MOBILE IMAGE SWAP (PC横 → スマホ縦)
   背景画像のみ上書き（center/coverはショートハンド由来を継承）
   ========================================================= */
@media (max-width:880px){
  .hall__img{background-image:url("../images/hall-mobile.jpg")}
}
@media (max-width:680px){
  .hero__img{background-image:url("../images/hero-mobile.jpg")}
  .hero__veil{background:linear-gradient(180deg,rgba(18,11,33,.52) 0%,rgba(18,11,33,.24) 44%,rgba(18,11,33,.52) 100%)}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important}
  .anim-ready [data-reveal]{opacity:1 !important;transform:none !important}
  .anim-ready .clipimg__img{clip-path:none !important;transform:none !important}
  .hero__media{transform:none !important}
}
