:root{
  --bg:#FAF6EC;--bg-s:#F3EEDF;--bg-d:#EBE4D1;
  --ink:#1F2A24;--ink-s:#4A5550;--ink-m:#8A8F86;--ink-mute:#A8ADA2;
  --forest:#284938;--forest-d:#1B3126;--moss:#6E8366;
  --terra:#C4663F;--terra-s:#E8C9B5;
  --line:#D9D2BF;--gold:#A68A4E;--gold-l:#C4A866;--gold-d:#8A7140;
  --fs:"Shippori Mincho B1",serif;--fn:"Noto Sans JP",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{background:var(--bg)}
body{background:var(--ink);color:var(--ink);font-family:var(--fn);-webkit-font-smoothing:antialiased;line-height:1.7}

/* ===== PC / SP 出し分け ===== */
.d-sp-only{display:none}
br.d-sp-only{display:none}
@media (max-width: 1024px){
  .d-pc-only{display:none !important}
  .d-sp-only{display:block}
  br.d-sp-only{display:inline}
  .d-sp-inline{display:inline}
}


/* ──────────────────────────────────── */
/*     DESKTOP LP                       */
/* ──────────────────────────────────── */
.d-wrap{font-family:var(--fn);color:var(--ink);background:var(--bg)}
.d-topdeco{position:relative;overflow:hidden;isolation:isolate}
.d-topdeco::before{content:"";position:absolute;top:-280px;right:-280px;width:560px;height:560px;border-radius:50%;border:1px solid var(--line);pointer-events:none;z-index:0}
.d-topdeco::after{content:"";position:absolute;bottom:-320px;left:-320px;width:620px;height:620px;border-radius:50%;border:1px solid var(--line);pointer-events:none;z-index:0}
.d-topdeco > *{position:relative;z-index:1}
.d-brandmark{padding:48px 56px 20px;display:flex;align-items:center;background:transparent}
.d-brandmark img{height:36px;width:auto;display:block}

/* Hero Desktop — 画像右レイアウト */
.d-hero{background:var(--bg);overflow:hidden;position:relative}
.d-hero__inner{display:grid;gap:56px;align-items:center;max-width:1400px;margin:0 auto;padding:56px 56px 64px;grid-template-columns:1fr 1.1fr;padding-right:0}
.d-hero__copy{max-width:560px}
.d-hero__sp{display:none}

/* 画像ビジュアル */
.d-hero__visual{position:relative;height:620px;overflow:hidden}
.d-hero__visual > img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}

/* 有資格者100%バッジ (trust-bar) */
.d-hero__trust-bar{display:flex;gap:10px;margin:4px 0 24px;flex-wrap:wrap}
.d-hero__trust-badge{
  display:inline-flex;align-items:center;gap:14px;
  padding:12px 18px;
  background:rgba(250,246,236,.94);
  -webkit-backdrop-filter:blur(6px);
  backdrop-filter:blur(6px);
  border:1px solid rgba(196,168,102,.4);
  border-radius:6px;
  position:relative;z-index:2;
}
.d-hero__trust-badge__icon{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-l) 0%,var(--gold) 100%);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 4px 10px -3px rgba(166,138,78,.45);
}
.d-hero__trust-badge__icon svg{
  width:18px;height:18px;
  stroke:#fff;stroke-width:2.2;fill:none;
  stroke-linecap:round;stroke-linejoin:round;
}
.d-hero__trust-badge__text{
  display:flex;flex-direction:column;gap:3px;line-height:1.4;
}
.d-hero__trust-badge__text strong{
  font-family:var(--fs);font-size:.96rem;color:var(--ink);font-weight:700;letter-spacing:.02em;
}
.d-hero__trust-badge__text strong b{
  color:var(--gold-d);font-weight:800;font-size:1.1em;letter-spacing:0;padding:0 1px;
}
.d-hero__trust-badge__text small{
  font-size:.7rem;color:var(--ink-s);letter-spacing:.02em;font-weight:500;
}

/* コピー */
.d-hero__topcopy{font-family:var(--fs);font-size:1.3rem;color:var(--ink);font-weight:600;line-height:1.7;margin-bottom:26px;letter-spacing:.04em}
.d-hero__topcopy em{font-style:normal;color:var(--gold);font-weight:700;border-bottom:2px solid var(--gold);padding-bottom:2px}
.d-hero__title{font-family:var(--fs);font-weight:700;font-size:3rem;line-height:1.4;color:var(--ink);letter-spacing:-.01em;margin-bottom:40px}
.d-hero__title em{font-style:normal;color:var(--terra)}

/* FV下便益カード（常に表示） */
.d-fv-bottom{background:var(--bg-s);padding:64px 56px}
.d-fv-bottom__inner{max-width:1200px;margin:0 auto}
.d-fv-bottom__head{text-align:center;margin-bottom:36px}
/* .d-fv-bottom__eb は統一eyebrowで上書き */
.d-fv-bottom__title{font-family:var(--fs);font-size:1.8rem;font-weight:700;color:var(--ink);line-height:1.5;letter-spacing:.02em}
.d-fv-bottom__title em{font-style:normal;color:var(--forest);font-weight:700}
.d-fv-bottom__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.d-fv-bottom__card{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:32px 26px;text-align:center}
.d-fv-bottom__illust{width:76px;height:76px;margin:0 auto 18px;background:var(--forest);border-radius:50%;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.d-fv-bottom__illust::before{content:"";position:absolute;top:-8px;right:-8px;width:18px;height:18px;border-radius:50%;background:rgba(196,167,102,.5)}
.d-fv-bottom__illust::after{content:"";position:absolute;bottom:-8px;left:-8px;width:18px;height:18px;border-radius:50%;background:rgba(214,115,93,.45)}
.d-fv-bottom__illust svg{width:34px;height:34px;stroke:var(--bg);stroke-width:1.6;fill:none;position:relative;z-index:1;display:block;transform:translateX(1.5px)}
.d-fv-bottom__num{font-family:var(--fs);font-size:.66rem;letter-spacing:.22em;color:var(--gold);font-weight:700;margin-bottom:8px}
.d-fv-bottom__t{font-family:var(--fs);font-size:1.42rem;font-weight:700;color:var(--ink);line-height:1.55;letter-spacing:.02em;margin-bottom:14px}
.d-fv-bottom__t em{font-style:normal;color:var(--forest);font-weight:700}
.d-fv-bottom__d{font-size:.8rem;color:var(--ink-s);line-height:1.85;text-align:left}
.d-hero__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.15fr;gap:64px;align-items:center;position:relative;z-index:1}
.d-hero__eyebrow{font-size:.68rem;letter-spacing:.28em;color:var(--terra);text-transform:uppercase;font-weight:600;margin-bottom:22px;display:inline-block}
.d-hero__eyebrow::before{content:"";display:inline-block;width:20px;height:1px;background:var(--terra);vertical-align:middle;margin-right:10px}
.d-hero__topcopy{font-family:var(--fs);font-size:1.3rem;color:var(--ink);font-weight:600;line-height:1.7;margin-bottom:26px;letter-spacing:.04em}
.d-hero__topcopy em{font-style:normal;color:var(--gold);font-weight:700;border-bottom:2px solid var(--gold);padding-bottom:2px}
.d-hero__title{font-family:var(--fs);font-weight:700;font-size:3rem;line-height:1.4;color:var(--ink);letter-spacing:-.01em;margin-bottom:40px}
.d-hero__sublead{font-family:var(--fs);font-size:1.15rem;font-weight:500;color:var(--ink-s);line-height:1.9;letter-spacing:.02em;margin-bottom:40px}
.d-hero__sublead em{font-style:normal;color:var(--forest);font-weight:700}
.d-hero__title em{font-style:normal;color:var(--terra)}
.d-hero__title-line{display:inline-block;white-space:nowrap}

/* 旧Hero用 料金CTAスタイル（新Heroから再利用） */
.d-hero__pricecta{display:flex;align-items:stretch;gap:20px;margin-top:4px;padding:20px 22px;background:var(--bg-s);border-radius:8px;border:1px solid var(--line)}
.d-hero__price-left{display:flex;flex-direction:column;justify-content:center;padding-right:20px;border-right:1px solid var(--line);white-space:nowrap}
.d-hero__price-left .d-hero__price-lbl{font-size:.66rem;color:var(--ink-s);letter-spacing:.16em;text-transform:uppercase;font-weight:600;margin-bottom:6px}
.d-hero__price-left .d-hero__price-amt{font-family:var(--fs);font-size:2rem;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em}
.d-hero__price-left .d-hero__price-amt span{font-size:.8rem;color:var(--ink-s);font-weight:500;margin-left:4px}
.d-hero__cta-wrap{flex:1;display:flex;flex-direction:column;gap:8px;align-items:stretch;justify-content:center}

.d-hero__cta-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  width:100%;
  padding:18px 32px;background:var(--forest);color:var(--bg);
  border-radius:999px;text-decoration:none;
  font-family:var(--fs);font-size:1.02rem;font-weight:700;letter-spacing:.08em;
  transition:transform .2s,box-shadow .2s;
  box-shadow:0 10px 24px -6px rgba(40,73,56,.35);
}
.d-hero__cta-primary:hover{transform:translateY(-1px);box-shadow:0 14px 32px -8px rgba(40,73,56,.5)}
.d-hero__cta-primary span{font-size:1.15rem;font-weight:400;transition:transform .25s}
.d-hero__cta-primary:hover span{transform:translateX(4px)}
.d-hero__cta-note{font-size:.68rem;color:var(--ink-m);letter-spacing:.06em;text-align:center}

/* ── Lead Section (after Hero) ─────── */
.d-lead{padding:90px 56px;background:linear-gradient(180deg,#f5ecd4 0%,#f0e6c8 100%);position:relative;overflow:hidden;border-top:1px solid rgba(166,138,78,.18);border-bottom:1px solid rgba(166,138,78,.18)}
.d-lead::before{content:"";position:absolute;top:50%;left:-80px;width:240px;height:240px;border-radius:50%;border:1px solid rgba(166,138,78,.22);transform:translateY(-50%);opacity:.7}
.d-lead::after{content:"";position:absolute;top:50%;right:-120px;width:280px;height:280px;border-radius:50%;border:1px solid rgba(166,138,78,.18);transform:translateY(-50%);opacity:.6}
.d-lead__inner{max-width:880px;margin:0 auto;position:relative;text-align:center}
.d-lead__copy{font-family:var(--fs);font-size:1.26rem;font-weight:500;color:var(--ink);line-height:2.3;letter-spacing:.04em}
.d-lead__copy em{font-style:normal;color:var(--forest);font-weight:700;background:linear-gradient(transparent 72%,rgba(166,138,78,.25) 72%,rgba(166,138,78,.25) 92%,transparent 92%);padding:0 3px}

/* ── Comparison Section: 通常 vs プレミアムプラン ─────── */
.d-cmpr{padding:80px 56px;background:var(--bg);position:relative}
.d-cmpr__inner{max-width:1000px;margin:0 auto}
.d-cmpr__head{text-align:center;margin-bottom:48px}
/* .d-cmpr__head .eyebrow は統一eyebrowで上書き */
.d-cmpr__title{font-family:var(--fs);font-size:2.2rem;font-weight:700;color:var(--ink);line-height:1.5;letter-spacing:.02em;margin-bottom:16px}
.d-cmpr__title em{font-style:normal;color:var(--gold-d);background:linear-gradient(transparent 68%,rgba(166,138,78,.28) 68%,rgba(166,138,78,.28) 94%,transparent 94%);padding:0 4px}
.d-cmpr__lede{font-size:.95rem;color:var(--ink-s);line-height:1.9;max-width:560px;margin:0 auto}

.d-cmpr__table-wrap{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.d-cmpr__sec{background:var(--bg);padding:32px 28px;border-radius:8px;border:1px solid var(--line)}
.d-cmpr__sec-head{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.d-cmpr__sec-icon{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--gold);color:var(--bg)}
.d-cmpr__sec-icon svg{width:22px;height:22px}
.d-cmpr__sec-info{flex:1}
.d-cmpr__sec-t{font-family:var(--fs);font-size:1.2rem;font-weight:700;color:var(--ink);line-height:1.3}
.d-cmpr__sec-sub{font-size:.66rem;color:var(--gold);margin-top:4px;letter-spacing:.22em;font-weight:600}

.d-cmpr__tbl{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--line);border-radius:6px;overflow:hidden;table-layout:fixed;font-family:var(--fs)}
.d-cmpr__tbl thead th{padding:12px 12px;font-size:.7rem;letter-spacing:.1em;font-weight:700;text-transform:uppercase;border-bottom:1px solid var(--line);font-family:var(--fs)}
.d-cmpr__tbl thead th:nth-child(1){background:var(--bg);border-right:1px solid var(--line);width:34%}
.d-cmpr__tbl thead th:nth-child(2){text-align:center;color:var(--ink-m);width:22%;background:var(--bg)}
.d-cmpr__tbl thead th:nth-child(3){text-align:center;color:var(--bg);background:var(--gold);width:44%;letter-spacing:.1em;padding-top:13px;padding-bottom:13px}
.d-cmpr__tbl tbody td{padding:12px 12px;font-size:.9rem;vertical-align:middle;font-family:var(--fs)}
.d-cmpr__tbl tbody td:nth-child(1){color:var(--ink);background:var(--bg);font-weight:600;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.d-cmpr__tbl tbody td.d-cmpr__tbl-normal{text-align:center;color:var(--ink-m);font-size:.86rem;background:var(--bg);border-bottom:1px solid var(--line)}
.d-cmpr__tbl tbody td.d-cmpr__tbl-premium{text-align:center;color:#8a7342;font-weight:700;font-family:var(--fs);font-size:1.02rem;background:rgba(166,138,78,.09);border-left:1px solid rgba(166,138,78,.18);border-bottom:1px solid rgba(166,138,78,.18)}
.d-cmpr__tbl tbody tr:last-child td{border-bottom:none}
.d-cmpr__tbl tbody td .u{font-size:.74rem;color:#8a7342;font-weight:500;margin-left:4px;opacity:.75}
.d-cmpr__tbl tbody td .dash{color:var(--ink-m);font-weight:400}
.d-fv-f-staff{padding:0;background:var(--bg);border-radius:6px;margin-bottom:14px;position:relative;overflow:hidden;border:1px solid var(--line)}
.d-fv-f-staff__hdr{padding:24px 22px;text-align:center;background:linear-gradient(180deg,var(--forest) 0%,var(--forest-d) 100%);color:var(--bg)}
.d-fv-f-staff__lbl{font-size:.62rem;letter-spacing:.28em;color:var(--gold-l);text-transform:uppercase;font-weight:700;margin-bottom:6px}
.d-fv-f-staff__h{font-family:var(--fs);font-size:1.5rem;font-weight:700;line-height:1.45;color:var(--bg);letter-spacing:.02em}
.d-fv-f-staff__body{padding:18px 16px}

/* ── FV 便益3カード（アメックス風 + 和モダンイラスト） ─────── */
.d-fv-ben{display:flex;flex-direction:column;gap:14px}
.d-fv-ben__card{background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:22px 24px;display:grid;grid-template-columns:auto 1fr;column-gap:20px;align-items:center;position:relative;transition:transform .2s ease,box-shadow .2s ease}
.d-fv-ben__card:hover{transform:translateY(-2px);box-shadow:0 8px 24px -8px rgba(31,61,44,.18)}
.d-fv-ben__illust{grid-row:1 / span 3;width:72px;height:72px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--forest);border-radius:50%;position:relative;overflow:hidden}
.d-fv-ben__illust::before{content:"";position:absolute;top:-8px;right:-8px;width:18px;height:18px;border-radius:50%;background:rgba(196,167,102,.5)}
.d-fv-ben__illust::after{content:"";position:absolute;bottom:-8px;left:-8px;width:18px;height:18px;border-radius:50%;background:rgba(214,115,93,.45)}
.d-fv-ben__illust svg{width:34px;height:34px;stroke:var(--bg);stroke-width:1.6;fill:none;position:relative;z-index:1;display:block;transform:translateX(1.5px)}
.d-fv-ben__num{font-family:var(--fs);font-size:.66rem;letter-spacing:.22em;color:var(--gold);font-weight:700;grid-column:2;margin-bottom:2px}
.d-fv-ben__t{font-family:var(--fs);font-size:1.14rem;font-weight:700;color:var(--ink);line-height:1.5;letter-spacing:.02em;grid-column:2;margin-bottom:6px}
.d-fv-ben__t em{font-style:normal;color:var(--forest);font-weight:700}
.d-fv-ben__d{font-size:.82rem;color:var(--ink-s);line-height:1.85;letter-spacing:.01em;grid-column:2}

/* セクション */
.d-fv-sec{margin-bottom:20px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.d-fv-sec:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
.d-fv-sec__head{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.d-fv-sec__icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--gold);color:var(--bg)}
.d-fv-sec__icon svg{width:18px;height:18px}
.d-fv-sec__info{flex:1}
.d-fv-sec__t{font-family:var(--fs);font-size:1rem;font-weight:700;color:var(--ink);line-height:1.2}
.d-fv-sec__sub{font-size:.62rem;color:var(--gold);margin-top:3px;letter-spacing:.18em;font-weight:600}

/* テーブル */
.d-fv-tbl{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--line);border-radius:6px;overflow:hidden;table-layout:fixed}
.d-fv-tbl thead th{padding:11px 12px;font-size:.7rem;letter-spacing:.1em;font-weight:700;text-transform:uppercase;border-bottom:1px solid var(--line);font-family:var(--fs)}
.d-fv-tbl thead th:nth-child(1){background:var(--bg);border-right:1px solid var(--line);width:34%}
.d-fv-tbl thead th:nth-child(2){text-align:center;color:var(--ink-m);width:22%;background:var(--bg)}
.d-fv-tbl thead th:nth-child(3){text-align:center;color:var(--bg);background:var(--gold);width:44%;letter-spacing:.1em;padding-top:12px;padding-bottom:12px}
.d-fv-tbl tbody td{padding:11px 12px;font-size:.88rem;vertical-align:middle;font-family:var(--fs)}
.d-fv-tbl tbody td:nth-child(1){color:var(--ink);background:var(--bg);font-weight:600;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.d-fv-tbl tbody td.d-fv-tbl__normal{text-align:center;color:var(--ink-m);font-size:.86rem;background:var(--bg);border-bottom:1px solid var(--line)}
.d-fv-tbl tbody td.d-fv-tbl__premium{text-align:center;color:#8a7342;font-weight:700;font-size:1rem;background:rgba(166,138,78,.09);border-left:1px solid rgba(166,138,78,.18);border-bottom:1px solid rgba(166,138,78,.18)}
.d-fv-tbl tbody tr:last-child td{border-bottom:none}
.d-fv-tbl tbody td .u{font-size:.74rem;color:#8a7342;font-weight:500;margin-left:4px;opacity:.75}
.d-fv-tbl tbody td .dash{color:var(--ink-m);font-weight:400}

.d-fv-f-roles{display:grid;grid-template-columns:1fr;gap:8px;position:relative}
.d-fv-f-role{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;padding:14px 16px;background:rgba(250,246,236,.08);border-radius:4px;border-left:2px solid var(--terra)}
.d-fv-f-role__n{font-family:var(--fs);font-weight:700;font-size:.88rem;color:var(--terra-s);letter-spacing:.12em;min-width:28px}
.d-fv-f-role__t{font-size:.9rem;color:rgba(250,246,236,.95);line-height:1.5}
.d-fv-f-role__t b{color:var(--bg);font-weight:700}

.d-fv-f-subhead{margin-top:18px;margin-bottom:14px;display:flex;align-items:center;gap:12px}
.d-fv-f-subhead__line{flex:1;height:1px;background:var(--line)}
.d-fv-f-subhead__t{font-size:.72rem;letter-spacing:.22em;color:var(--ink-m);text-transform:uppercase;font-weight:600}

.d-fv-f-perks{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:16px}
.d-fv-f-perk{padding:16px 10px;background:var(--bg);border:1px solid var(--line);border-radius:4px;text-align:center}
.d-fv-f-perk__when{font-size:.64rem;letter-spacing:.16em;color:var(--ink-m);text-transform:uppercase;font-weight:600;margin-bottom:6px;line-height:1.2}
.d-fv-f-perk__v{font-family:var(--fs);font-weight:700;font-size:1.15rem;color:var(--forest);letter-spacing:-.01em;line-height:1.1}
.d-fv-f-perk__v small{font-family:var(--fs);font-size:.72rem;color:var(--forest);font-weight:700;letter-spacing:.04em;margin-left:4px;vertical-align:2px}
.d-fv-f-perk__t{font-family:var(--fs);font-size:.78rem;letter-spacing:.06em;color:var(--ink);font-weight:700;line-height:1.3;margin-bottom:8px}


/* Desktop FV price row */
.d-hero__price{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg);border:1px solid var(--line);border-radius:4px;margin-bottom:14px;text-align:center}
.d-hero__price-lbl{font-size:.74rem;color:var(--ink-s);letter-spacing:.16em;text-transform:uppercase;font-weight:600;margin-bottom:10px}
.d-hero__price-amt{font-family:var(--fs);font-size:2.8rem;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em}
.d-hero__price-amt span{font-size:.9rem;color:var(--ink-s);font-weight:500;margin-left:6px}
.d-hero__btn{width:100%;padding:15px;background:var(--forest);color:var(--bg);border:0;border-radius:999px;font-size:.88rem;font-weight:600;cursor:pointer;letter-spacing:.04em}
.d-hero__btn-note{text-align:center;font-size:.64rem;color:var(--ink-m);margin-top:8px;letter-spacing:.06em}

.d-fv-f-wrap{display:block}

/* ── CONCIERGE (desktop) ──────────── */
.d-concierge{padding:100px 56px;background:var(--forest);color:var(--bg);position:relative;overflow:hidden}
.d-concierge::before{content:"";position:absolute;top:-150px;right:-100px;width:400px;height:400px;border:1px solid rgba(250,246,236,.08);border-radius:50%}
.d-concierge::after{content:"";position:absolute;bottom:-200px;left:-100px;width:380px;height:380px;border:1px solid rgba(250,246,236,.06);border-radius:50%}
.d-concierge__inner{max-width:1200px;margin:0 auto;position:relative}
.d-concierge__head{text-align:center;max-width:820px;margin:0 auto 56px}
.d-concierge__stamp{display:inline-block;padding:5px 14px;background:var(--terra);color:var(--bg);border-radius:999px;font-size:.62rem;font-weight:700;letter-spacing:.22em;margin-bottom:20px}
/* .d-concierge__eyebrow は統一eyebrowで上書き */
.d-concierge__title{font-family:var(--fs);font-weight:700;font-size:2.6rem;line-height:1.5;color:var(--bg);margin-bottom:22px;letter-spacing:.01em}
.d-concierge__title em{font-style:normal;color:var(--bg);background:linear-gradient(transparent 68%,rgba(196,102,63,.55) 68%,rgba(196,102,63,.55) 94%,transparent 94%);padding:0 4px}
.d-concierge__lede{font-size:1rem;color:rgba(250,246,236,.85);line-height:2.05;max-width:720px;margin:0 auto}
.d-concierge__note{font-size:.78rem;color:rgba(250,246,236,.6);line-height:1.85;margin-top:18px}
.d-concierge__footer{padding:28px 36px;background:rgba(0,0,0,.2);border-radius:6px;display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;max-width:960px;margin:0 auto;border:1px solid rgba(250,246,236,.08)}
.d-concierge__footer-lbl{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--terra-s);font-weight:600;margin-bottom:4px}
.d-concierge__footer-h{font-family:var(--fs);font-size:1rem;font-weight:700;color:var(--bg);line-height:1.5}
.d-concierge__footer-desc{font-size:.78rem;color:rgba(250,246,236,.72);line-height:1.85}
.d-concierge__footer-cta{padding:13px 26px;background:var(--bg);color:var(--forest);border-radius:999px;text-decoration:none;font-weight:600;font-size:.82rem;white-space:nowrap}

/* FV concierge badge desktop */
.d-fv__concierge-badge{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;padding:14px 16px;background:rgba(40,73,56,.05);border:1px solid rgba(40,73,56,.18);border-left:3px solid var(--forest);border-radius:4px;margin-top:18px;margin-bottom:4px}
.d-fv__concierge-badge-icon{width:42px;height:42px;border-radius:50%;background:var(--forest);color:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--fs);font-weight:700;font-size:.74rem}
.d-fv__concierge-badge-txt{font-size:.76rem;color:var(--ink-s);line-height:1.6}
.d-fv__concierge-badge-txt b{display:block;font-family:var(--fs);font-size:.88rem;color:var(--forest);font-weight:700;margin-bottom:2px}

/* Desktop sections */
.d-sec{padding:90px 56px;background:var(--bg)}
.d-sec--soft{background:var(--bg-s)}
.d-sec--forest{background:var(--forest);color:var(--bg)}
.d-sec--forest .d-sec-title{color:var(--bg)}
.d-sec--forest .d-sec-title em{color:var(--terra-s)}
.d-sec--forest .d-lede{color:rgba(250,246,236,.78)}
.d-sec__inner{max-width:1200px;margin:0 auto}
.d-sec-head{margin-bottom:48px;text-align:center;max-width:720px;margin-left:auto;margin-right:auto}
.d-sec-head.left{text-align:left;margin-left:0}
.d-sec-head .eyebrow{margin-bottom:16px}
.d-sec-title{font-family:var(--fs);font-weight:600;font-size:2.2rem;line-height:1.45;letter-spacing:.01em}
.d-sec-title em{font-style:normal;color:var(--forest)}
.d-lede{font-size:.94rem;color:var(--ink-s);line-height:2;margin-top:18px;max-width:640px;margin-left:auto;margin-right:auto}

/* For you desktop */
.d-foryou{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.d-foryou-card{padding:32px 28px;background:var(--bg);border:1px solid var(--line);border-radius:6px;position:relative}
.d-sec--soft .d-foryou-card{background:var(--bg)}
.d-foryou-card__tag{position:absolute;top:22px;right:24px;font-size:.58rem;letter-spacing:.18em;color:var(--terra);text-transform:uppercase;font-weight:600}
.d-foryou-card__age{font-family:var(--fs);font-weight:700;font-size:1.7rem;color:var(--forest);line-height:1.1;letter-spacing:-.01em;margin-bottom:14px}
.d-foryou-card__age sup{font-size:inherit;color:var(--forest);margin-left:0;vertical-align:baseline;font-weight:700}
.d-foryou-card__range{font-family:var(--fs);font-size:.96rem;font-weight:600;margin-bottom:10px}
.d-foryou-card__desc{font-size:.8rem;color:var(--ink-s);line-height:1.95}

/* Benefits — vertical timeline */
.d-tl{position:relative;margin-top:40px;max-width:900px;margin-left:auto;margin-right:auto;padding-left:32px}
.d-tl::before{content:"";position:absolute;left:32px;top:30px;bottom:30px;width:1px;background:linear-gradient(180deg,var(--terra) 0%,var(--terra-s) 50%,var(--terra) 100%)}

.d-tl-step{position:relative;padding:28px 32px 28px 68px;margin-bottom:24px;background:var(--bg);border:1px solid var(--line);border-radius:8px;box-shadow:0 4px 16px -8px rgba(40,50,40,.08)}
.d-tl-step:last-child{margin-bottom:0}
.d-tl-step::before{content:"";position:absolute;top:0;left:0;bottom:0;width:4px;background:var(--terra);border-radius:8px 0 0 8px}

/* Left anchor (timeline dot + icon) */
.d-tl-anchor{position:absolute;left:-24px;top:24px;width:56px;height:56px;border-radius:50%;background:var(--bg);border:1.5px solid var(--terra);display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:0 4px 12px -4px rgba(40,50,40,.15)}
.d-tl-anchor svg{width:26px;height:26px;color:var(--terra)}

/* Head row: step + when + amount */
.d-tl-head{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.d-tl-head-l{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap}
.d-tl-step-lbl{display:flex;align-items:baseline;gap:6px}
.d-tl-step-lbl__step{font-family:var(--fs);font-size:.66rem;letter-spacing:.22em;color:var(--ink-m);text-transform:uppercase;font-weight:600}
.d-tl-step-lbl__num{font-family:var(--fs);font-size:1.5rem;font-weight:700;color:var(--terra);letter-spacing:-.02em;line-height:1}
.d-tl-when{font-family:var(--fs);font-size:1.2rem;font-weight:700;color:var(--ink);padding-left:18px;border-left:1px solid var(--line);line-height:1}

.d-tl-amount{display:flex;align-items:baseline;gap:4px;flex-shrink:0}
.d-tl-amount__val{font-family:var(--fs);font-size:2.2rem;font-weight:700;color:var(--forest);line-height:1;letter-spacing:-.02em}
.d-tl-amount__unit{font-family:var(--fs);font-size:.82rem;color:var(--ink-s);font-weight:500}
.d-tl-amount__off{font-family:var(--fs);font-size:1.55rem;color:var(--forest);font-weight:700;letter-spacing:.04em;align-self:center;margin-left:10px}

.d-tl-title{font-family:var(--fs);font-weight:700;font-size:1.35rem;line-height:1.5;color:var(--ink);margin-bottom:10px}
.d-tl-title em{font-family:var(--fs);font-style:normal;color:var(--terra);font-weight:inherit}
.d-tl-lead{font-family:var(--fs);font-size:.9rem;color:var(--ink-s);line-height:1.95;margin-bottom:16px}

/* Step03: Tier progression (30h → 100h → 300h) */
.d-tl-tiers{margin-bottom:14px;padding:16px 18px;background:linear-gradient(135deg,rgba(196,102,63,.06) 0%,rgba(196,102,63,.02) 100%);border:1px solid var(--terra-s);border-radius:4px}
.d-tl-tiers__lbl{font-size:.64rem;letter-spacing:.18em;color:var(--terra);text-transform:uppercase;font-weight:700;margin-bottom:12px}
.d-tl-tiers__bar{display:flex;align-items:center;justify-content:space-between;gap:8px}
.d-tl-tier{flex:1;text-align:center;padding:10px 8px;background:var(--bg);border-radius:3px}
.d-tl-tier__hr{font-size:.7rem;color:var(--ink-s);margin-bottom:4px;letter-spacing:.02em}
.d-tl-tier__hr b{font-family:var(--fs);font-size:1rem;color:var(--ink);font-weight:700;margin:0 2px}
.d-tl-tier__val{font-family:var(--fs);font-size:1.15rem;font-weight:700;color:var(--forest);letter-spacing:-.01em;line-height:1}
.d-tl-tier__arrow{color:var(--terra);font-size:.95rem;flex-shrink:0;font-weight:300}

.d-tl-note{padding:12px 16px;background:var(--bg-s);border:1px dashed var(--line);border-radius:3px;font-size:.78rem;color:var(--ink-s);line-height:1.8}
.d-tl-note b{color:var(--terra);font-weight:700}

/* Grand Total */
.d-tl-total{margin-top:40px;padding:36px 44px;background:var(--forest);color:var(--bg);border-radius:6px;display:flex;justify-content:space-between;align-items:center;gap:32px;position:relative;overflow:hidden;max-width:900px;margin-left:auto;margin-right:auto}
.d-tl-total__text-wrap{flex:1;min-width:0}
.d-tl-total__cta{flex-shrink:0;white-space:nowrap}
.d-tl-total::before{content:"";position:absolute;top:-40px;right:-40px;width:140px;height:140px;border:1px solid rgba(250,246,236,.15);border-radius:50%}
.d-tl-total__lbl{font-size:.62rem;letter-spacing:.26em;color:var(--terra-s);text-transform:uppercase;margin-bottom:6px;font-weight:600}
.d-tl-total__val{font-family:var(--fs);font-weight:700;font-size:1.9rem;line-height:1.3;word-break:keep-all;overflow-wrap:break-word;line-break:strict;font-feature-settings:"palt"}
.d-tl-total__val em{font-style:normal;color:var(--terra-s)}
.d-tl-total__sub{font-size:.86rem;color:rgba(250,246,236,.88);margin-top:10px;line-height:1.7}
.d-tl-total__toggle{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  width:100%;margin-top:14px;padding:14px 16px;
  background:rgba(250,246,236,.04);
  border:1px solid rgba(250,246,236,.18);
  border-radius:6px;
  color:rgba(250,246,236,.88);
  font-family:var(--fs);font-size:.84rem;font-weight:600;letter-spacing:.04em;
  text-align:left;cursor:pointer;
  transition:background-color .25s ease,border-color .25s ease,color .25s ease;
  -webkit-tap-highlight-color:rgba(250,246,236,.08);
}
.d-tl-total__toggle:hover,
.d-tl-total__toggle:focus-visible{background:rgba(250,246,236,.08);border-color:rgba(250,246,236,.4);color:var(--bg)}
.d-tl-total__toggle:focus-visible{outline:2px solid rgba(250,246,236,.45);outline-offset:2px}
.d-tl-total__toggle-txt{flex:1;min-width:0}
.d-tl-total__chevron{
  flex-shrink:0;width:10px;height:10px;
  border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg);margin-top:-3px;
  transition:transform .3s ease;
}
.d-tl-total__toggle[aria-expanded="true"] .d-tl-total__chevron{transform:rotate(-135deg);margin-top:2px}
.d-tl-total__body[hidden]{display:none}
.d-tl-total__body{margin-top:14px;animation:d-tl-total-fade .3s ease both}
@keyframes d-tl-total-fade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.d-tl-total__breakdown{display:flex;flex-direction:column;gap:0}
.d-tl-total__row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 2px;border-bottom:1px solid rgba(250,246,236,.12)}
.d-tl-total__row:last-child{border-bottom:0}
.d-tl-total__row-label{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.d-tl-total__row-label b{font-size:.92rem;font-weight:600;color:var(--bg);letter-spacing:.02em}
.d-tl-total__row-formula{font-size:.74rem;color:rgba(250,246,236,.62);line-height:1.55;font-feature-settings:"tnum"}
.d-tl-total__row-amt{flex-shrink:0;font-family:var(--fs);font-weight:700;font-size:1.05rem;color:var(--terra-s);white-space:nowrap;letter-spacing:.01em;font-feature-settings:"tnum"}
.d-tl-total__note{margin-top:14px;font-size:.74rem;line-height:1.75;color:rgba(250,246,236,.7)}
.d-tl-total__note b{color:var(--bg);font-weight:600}

/* Benefits — PC asymmetric layout (Benefit03 = hero top, 01/02 below in 2 cols) */
@media (min-width: 1025px){
  .d-tl{
    display:grid;
    grid-template-columns:1fr 1fr;
    column-gap:24px;
    row-gap:24px;
    padding-left:0;
    max-width:1140px;
    margin-top:48px;
  }
  .d-tl::before{display:none}

  .d-tl-step{
    margin-bottom:0;
    padding:30px 26px 26px;
  }
  /* アイコンはカード左上にバッジ風に配置（全カード共通） */
  .d-tl-anchor{
    left:26px;
    top:30px;
    transform:none;
    width:46px;
    height:46px;
  }
  .d-tl-anchor svg{width:22px;height:22px}

  .d-tl-head{
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
    margin-bottom:14px;
    padding-bottom:14px;
    padding-left:60px;
    min-height:46px;
  }
  .d-tl-head-l{flex-wrap:nowrap;gap:10px;width:100%;align-items:baseline}
  .d-tl-step-lbl__num{font-size:1.3rem}
  .d-tl-when{font-size:1rem;padding-left:12px}
  .d-tl-amount{align-self:flex-start;flex-wrap:wrap;gap:2px}
  .d-tl-amount__val{font-size:1.85rem}
  .d-tl-amount__unit{font-size:.82rem !important}
  .d-tl-amount__off{font-size:1.3rem;margin-left:6px}

  .d-tl-title{font-size:1.16rem;line-height:1.55}
  .d-tl-lead{font-size:.86rem;line-height:1.95;margin-bottom:14px}
  .d-tl-note{font-size:.76rem;padding:10px 14px;line-height:1.75}

  /* Benefit01, Benefit02 → 上段2列 */
  .d-tl-step:nth-child(1){grid-column:1;grid-row:1}
  .d-tl-step:nth-child(2){grid-column:2;grid-row:1}

  /* Benefit03 = クライマックス（下段全幅・左:コピー / 右:ティア） */
  .d-tl-step:nth-child(3){
    grid-column:1 / -1;
    grid-row:2;
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(0,1.25fr);
    grid-template-rows:auto 1fr;
    column-gap:40px;
    row-gap:14px;
    padding:32px 40px 36px;
  }
  /* アイコンはBenefit03のpadding-leftに合わせて左寄せ */
  .d-tl-step:nth-child(3) .d-tl-anchor{left:40px}
  .d-tl-step:nth-child(3) .d-tl-head{
    grid-column:1;grid-row:1;
    margin-bottom:0;padding-bottom:14px;
  }
  .d-tl-step:nth-child(3) .d-tl-lead{grid-column:1;grid-row:2;margin-bottom:0;align-self:start;font-size:.92rem;line-height:2}
  .d-tl-step:nth-child(3) .d-tl-tiers{
    grid-column:2;grid-row:1 / span 2;
    align-self:stretch;
    margin:0;
    padding:18px 18px;
    display:flex;flex-direction:column;justify-content:center;
  }
  .d-tl-step:nth-child(3) .d-tl-tiers__lbl{margin-bottom:14px}
  .d-tl-step:nth-child(3) .d-tl-tiers__bar{
    flex-direction:row;
    gap:6px;
    align-items:stretch;
  }
  .d-tl-step:nth-child(3) .d-tl-tier{
    flex:1;flex-direction:column;
    text-align:center;align-items:center;justify-content:center;
    padding:14px 8px;width:auto;
  }
  .d-tl-step:nth-child(3) .d-tl-tier__hr{
    margin-bottom:6px;font-size:.72rem;white-space:nowrap;
  }
  .d-tl-step:nth-child(3) .d-tl-tier__hr b{font-size:1rem}
  .d-tl-step:nth-child(3) .d-tl-tier__val{
    font-size:1.05rem;text-align:center;
  }
  .d-tl-step:nth-child(3) .d-tl-tier__arrow{
    display:flex;align-items:center;justify-content:center;
    flex:0 0 auto;color:var(--terra);font-size:.95rem;
  }

  /* デフォルトの縦積みtiers（Step01/02には影響なし、Step03のみ上書き済） */
  .d-tl-tiers{padding:12px 12px;margin-bottom:0}
  .d-tl-tiers__lbl{margin-bottom:10px}
  .d-tl-tiers__bar{flex-direction:column;gap:6px}
  .d-tl-tier{
    display:flex;align-items:center;justify-content:space-between;
    text-align:left;padding:9px 12px;width:100%;
  }
  .d-tl-tier__hr{margin-bottom:0;flex-shrink:0;font-size:.74rem;white-space:nowrap}
  .d-tl-tier__hr b{font-size:.96rem}
  .d-tl-tier__val{
    font-size:.98rem;flex-shrink:0;text-align:right;
    font-variant-numeric:tabular-nums;font-feature-settings:"tnum";
  }
  .d-tl-tier__arrow{display:none}
}

/* Scenes desktop */
.d-scenes{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.d-scene{padding:24px 20px;background:var(--bg);border:1px solid var(--line);border-radius:5px}
.d-sec--soft .d-scene{background:var(--bg)}
.d-scene__tag{font-size:.58rem;letter-spacing:.18em;color:var(--terra);text-transform:uppercase;font-weight:600;margin-bottom:12px;display:block}
.d-scene__title{font-family:var(--fs);font-size:1rem;font-weight:600;line-height:1.5;margin-bottom:8px}
.d-scene__desc{font-size:.76rem;color:var(--ink-s);line-height:1.85}

/* Requirements desktop */
.d-req-list{list-style:none;display:flex;flex-direction:column;gap:10px;max-width:720px;margin:0 auto}
.d-req-list li{display:grid;grid-template-columns:32px 1fr;gap:14px;padding:18px 22px;background:var(--bg);border:1px solid var(--line);border-radius:4px;align-items:start}
.d-sec--soft .d-req-list li{background:var(--bg)}
.d-req-icon{width:32px;height:32px;border:1px solid var(--forest);color:var(--forest);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.84rem;margin-top:2px}
.d-req-txt{font-size:.86rem;line-height:1.7}
.d-req-txt small{display:block;color:var(--ink-s);font-size:.72rem;margin-top:2px}



/* Flow desktop */
.d-flow{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;position:relative}
.d-flow::before{content:"";position:absolute;top:32px;left:40px;right:40px;height:1px;border-top:1px dashed var(--line)}
.d-flow-step{text-align:center;padding:20px 14px;background:var(--bg);border:1px solid var(--line);border-radius:5px;position:relative;z-index:1}
.d-flow-num{width:48px;height:48px;border-radius:50%;background:var(--bg-s);color:var(--terra);display:flex;align-items:center;justify-content:center;font-family:var(--fs);font-size:1.1rem;font-weight:700;margin:0 auto 14px;border:1px solid var(--terra)}
.d-flow-title{font-family:var(--fs);font-size:.84rem;font-weight:600;margin-bottom:8px;line-height:1.5}
.d-flow-desc{font-size:.7rem;color:var(--ink-s);line-height:1.75}

/* Pricing desktop */
.d-sec--pricing{background:var(--forest);color:var(--bg)}
.d-sec--pricing .d-sec-title{color:var(--bg)}
.d-sec--pricing .d-sec-title em{color:var(--terra-s)}
.d-sec--pricing .d-lede{color:rgba(250,246,236,.78)}
.d-sec--pricing .eyebrow{color:var(--terra-s)}
.d-price-layers{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:center;margin-bottom:28px}
.d-price-layer{background:var(--bg);color:var(--ink);padding:28px 26px;border-radius:5px;border-left:3px solid var(--terra);position:relative}
.d-price-layer--2{border-left-color:var(--moss);background:var(--bg-s)}
.d-price-layer__num{position:absolute;top:18px;right:20px;font-family:var(--fs);font-size:1.6rem;font-weight:300;color:var(--line)}
.d-price-layer__lbl{font-size:.62rem;letter-spacing:.2em;color:var(--ink-s);text-transform:uppercase;font-weight:600;margin-bottom:8px}
.d-price-layer__amt{font-family:var(--fs);font-size:2.2rem;font-weight:700;color:var(--forest);line-height:1.2}
.d-price-layer__amt span{font-size:.9rem;color:var(--ink-s);font-weight:400;margin-left:4px}
.d-price-layer__amt.sm{font-size:1.3rem;color:var(--ink);letter-spacing:0}
.d-price-layer__desc{font-size:.8rem;color:var(--ink-s);line-height:1.85;padding-top:12px;margin-top:12px;border-top:1px dashed var(--line)}
.d-price-layer__sub{font-size:.78rem;color:var(--ink-s);font-weight:500;margin-top:8px;letter-spacing:.02em;line-height:1.5}
.d-price-plus{font-family:var(--fs);font-size:2rem;color:var(--bg);font-weight:300}
.d-price-card{background:var(--bg);color:var(--ink);padding:32px 32px;border-radius:5px;box-shadow:0 30px 70px -15px rgba(0,0,0,.25)}
.d-price-card__eb{font-size:.62rem;letter-spacing:.22em;color:var(--terra);text-transform:uppercase;margin-bottom:10px;font-weight:600}
.d-price-card__name{font-family:var(--fs);font-size:1.15rem;font-weight:600;margin-bottom:20px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.d-price-card__feats{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 28px}
.d-price-card__feats li{display:grid;grid-template-columns:20px minmax(0,1fr);gap:10px;font-size:.82rem;color:var(--ink-s);line-height:1.75;word-break:normal;overflow-wrap:break-word}
.d-price-card__feats li > *{min-width:0}
.d-price-card__feats li::before{content:"✓";color:var(--forest);font-weight:700;font-size:.92rem}
.d-price-disclaimer{margin-top:28px;padding:24px 26px;background:rgba(250,246,236,.06);border:1px solid rgba(232,201,181,.3);border-left:3px solid var(--terra);border-radius:4px;max-width:880px;margin-left:auto;margin-right:auto}
.d-price-disclaimer__lbl{display:inline-block;padding:4px 11px;background:var(--terra);color:var(--bg);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;border-radius:2px;margin-bottom:12px}
.d-price-disclaimer__t{font-family:var(--fs);font-size:1.1rem;font-weight:700;color:var(--bg);margin-bottom:12px;line-height:1.55}
.d-price-disclaimer__p{font-size:.82rem;line-height:1.95;color:rgba(250,246,236,.82);margin-bottom:8px}
.d-price-disclaimer__p b{color:var(--terra-s);font-weight:600}

/* FAQ desktop */
.d-faq{max-width:820px;margin:0 auto}
.d-faq-item{border-bottom:1px solid var(--line)}
.d-faq-q{display:grid;grid-template-columns:1fr auto;gap:14px;padding:22px 0;cursor:pointer;font-family:var(--fs);font-size:.96rem;font-weight:600;line-height:1.55;align-items:center}
.d-faq-icon{width:26px;height:26px;border:1px solid var(--ink);border-radius:50%;position:relative;transition:.3s;flex-shrink:0}
.d-faq-icon::before,.d-faq-icon::after{content:"";position:absolute;top:50%;left:50%;width:10px;height:1px;background:var(--ink);transform:translate(-50%,-50%);transition:.3s}
.d-faq-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.d-faq-item.open .d-faq-icon{background:var(--forest);border-color:var(--forest)}
.d-faq-item.open .d-faq-icon::before,.d-faq-item.open .d-faq-icon::after{background:var(--bg)}
.d-faq-item.open .d-faq-icon::after{transform:translate(-50%,-50%) rotate(0)}
.d-faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s cubic-bezier(.4,0,.2,1);color:var(--ink-s);font-size:.82rem;line-height:2}
.d-faq-a > div{overflow:hidden;min-height:0}
.d-faq-item.open .d-faq-a{grid-template-rows:1fr;padding-bottom:22px}

/* Final CTA desktop */
.d-final{padding:100px 56px;background:var(--bg);text-align:center;position:relative;overflow:hidden}
.d-final::before{content:"";position:absolute;top:-120px;left:-80px;width:280px;height:280px;border-radius:50%;border:1px solid var(--line)}
.d-final::after{content:"";position:absolute;bottom:-150px;right:-100px;width:320px;height:320px;border-radius:50%;border:1px solid var(--line)}
.d-final__inner{max-width:720px;margin:0 auto;position:relative}
/* .d-final__eb は統一eyebrowで上書き */
.d-final__h{font-family:var(--fs);font-size:2.2rem;font-weight:600;line-height:1.55;margin-bottom:20px}
.d-final__h em{font-style:normal;color:var(--forest)}
.d-final__sub{font-size:.92rem;color:var(--ink-s);margin-bottom:32px;line-height:2.1}
.d-final__btn{display:inline-flex;align-items:center;gap:12px;padding:18px 40px;background:var(--forest);color:var(--bg);border-radius:999px;font-size:.92rem;font-weight:600;text-decoration:none;letter-spacing:.04em;box-shadow:0 15px 40px -10px rgba(40,73,56,.4)}
.d-final__btn::after{content:"→"}
.d-final__fine{text-align:center;margin-top:14px;font-size:.72rem;color:var(--ink-m);letter-spacing:.06em}

.d-footer{padding:24px 56px 12px;background:var(--ink);color:var(--bg-s);font-size:.76rem;letter-spacing:.04em;position:relative}
.d-footer__links{display:flex;flex-wrap:wrap;gap:6px 22px;justify-content:center;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid rgba(250,246,236,.12)}
.d-footer__links a{color:var(--bg-s);text-decoration:none;font-size:.72rem;letter-spacing:.04em;opacity:.7;transition:opacity .2s}
.d-footer__links a:hover{opacity:1;text-decoration:underline}
.d-footer__copyright{text-align:center;font-size:.68rem;letter-spacing:.12em;opacity:.55}

/* ============================================================
   ▼▼▼ 和モダン強化レイヤー V2  (案A: Quiet Luxury Japonisme) ▼▼▼
   既存のスタイルを上書き／拡張する追加レイヤー
   ============================================================ */

/* --- 0. JSが効いてる時のみアニメーション初期状態 --- */
.js-on .reveal{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.22,.85,.36,1),transform .9s cubic-bezier(.22,.85,.36,1)}
@media (min-width: 1025px){.js-on .reveal{will-change:opacity,transform}}
.js-on .reveal.up-lg{transform:translateY(40px)}
.js-on .reveal.left{transform:translateX(-32px)}
.js-on .reveal.right{transform:translateX(32px)}
.js-on .reveal.scale{transform:scale(.94)}
.js-on .reveal.in-view{opacity:1 !important;transform:none !important}
.js-on .reveal[data-d="1"]{transition-delay:.08s}
.js-on .reveal[data-d="2"]{transition-delay:.16s}
.js-on .reveal[data-d="3"]{transition-delay:.24s}
.js-on .reveal[data-d="4"]{transition-delay:.32s}
.js-on .reveal[data-d="5"]{transition-delay:.40s}
.js-on .reveal[data-d="6"]{transition-delay:.48s}

/* --- 1. 上部スクロール進捗バー（金糸） --- */
.d-progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:9999;pointer-events:none;
  background:linear-gradient(90deg,transparent 0%,var(--gold) 25%,var(--terra) 75%,transparent 100%);
  box-shadow:0 0 8px rgba(166,138,78,.5);transition:width .12s ease-out}

/* --- 2. 全体背景に和紙テクスチャ風のごく薄いノイズ --- */
.d-wrap{position:relative;background-image:
  radial-gradient(circle at 12% 18%, rgba(166,138,78,.03) 0%, transparent 55%),
  radial-gradient(circle at 88% 76%, rgba(196,102,63,.022) 0%, transparent 55%),
  repeating-linear-gradient(45deg,transparent,transparent 28px,rgba(166,138,78,.014) 28px,rgba(166,138,78,.014) 29px),
  linear-gradient(180deg,var(--bg) 0%,var(--bg) 100%)}

/* --- 3. eyebrow を両側罫線つきに格上げ --- */
/* === 統一 Eyebrow デザイン（全セクション共通） === */
.eyebrow,
.d-fv-bottom__eb,
.d-concierge__eyebrow,
.d-final__eb{
  position:relative;display:inline-block !important;
  font-family:var(--fn);
  font-size:.68rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--gold);
  margin-bottom:16px;
}
.eyebrow::before,.eyebrow::after,
.d-fv-bottom__eb::before,.d-fv-bottom__eb::after,
.d-concierge__eyebrow::before,.d-concierge__eyebrow::after,
.d-final__eb::before,.d-final__eb::after{
  content:"";display:inline-block;width:22px;height:1px;
  background:currentColor;vertical-align:middle;margin:0 12px;opacity:.5;
}
/* 既存のd-hero__eyebrowは元から::before持ちなので干渉回避 */
.d-hero__eyebrow.eyebrow::before,.d-hero__eyebrow.eyebrow::after{display:none}
/* 暗い背景セクションは色違いに */
.d-sec--forest .eyebrow,
.d-concierge__eyebrow{color:var(--terra-s)}
/* 既存のd-hero__eyebrowは元から::before持ちなので干渉回避 */
.d-hero__eyebrow.eyebrow::before,.d-hero__eyebrow.eyebrow::after{display:none}

/* --- 4. d-topdeco の円装飾を緩慢に回転 --- */
.d-topdeco::before{animation:rot-slow 90s linear infinite}
.d-topdeco::after{animation:rot-slow 130s linear infinite reverse}
.d-concierge::before{animation:rot-slow 110s linear infinite}
.d-concierge::after{animation:rot-slow 150s linear infinite reverse}
.d-final::before{animation:rot-slow 100s linear infinite}
.d-final::after{animation:rot-slow 140s linear infinite reverse}
@keyframes rot-slow{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* --- 5. Hero画像 Ken Burns + 紗(オーバーレイ) + 絵巻枠 --- */
.d-hero__visual{position:relative}
.d-hero__visual > img{animation:kenburns 22s ease-in-out infinite alternate;transform-origin:50% 42%}
@keyframes kenburns{0%{transform:scale(1.0) translateX(0)}100%{transform:scale(1.07) translateX(-1.2%)}}
/* 紗 */
.d-hero__visual::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(250,246,236,.10) 0%,transparent 22%,transparent 78%,rgba(250,246,236,.16) 100%),
    radial-gradient(ellipse at 82% 18%,rgba(166,138,78,.10) 0%,transparent 50%),
    radial-gradient(ellipse at 12% 82%,rgba(40,73,56,.10) 0%,transparent 55%)}
/* 四隅 留め金風（絵巻ものモチーフ） */
.d-hero__visual::after{content:"";position:absolute;inset:18px;z-index:2;pointer-events:none;
  border:1px solid rgba(250,246,236,.22);
  background:
    linear-gradient(135deg,rgba(166,138,78,.6) 0%,rgba(166,138,78,.6) 1.2%,transparent 1.4%) top left/22px 22px no-repeat,
    linear-gradient(225deg,rgba(166,138,78,.6) 0%,rgba(166,138,78,.6) 1.2%,transparent 1.4%) top right/22px 22px no-repeat,
    linear-gradient(45deg,rgba(166,138,78,.6) 0%,rgba(166,138,78,.6) 1.2%,transparent 1.4%) bottom left/22px 22px no-repeat,
    linear-gradient(315deg,rgba(166,138,78,.6) 0%,rgba(166,138,78,.6) 1.2%,transparent 1.4%) bottom right/22px 22px no-repeat}

/* --- 6. 浮遊する細い金の円(波紋) --- */
.deco-ripple{position:absolute;border-radius:50%;border:1px solid var(--gold);opacity:.18;pointer-events:none;animation:float-ripple 9s ease-in-out infinite}
.deco-ripple--terra{border-color:var(--terra);opacity:.14}
.deco-ripple--bg{border-color:rgba(250,246,236,.22);opacity:.5}
@keyframes float-ripple{0%,100%{transform:translate(0,0) scale(1);opacity:.18}50%{transform:translate(-12px,-18px) scale(1.06);opacity:.3}}

/* --- 7. SVG 波紋(ripple) アニメ --- */
.svg-ripple{position:absolute;pointer-events:none;opacity:.45}
.svg-ripple circle{transform-origin:50% 50%;transform-box:fill-box;animation:rip 6s ease-out infinite}
.svg-ripple circle:nth-child(2){animation-delay:2s}
.svg-ripple circle:nth-child(3){animation-delay:4s}
@keyframes rip{0%{transform:scale(.4);opacity:.65}100%{transform:scale(1);opacity:0}}

/* --- 8. 霞 mist (横長グラデ帯) --- */
.deco-mist{position:absolute;left:50%;transform:translateX(-50%);width:520px;max-width:90%;height:50px;pointer-events:none;opacity:.35;
  background:radial-gradient(ellipse at center,rgba(166,138,78,.4) 0%,transparent 70%);filter:blur(6px)}

/* --- 9. 唐草 / 蔓系の細線(SVG) --- */
.deco-vine{position:absolute;pointer-events:none;opacity:.22}
.deco-vine path{stroke-dasharray:1200;stroke-dashoffset:1200;transition:stroke-dashoffset 3s cubic-bezier(.5,.05,.3,1) .2s}
.in-view .deco-vine path,.deco-vine.in-view path{stroke-dashoffset:0}

/* --- 10. 金箔のかすれ粒 --- */
.deco-flake{position:absolute;border-radius:50%;background:radial-gradient(circle,var(--gold) 0%,rgba(166,138,78,.4) 40%,transparent 75%);pointer-events:none}
.deco-flake--sm{width:6px;height:6px;opacity:.55}
.deco-flake--md{width:10px;height:10px;opacity:.5}
.deco-flake--lg{width:16px;height:16px;opacity:.4}

/* --- 11. CTAボタン 光沢ホバー --- */
.d-hero__cta-primary,.d-final__btn,.d-concierge__footer-cta{position:relative;overflow:hidden}
.d-hero__cta-primary::before,.d-final__btn::before,.d-concierge__footer-cta::before{
  content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;
  background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.22) 50%,transparent 100%);
  transition:left .9s cubic-bezier(.4,.1,.4,1);pointer-events:none}
.d-hero__cta-primary:hover::before,.d-final__btn:hover::before,.d-concierge__footer-cta:hover::before{left:140%}
.d-final__btn{transition:transform .3s ease,box-shadow .3s ease}
.d-final__btn:hover{transform:translateY(-2px);box-shadow:0 22px 50px -12px rgba(40,73,56,.5)}

/* --- 12. trust-badge アイコンの呼吸 --- */
@keyframes pulse-soft{0%,100%{box-shadow:0 0 0 0 rgba(40,73,56,0)}50%{box-shadow:0 0 0 10px rgba(40,73,56,.05)}}

/* --- 13. timeline anchor の鼓動 + 線の流れ --- */
.d-tl-anchor{animation:pulse-anchor 3.6s ease-in-out infinite}
@keyframes pulse-anchor{0%,100%{box-shadow:0 4px 12px -4px rgba(40,50,40,.15)}50%{box-shadow:0 4px 12px -4px rgba(40,50,40,.15),0 0 0 7px rgba(196,102,63,.08)}}
.d-tl::before{background:linear-gradient(180deg,var(--terra) 0%,var(--terra-s) 50%,var(--terra) 100%);background-size:100% 200%;animation:flow-line 9s ease-in-out infinite}
@keyframes flow-line{0%,100%{background-position:0% 0%}50%{background-position:0% 100%}}

/* --- 14. カードホバー強化(全体的に) --- */
.d-fv-bottom__card,.d-foryou-card,.d-scene,.d-flow-step,.d-cmpr__sec,.d-tl-step,.d-fv-ben__card{
  transition:transform .55s cubic-bezier(.2,.8,.25,1),box-shadow .55s cubic-bezier(.2,.8,.25,1),border-color .4s ease}
.d-fv-bottom__card:hover,.d-foryou-card:hover,.d-scene:hover,.d-flow-step:hover,.d-cmpr__sec:hover{
  transform:translateY(-3px);box-shadow:0 18px 40px -16px rgba(40,73,56,.18);border-color:rgba(166,138,78,.4)}

/* --- 15. d-fv-bottom__card 円アイコンに微かな鼓動 --- */
.d-fv-bottom__illust{transition:transform .6s cubic-bezier(.2,.8,.25,1)}
.d-fv-bottom__card:hover .d-fv-bottom__illust{transform:scale(1.07) rotate(-3deg)}
.d-fv-ben__illust{transition:transform .6s cubic-bezier(.2,.8,.25,1)}
.d-fv-ben__card:hover .d-fv-ben__illust{transform:scale(1.07) rotate(-3deg)}

/* --- 16. flow-step 番号の固定→ホバー強調 --- */
.d-flow-num{transition:background .3s ease,color .3s ease,transform .3s ease,border-color .3s ease}
.d-flow-step:hover .d-flow-num{background:var(--terra);color:var(--bg);transform:scale(1.08);border-color:var(--terra)}

/* --- 17. 比較テーブル premium列 ホバー時の発光 --- */
.d-cmpr__tbl tbody td.d-cmpr__tbl-premium{position:relative;z-index:0}
.d-cmpr__tbl tbody td.d-cmpr__tbl-premium::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:-1;
  background:radial-gradient(ellipse at 50% 50%,rgba(166,138,78,.14) 0%,transparent 70%);
  opacity:0;transition:opacity .8s ease}
.d-cmpr__sec:hover .d-cmpr__tbl tbody td.d-cmpr__tbl-premium::after{opacity:1}

/* --- 18. Pricingセクション「+」記号の鼓動 --- */
.d-price-plus{animation:plus-pulse 3.2s ease-in-out infinite}
@keyframes plus-pulse{0%,100%{opacity:.65;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}

/* --- 19. price-card の枠の柔らかな発光 --- */
.d-price-card{position:relative}
.d-price-card::before{
  content:"";position:absolute;inset:-2px;border-radius:7px;pointer-events:none;
  background:linear-gradient(135deg,rgba(166,138,78,.5) 0%,transparent 40%,transparent 60%,rgba(196,102,63,.4) 100%);
  z-index:-1;opacity:.7}

/* --- 20. FAQ ホバー --- */
.d-faq-q{transition:color .3s ease}
.d-faq-q:hover{color:var(--terra)}
.d-faq-q:hover .d-faq-icon{border-color:var(--terra)}
.d-faq-q:hover .d-faq-icon::before,.d-faq-q:hover .d-faq-icon::after{background:var(--terra)}

/* --- 21. tier progress bar の流れ --- */
.d-tl-tiers__bar{position:relative}
.d-tl-tier{position:relative;transition:transform .3s ease,box-shadow .3s ease}
.d-tl-tier:hover{transform:translateY(-2px);box-shadow:0 6px 14px -6px rgba(196,102,63,.3)}

/* --- 22. final セクション 大きな波紋を背景に --- */
.d-final{position:relative}
.d-final::before{z-index:0}
.d-final::after{z-index:0}
.d-final__inner{position:relative;z-index:1}
.d-final__h em{position:relative;display:inline-block}
.d-final__h em::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:8px;
  background:linear-gradient(90deg,transparent,rgba(196,102,63,.25) 20%,rgba(196,102,63,.25) 80%,transparent);
  border-radius:50%;filter:blur(2px)}

/* --- 23. concierge セクション内 装飾 --- */
.d-concierge{position:relative}
.d-concierge__inner{position:relative;z-index:2}

/* --- 24. lead セクションの中央波紋 --- */
.d-lead__inner{position:relative;z-index:1}

/* --- 25. for-you cards 浮遊感 --- */
.d-foryou-card::after{
  content:"";position:absolute;top:0;left:0;width:100%;height:3px;z-index:3;
  background:linear-gradient(90deg,var(--terra) 0%,var(--gold) 100%);
  transform:scaleX(0);transform-origin:left center;transition:transform .6s cubic-bezier(.4,.1,.4,1);
  border-radius:6px 6px 0 0}
.d-foryou-card:hover::after{transform:scaleX(1)}

/* --- 27. requirements list アイテム ホバー --- */
.d-req-list li{transition:transform .3s ease,border-color .3s ease,background-color .3s ease}
.d-req-list li:hover{transform:translateX(4px);border-color:var(--forest)}
.d-req-icon{transition:background .3s ease,color .3s ease,transform .4s ease}
.d-req-list li:hover .d-req-icon{background:var(--forest);color:var(--bg);transform:scale(1.08)}

/* --- 28. SVG draw-line アニメ --- */
.draw-line{stroke-dasharray:1200;stroke-dashoffset:1200;transition:stroke-dashoffset 2.6s cubic-bezier(.45,.05,.3,1)}
.in-view .draw-line,.draw-line.in-view{stroke-dashoffset:0}

/* --- 29. 価格金額のホバー時のトーン --- */
.d-price-layer__amt{transition:color .3s ease;display:inline-block}

/* --- 30. d-fv-bottom 上下に霞の帯 --- */
.d-fv-bottom{position:relative;overflow:hidden}
.d-fv-bottom::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(166,138,78,.3) 25%,rgba(166,138,78,.3) 75%,transparent 100%)}
.d-fv-bottom::after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(166,138,78,.25) 30%,rgba(166,138,78,.25) 70%,transparent 100%)}

/* --- 31. d-cmpr セクションも同様 --- */
.d-cmpr{position:relative;overflow:hidden}

/* --- 32. d-sec 区切りに細い金線 --- */
.d-sec--soft{position:relative;overflow:hidden}

/* --- 33. d-concierge__stamp の鼓動 --- */
.d-concierge__stamp{animation:pulse-stamp 3s ease-in-out infinite}
@keyframes pulse-stamp{0%,100%{box-shadow:0 0 0 0 rgba(196,102,63,.6)}50%{box-shadow:0 0 0 10px rgba(196,102,63,0)}}

/* --- 34. lead__copy emphasis に微妙なフェードハイライト --- */
.d-lead__copy em{position:relative;display:inline-block}

/* --- 35. d-final__btn 矢印の動き --- */
.d-final__btn::after{transition:transform .3s ease}
.d-final__btn:hover::after{transform:translateX(6px)}

/* --- 36. h1, h2タイトル emの装飾(下線をアニメ) --- */
.d-hero__title em,.d-sec-title em{position:relative}
.d-hero__title em::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:linear-gradient(90deg,var(--terra) 0%,var(--gold) 100%);
  transform:scaleX(0);transform-origin:left center;transition:transform 1.2s cubic-bezier(.4,.1,.4,1) .4s}
.in-view .d-hero__title em::after,.d-hero__title.in-view em::after{transform:scaleX(1)}

/* --- 37. d-fv-bottom__num, d-fv-ben__num にカウンタ風の点 --- */
.d-fv-bottom__num::before,.d-fv-ben__num::before{
  content:"●";font-size:.5rem;margin-right:8px;color:var(--terra);opacity:.6;vertical-align:middle}

/* --- 38. price-layer__amt の数字を微発光 --- */
.d-price-layer__amt{position:relative}

/* --- 39. ロゴまわり ふわっと --- */
.d-brandmark img{transition:transform .5s ease,filter .5s ease;display:block}
.d-brandmark__link{display:inline-flex;align-items:center;text-decoration:none;line-height:0}
.d-brandmark__link:hover img{transform:scale(1.03)}

/* --- 40. body 全体の最低限の動きを抑える設定 --- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .js-on .reveal{opacity:1 !important;transform:none !important}
  .d-hero__visual > img{animation:none}
}

/* --- 41. SP対応：装飾サイズ調整 --- */
@media (max-width: 1024px){
  .deco-ripple{display:none}
  .deco-mist{height:32px;width:280px}
  .d-progress{height:1.5px}
}

/* --- 42. d-hero に背景の装飾SVG用ゾーン確保 --- */
.d-hero{position:relative;overflow:hidden}
.d-hero__deco{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.d-hero__inner{position:relative;z-index:1}

/* --- 43. d-lead に装飾SVG用ゾーン --- */
.d-lead__deco{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}

/* --- 44. d-concierge に装飾SVG用ゾーン --- */
.d-concierge__deco{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}

/* --- 45. d-final に装飾SVG用ゾーン --- */
.d-final__deco{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}

/* --- 46. d-fv-bottom にも --- */
.d-fv-bottom__deco{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.d-fv-bottom__inner{position:relative;z-index:1}

/* --- 47. d-cmpr にも装飾ゾーン --- */
.d-cmpr__deco{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.d-cmpr__inner{position:relative;z-index:1}

/* --- 47b. ★ For You カードに画像追加 ★ ----------------------------- */
.d-foryou-card{padding:0;overflow:hidden;display:flex;flex-direction:column}
.d-foryou-card__img{display:block;width:100%;aspect-ratio:5/4;object-fit:cover;background:var(--bg-s);transition:transform .9s cubic-bezier(.2,.8,.25,1);will-change:transform}
.d-foryou-card:hover .d-foryou-card__img{transform:scale(1.05)}
.d-foryou-card__img-wrap{position:relative;overflow:hidden;border-radius:6px 6px 0 0}
/* 画像にうっすら和の紗 */
.d-foryou-card__img-wrap::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 60%,rgba(250,246,236,.18) 100%);
}
.d-foryou-card__body{padding:28px 26px 32px;flex:1;display:flex;flex-direction:column}
/* タグを画像の上に重ねる(上品な金箔バッジ) */
.d-foryou-card__tag{
  position:absolute;top:14px;left:14px;right:auto;
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;background:rgba(31,42,36,.78);color:var(--bg);
  border-radius:2px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  letter-spacing:.22em;font-weight:600;font-size:.6rem;
  border-left:2px solid var(--gold);
  text-transform:uppercase;
}
@media (max-width: 1024px){
  /* SP用 ForYouレイアウトは下段の @media block に統合済み */
}
/* ----------------------------------------------------------------- */

/* --- 48. ★ z-index 整理 ★ ----------------------------------------
   装飾(deco)レイヤーがカードの上に来てしまう問題を解消するため、
   各セクションに stacking context を明示的に作り、
   主要コンテンツを前面、装飾を背面にロックする。
------------------------------------------------------------------- */
.d-hero,.d-fv-bottom,.d-lead,.d-cmpr,.d-concierge,.d-final{isolation:isolate}
/* 装飾レイヤーは必ず背面 */
.d-hero__deco,.d-fv-bottom__deco,.d-lead__deco,.d-cmpr__deco,.d-final__deco{z-index:0 !important}
.d-concierge__deco{z-index:0 !important}
/* 主要コンテンツコンテナは必ず装飾より前面 */
.d-hero__inner,.d-fv-bottom__inner,.d-lead__inner,.d-cmpr__inner,.d-concierge__inner,.d-final__inner{position:relative;z-index:2}
/* 個別のカード/コンテンツも保険で z-index:1 */
.d-fv-bottom__card,.d-foryou-card,.d-cmpr__sec,.d-tl-step,.d-tl-total,
.d-scene,.d-flow-step,.d-price-layer,.d-price-card,.d-price-disclaimer,
.d-faq-item,.d-concierge__footer,
.d-fv-ben__card{position:relative;z-index:1}

/* ============================================================
   ▲▲▲ 和モダン強化レイヤー V2 終了 ▲▲▲
   ============================================================ */


/* ===== Responsive ===== */

/* Tablet (1024px以下) */
@media (max-width: 1024px){
  /* Global */
  .d-brandmark{padding:32px 32px 16px}
  .d-brandmark img{height:24px}

  /* FV下便益 */
  .d-fv-bottom{padding:56px 32px}
  .d-fv-bottom__grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .d-fv-bottom__card:last-child{grid-column:1/-1;max-width:calc(50% - 10px);margin:0 auto}
  .d-fv-bottom__title{font-size:1.5rem}

  /* Lead */
  .d-lead{padding:64px 32px}
  .d-lead__copy{font-size:1.1rem;line-height:2.1}

  /* Common Section */
  .d-sec{padding:64px 32px}
  .d-sec-title{font-size:1.9rem}

  /* Comparison */
  .d-cmpr{padding:64px 32px}
  .d-cmpr__title{font-size:1.8rem}
  .d-cmpr__tbl{font-size:.84rem}
  .d-cmpr__tbl th,.d-cmpr__tbl td{padding:14px 12px}

  /* Pricing */
  .d-price-layers{grid-template-columns:1fr;gap:14px}
  .d-price-plus{justify-self:center;transform:rotate(90deg);margin:4px 0}
  .d-price-layer{padding:22px 20px}
  .d-price-card{padding:28px 24px}
  .d-price-card__feats{grid-template-columns:1fr;gap:10px}

  /* Flow */
  .d-flow{grid-template-columns:repeat(5,minmax(140px,1fr));overflow-x:auto;padding-bottom:12px;-webkit-overflow-scrolling:touch}
  .d-flow::before{left:20px;right:20px}

  /* Timeline */
  .d-tl-tiers{grid-template-columns:1fr;gap:10px}
  .d-tl-tier__arrow{display:none}

  /* Concierge */
  .d-concierge{padding:64px 32px}

  /* Scenes/ForYou/Prob/Areas/Foryou */
  .d-scenes{grid-template-columns:repeat(2,1fr);gap:14px}
  .d-foryou{grid-template-columns:repeat(2,1fr)}
  .d-areas-inline{grid-template-columns:1fr}

  /* FAQ */
  .d-faq{padding:0}
  .d-faq-q{font-size:.92rem}

  /* Final CTA */
  .d-final{padding:64px 32px}
  .d-final__h{font-size:1.6rem}
  .d-final__btn{padding:20px 32px;font-size:1rem}

  /* Footer */
  .d-footer{padding:28px 32px 24px;font-size:.72rem}
  .d-footer__links{gap:6px 16px;justify-content:flex-start;margin-bottom:18px;padding-bottom:16px}
  .d-footer__links a{font-size:.66rem}
}

/* Hero L1 レイアウト (1024px以下で適用: スマホ+タブレット) */
@media (max-width: 1024px){
  .d-hero{padding:0;display:flex;flex-direction:column}
  .d-hero__sp{display:block;order:1}
  .d-hero__inner{padding:0;gap:0;display:flex;flex-direction:column;order:2}
  .d-hero__copy{display:flex;flex-direction:column;padding:0;max-width:none}
  .d-hero__topcopy{display:none}
  .d-hero__title{display:none}
  .d-hero__visual{display:none}

  /* SP専用 FV 表示 */
  .d-hero__sp-intro{padding:24px 24px 26px;background:var(--bg);border-bottom:1px solid var(--line)}
  .d-hero__sp-eb{display:inline-flex;align-items:center;gap:8px;font-family:var(--fs);font-size:.62rem;color:var(--gold);letter-spacing:.22em;text-transform:uppercase;font-weight:700;margin-bottom:10px}
  .d-hero__sp-eb::before{content:"";width:16px;height:1px;background:var(--gold)}
  .d-hero__sp-topcopy{font-family:var(--fs);font-size:1rem;color:var(--ink);font-weight:600;line-height:1.8;letter-spacing:.04em;margin:0}
  .d-hero__sp-topcopy em{font-style:normal;color:var(--gold);font-weight:700;border-bottom:2px solid var(--gold);padding-bottom:1px}
  .d-hero__sp-visual{position:relative;height:420px;overflow:hidden;background:var(--forest)}
  .d-hero__sp-visual img{width:100%;height:100%;object-fit:cover;object-position:center 38%;display:block}
  .d-hero__sp-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(31,42,36,0) 0%,rgba(31,42,36,0) 50%,rgba(31,42,36,.30) 70%,rgba(19,30,24,.82) 100%);pointer-events:none}
  .d-hero__sp-title{position:absolute;left:0;right:0;bottom:0;margin:0;padding:36px 24px 24px;color:#fff;font-family:var(--fs);font-size:1.7rem;font-weight:700;line-height:1.5;letter-spacing:.02em;text-shadow:0 2px 14px rgba(0,0,0,.6),0 1px 4px rgba(0,0,0,.45);background:linear-gradient(180deg,transparent 0%,rgba(19,30,24,.55) 55%,rgba(19,30,24,.85) 100%)}
  .d-hero__sp-title em{font-style:normal;color:#C4A866}

  /* trust-bar と pricecta は画像の下、クリーム背景エリアに */
  .d-hero__trust-bar{margin:20px 20px 20px}
  .d-hero__trust-badge{padding:10px 14px;gap:12px}
  .d-hero__trust-badge__icon{width:34px;height:34px}
  .d-hero__trust-badge__icon svg{width:16px;height:16px}
  .d-hero__trust-badge__text strong{font-size:.88rem}
  .d-hero__trust-badge__text small{font-size:.66rem;line-height:1.55}
  .d-hero__pricecta{flex-direction:row;gap:16px;padding:18px 20px;align-items:center;margin:0 24px 32px}
  .d-hero__price-left{padding-right:20px;border-right:1px solid var(--line);padding-bottom:0;border-bottom:none;text-align:left;align-items:flex-start}
  .d-hero__price-left .d-hero__price-amt{font-size:1.8rem}
  .d-hero__cta-primary{padding:16px 24px;font-size:.96rem}
  .d-hero__cta-note{font-size:.64rem;line-height:1.6}
}

/* Mobile (767px以下) */
@media (max-width: 767px){
  /* Global */
  .d-brandmark{padding:24px 20px 12px}
  .d-brandmark img{height:18px}

  /* Hero SP (狭い画面向け微調整) */
  .d-hero__sp-intro{padding:20px 20px 22px}
  .d-hero__sp-topcopy{font-size:1rem}
  .d-hero__sp-visual{height:380px}
  .d-hero__sp-title{font-size:1.65rem;padding:36px 20px 22px}
  .d-hero__trust-bar{margin:20px 20px 20px}
  .d-hero__pricecta{flex-direction:column;gap:14px;padding:18px;align-items:stretch;margin:0 20px 28px}
  .d-hero__price-left{padding-right:0;border-right:none;padding-bottom:14px;border-bottom:1px solid var(--line);text-align:center;align-items:center}

  /* FV下便益 */
  .d-fv-bottom{padding:48px 20px}
  .d-fv-bottom__grid{grid-template-columns:1fr;gap:16px}
  .d-fv-bottom__card:last-child{max-width:none;margin:0}
  .d-fv-bottom__card{padding:28px 22px}
  .d-fv-bottom__title{font-size:1.55rem;line-height:1.5}
  .d-fv-bottom__eb{font-size:.6rem}
  .d-fv-bottom__t{font-size:1.18rem;line-height:1.55}
  .d-fv-bottom__d{font-size:.78rem}

  /* Lead */
  .d-lead{padding:48px 20px}
  .d-lead__copy{font-size:.92rem;line-height:1.95;letter-spacing:.02em;word-break:keep-all;overflow-wrap:break-word;font-feature-settings:"palt"}
  .d-lead__nowrap{display:inline-block;white-space:nowrap;letter-spacing:0;font-feature-settings:"palt"}
  /* 320pxなど極端に狭い端末向け：縮小して必ず1行にする */
  @media (max-width: 360px){
    .d-lead__nowrap{font-size:.86rem}
  }

  /* Common Section */
  .d-sec{padding:48px 20px}
  .d-sec-title{font-size:1.5rem;line-height:1.55}
  .d-sec-head .eyebrow{font-size:.6rem}

  /* Comparison */
  .d-cmpr{padding:48px 20px}
  .d-cmpr__title{font-size:1.4rem}
  .d-cmpr__lede{font-size:.86rem}
  .d-cmpr__table-wrap{grid-template-columns:1fr;gap:20px}
  .d-cmpr__sec{padding:24px 18px}
  .d-cmpr__sec-head{gap:11px;margin-bottom:16px}
  .d-cmpr__sec-icon{width:40px;height:40px}
  .d-cmpr__sec-icon svg{width:20px;height:20px}
  .d-cmpr__sec-t{font-size:1.08rem}
  .d-cmpr__sec-sub{font-size:.6rem}
  .d-cmpr__tbl{font-size:.82rem}
  .d-cmpr__tbl th,.d-cmpr__tbl td{padding:12px 10px}
  .d-cmpr__tbl thead th{font-size:.68rem}

  /* Pricing */
  .d-price-layer{padding:20px 18px}
  .d-price-layer__amt{font-size:1.8rem}
  .d-price-card{padding:22px 18px}
  .d-price-card__name{font-size:1.04rem}
  .d-price-card__feats li{font-size:.76rem}
  .d-price-disclaimer{padding:20px}
  .d-price-disclaimer__t{font-size:.98rem}
  .d-price-disclaimer__p{font-size:.76rem}

  /* Flow */
  .d-flow{grid-auto-flow:row;grid-auto-columns:none;grid-template-columns:1fr;overflow-x:visible;padding:0;margin:0;gap:10px}
  .d-flow::before{display:none}
  .d-flow-step{padding:14px 16px;display:grid;grid-template-columns:44px 1fr;gap:14px;text-align:left;align-items:center}
  .d-flow-num{width:36px;height:36px;font-size:.86rem;margin:0}
  .d-flow-title{font-size:1.02rem;margin-bottom:4px;text-align:left}
  .d-flow-desc{font-size:.72rem;text-align:left;line-height:1.55}
  .d-flow-step > .d-flow-num{grid-row:1/span 2;align-self:center}
  .d-flow-step > .d-flow-title{grid-column:2}
  .d-flow-step > .d-flow-desc{grid-column:2}

  /* Timeline */
  .d-tl{padding:0 0 0 22px;margin-top:28px}
  .d-tl::before{display:none}
  .d-tl-step{padding:22px 18px 22px 40px;margin-bottom:16px;border-radius:6px}
  .d-tl-step::before{width:3px;border-radius:6px 0 0 6px}
  .d-tl-anchor{left:-18px;top:18px;width:44px;height:44px;border-width:1.5px}
  .d-tl-anchor svg{width:20px;height:20px}
  .d-tl-head{display:block;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
  .d-tl-head-l{display:flex;align-items:center;gap:10px;flex-wrap:nowrap;margin-bottom:8px}
  .d-tl-step-lbl{align-self:auto;gap:4px}
  .d-tl-step-lbl__step{font-size:.6rem;letter-spacing:.2em}
  .d-tl-step-lbl__num{font-size:1.2rem}
  .d-tl-when{padding-left:10px;font-size:1rem;border-left:1px solid var(--line)}
  .d-tl-amount{justify-content:flex-start;align-items:baseline;gap:4px}
  .d-tl-amount__unit{font-size:.78rem !important}
  .d-tl-amount__val{font-size:1.6rem}
  .d-tl-amount__off{font-size:1.05rem;margin-left:6px}
  .d-tl-title{font-size:1.16rem;line-height:1.55;margin-bottom:8px}
  .d-tl-lead{font-size:.84rem;line-height:1.85;margin-bottom:14px}
  .d-tl-note{padding:10px 12px;font-size:.72rem;line-height:1.65}
  /* Tiers: 3列→縦並び */
  .d-tl-tiers{padding:14px 14px;margin-bottom:12px}
  .d-tl-tiers__lbl{font-size:.6rem;margin-bottom:10px}
  .d-tl-tiers__bar{flex-direction:column;gap:8px}
  .d-tl-tier{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;text-align:left;width:100%;gap:10px}
  .d-tl-tier__hr{margin-bottom:0;font-size:.74rem;white-space:nowrap;flex-shrink:0}
  .d-tl-tier__hr b{font-size:.96rem}
  .d-tl-tier__val{
    font-size:1rem;white-space:nowrap;flex-shrink:0;
    font-variant-numeric:tabular-nums;font-feature-settings:"tnum";
    text-align:right;
  }
  .d-tl-tier__arrow{display:none}
  /* Grand Total */
  .d-tl-total{margin-top:28px;flex-direction:column;gap:16px;padding:24px 20px;align-items:stretch;text-align:left;border-radius:6px}
  .d-tl-total__val{font-size:1.5rem;line-height:1.4}
  .d-tl-total__lbl{font-size:.58rem;letter-spacing:.22em}
  .d-tl-total__sub{font-size:.78rem}
  .d-tl-total__row{flex-direction:column;align-items:flex-start;gap:6px;padding:12px 0}
  .d-tl-total__row:first-child{padding-top:4px}
  .d-tl-total__row-label b{font-size:.86rem}
  .d-tl-total__row-formula{font-size:.7rem;line-height:1.6}
  .d-tl-total__row-amt{align-self:flex-end;font-size:1rem}
  .d-tl-total__note{font-size:.7rem;line-height:1.7}

  /* Concierge */
  .d-concierge{padding:48px 20px}
  .d-concierge__title{font-size:1.4rem}
  .d-concierge__footer{display:flex;flex-direction:column;gap:18px;padding:24px 22px;text-align:left;align-items:stretch}
  .d-concierge__footer-h{font-size:.98rem}
  .d-concierge__footer-desc{font-size:.78rem;line-height:1.85}
  .d-concierge__footer-cta{align-self:center;padding:14px 30px}

  /* Scenes / ForYou / Prob / Areas */
  .d-scenes{grid-template-columns:1fr;gap:12px}
  .d-scene{padding:22px 18px}

  /* ★ For You カード SPは横並び（画像左 + テキスト右）★ */
  .d-foryou{grid-template-columns:1fr;gap:10px}
  .d-foryou-card{display:grid;grid-template-columns:108px 1fr;align-items:stretch;padding:0}
  .d-foryou-card__img-wrap{border-radius:6px 0 0 6px;height:100%;overflow:hidden}
  .d-foryou-card__img-wrap::after{background:linear-gradient(90deg,transparent 65%,rgba(250,246,236,.2) 100%)}
  .d-foryou-card__img{aspect-ratio:auto;width:100%;height:100%;min-height:108px;object-fit:cover}
  .d-foryou-card__body{padding:12px 14px 12px 16px;display:flex;flex-direction:column;justify-content:center;gap:0}
  .d-foryou-card__age{font-size:1.32rem;line-height:1.25;margin-bottom:8px}
  .d-foryou-card__range{font-size:.74rem;line-height:1.3;margin-bottom:4px;color:var(--terra);font-weight:700}
  .d-foryou-card__desc{font-size:.7rem;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .d-foryou-card__tag{top:6px;left:6px;font-size:.54rem;padding:3px 7px;letter-spacing:.18em;border-left-width:2px}
  .d-foryou-card::after{display:none}
  /* For Youセクションの上下余白を詰める */
  #foryou-sp{padding:40px 20px}
  #foryou-sp .d-sec-head{margin-bottom:20px}

  /* FAQ */
  .d-faq-q{font-size:.86rem;padding:16px 0;gap:10px}
  .d-faq-icon{width:22px;height:22px}

  /* Final CTA */
  .d-final{padding:48px 20px}
  .d-final__eb{font-size:.62rem}
  .d-final__h{font-size:1.3rem;line-height:1.55;margin-bottom:12px}
  .d-final__sub{font-size:.86rem}
  .d-final__btn{padding:18px 24px;font-size:.92rem;width:100%;justify-content:center}
  .d-final__fine{font-size:.66rem;margin-top:12px}


  /* Footer */
  .d-footer{padding:22px 20px 18px;font-size:.66rem;line-height:1.6}
  .d-footer__links{gap:5px 14px;margin-bottom:14px;padding-bottom:14px}
  .d-footer__links a{font-size:.62rem}
  .d-footer__copyright{font-size:.62rem}

  /* 横スクロール防止 */
  .d-wrap{overflow-x:hidden}
}

/* ── For Youカード 縦幅統一（強制） ─────── */
.d-foryou{align-items:stretch !important;grid-auto-rows:1fr}
/* カード自体を Grid にして row1=画像 / row2=本文 と固定し、bodyを 1fr で残り全部に広げる */
.d-foryou-card{
  display:grid !important;
  grid-template-rows:auto 1fr !important;
  align-self:stretch !important;
  min-height:0;
  /* JSで実測同期した高さが入る */
}
.d-foryou-card__img-wrap{
  aspect-ratio:5/4;width:100%;height:auto;
  position:relative;overflow:hidden;
}
.d-foryou-card__img{
  width:100%;height:100%;aspect-ratio:auto;object-fit:cover;display:block;
}
.d-foryou-card__body{
  display:flex;flex-direction:column;
}
@media (max-width: 767px){
  /* SP横並びレイアウト時：説明文を省略しない & 画像枠は親グリッドに合わせる */
  .d-foryou-card{
    display:grid !important;
    grid-template-columns:108px 1fr !important;
    grid-template-rows:none !important;
    min-height:0;
  }
  .d-foryou-card__img-wrap{aspect-ratio:auto;height:100%}
  .d-foryou-card__img{aspect-ratio:auto;min-height:108px}
  .d-foryou-card__desc{
    display:block !important;
    -webkit-line-clamp:initial !important;
    -webkit-box-orient:initial !important;
    overflow:visible !important;
  }
}

/* ── ヘッダーナビゲーション（PCのみ・固定表示） ─────── */
.d-brandmark{
  position:fixed !important;
  top:0;left:0;right:0;
  width:auto;
  z-index:200;
  padding:12px 44px;
  background:rgba(250,246,236,.94) !important;
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(166,138,78,.16);
  justify-content:space-between;
  gap:24px;
  transform:none !important;
}
.d-brandmark img{height:26px;flex-shrink:0}
.d-nav{
  display:flex;align-items:center;gap:2px;
  margin-left:auto;
}
.d-nav__link{
  position:relative;
  display:inline-flex;align-items:center;
  padding:8px 12px;
  font-family:var(--fs);font-size:.84rem;font-weight:600;
  color:var(--ink);text-decoration:none;
  letter-spacing:.02em;
  border-radius:4px;
  white-space:nowrap;
  transition:color .2s ease, background .2s ease;
}
.d-nav__link::after{
  content:"";
  position:absolute;left:12px;right:12px;bottom:4px;
  height:1px;background:var(--gold);
  transform:scaleX(0);transform-origin:left center;
  transition:transform .3s cubic-bezier(.2,.8,.25,1);
}
.d-nav__link:hover{color:var(--forest)}
.d-nav__link:hover::after{transform:scaleX(1)}
.d-nav__link.is-active{color:var(--forest)}
.d-nav__link.is-active::after{transform:scaleX(1)}
.d-nav__cta-group{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  margin-left:28px;
}
.d-nav__cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 36px;
  min-width:200px;
  background:var(--forest);color:var(--bg);text-decoration:none;
  font-family:var(--fs);font-size:.9rem;font-weight:700;letter-spacing:.08em;
  border-radius:999px;
  box-shadow:0 8px 20px -8px rgba(40,73,56,.5);
  transition:transform .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.d-nav__cta:hover{transform:translateY(-1px);box-shadow:0 12px 26px -10px rgba(40,73,56,.6)}
.d-nav__cta span{font-weight:400;font-size:1rem}
.d-nav__cta-note{
  font-size:.58rem;color:var(--ink-s);letter-spacing:.04em;font-weight:500;
  white-space:nowrap;line-height:1.3;
}

/* 固定ヘッダー分の本文オフセット（PC のみ） */
@media (min-width: 1025px){
  body{padding-top:62px}
}

/* スクロール時のオフセット */
html{scroll-behavior:smooth}
section[id]{scroll-margin-top:78px}

/* やや狭いPC幅向けの密度調整 */
@media (min-width: 1025px) and (max-width: 1279px){
  .d-brandmark{padding:10px 28px;gap:14px}
  .d-nav{gap:0}
  .d-nav__link{padding:8px 7px;font-size:.74rem}
  .d-nav__link::after{left:7px;right:7px}
  .d-nav__cta-group{margin-left:18px;gap:2px}
  .d-nav__cta{padding:10px 28px;font-size:.82rem;min-width:170px}
  .d-nav__cta-note{font-size:.54rem}
  .d-brandmark img{height:24px}
}

/* SP/タブレット：ヘッダーは固定でスリムに、ハンバーガーで開閉
   FV表示中は隠れていて、少しスクロールするとスライドダウンする */
@media (max-width: 1024px){
  .d-brandmark{
    position:fixed !important;
    top:0;left:0;right:0;
    z-index:200;
    background:#FAF6EC !important;
    border-bottom:1px solid rgba(166,138,78,.16);
    padding:11px 20px;
    justify-content:space-between;
    align-items:center;
    transform:translateY(-100%);
    opacity:0;
    pointer-events:none;
    transition:transform .35s cubic-bezier(.4,0,.2,1), opacity .25s ease;
  }
  body.is-scrolled .d-brandmark{
    transform:translateY(0);
    opacity:1;
    pointer-events:auto;
  }
  .d-brandmark img{height:24px}
  .d-nav{display:none !important}
  body{padding-top:0}
  section[id]{scroll-margin-top:54px}
}
@media (max-width: 767px){
  .d-brandmark{padding:10px 16px}
  .d-brandmark img{height:18px}
  body{padding-top:0}
  section[id]{scroll-margin-top:50px}
}

/* ── ハンバーガーボタン ─────── */
.d-nav-toggle{
  display:none;
  width:40px;height:40px;
  background:none;border:none;
  padding:0;cursor:pointer;
  position:relative;
  flex-shrink:0;
  -webkit-tap-highlight-color:transparent;
}
@media (max-width: 1024px){
  .d-nav-toggle{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px}
}
.d-nav-toggle__bar{
  display:block;
  width:22px;height:2px;
  background:var(--ink);
  border-radius:2px;
  transition:transform .3s cubic-bezier(.5,.1,.3,1),opacity .25s ease;
  transform-origin:center;
}
.d-nav-toggle.is-open .d-nav-toggle__bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.d-nav-toggle.is-open .d-nav-toggle__bar:nth-child(2){opacity:0;transform:scaleX(.4)}
.d-nav-toggle.is-open .d-nav-toggle__bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── SPメニュードロワー ─────── */
.d-drawer{
  display:none;
  position:fixed;
  inset:0;
  z-index:195;
  background:rgba(250,246,236,.98);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  backdrop-filter:saturate(180%) blur(20px);
  flex-direction:column;
  padding:74px 28px 32px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  opacity:0;
  transition:opacity .25s cubic-bezier(.4,.0,.2,1);
}
.d-drawer.is-open{display:flex;opacity:1}
.d-drawer__close{
  position:absolute;top:11px;right:14px;
  width:42px;height:42px;
  background:none;border:none;
  font-size:30px;line-height:1;
  color:var(--ink);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  -webkit-tap-highlight-color:transparent;
}
.d-drawer__nav{
  display:flex;flex-direction:column;gap:0;
  flex:1;margin-top:8px;
}
.d-drawer__link{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 4px;
  font-family:var(--fs);
  font-size:1.08rem;font-weight:600;
  color:var(--ink);text-decoration:none;
  letter-spacing:.04em;
  border-bottom:1px solid rgba(166,138,78,.18);
  transition:color .2s ease,padding-left .2s ease;
}
.d-drawer__link::after{
  content:"›";
  color:var(--gold);font-size:1.4rem;font-weight:300;
  margin-left:12px;
}
.d-drawer__link:active{color:var(--forest);padding-left:8px}
.d-drawer__cta{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin-top:32px;
  padding:18px 24px;
  background:var(--forest);color:var(--bg);
  text-decoration:none;border-radius:999px;
  font-family:var(--fs);font-size:1rem;font-weight:700;letter-spacing:.08em;
  box-shadow:0 10px 22px -8px rgba(40,73,56,.5);
}
.d-drawer__cta span{font-weight:400;font-size:1.1rem}
.d-drawer__note{
  text-align:center;
  margin-top:14px;
  font-size:.74rem;color:var(--ink-s);letter-spacing:.06em;
}
@media (min-width: 1025px){
  .d-drawer,.d-nav-toggle{display:none !important}
}

/* ドロワー表示中はスティッキーフッターを隠す */
body.is-drawer-open .d-fixed-cta{display:none !important}


/* SPセクションタイトル：意図しない位置で改行されないよう調整 */
@media (max-width: 767px){
  .d-sec-title{
    word-break:keep-all;
    overflow-wrap:break-word;
    line-break:strict;
    font-feature-settings:"palt";
  }
}

/* ── スクロール領域の上端に薄いフェード（コンテンツ続いてる感） ─────── */
.d-wrap::before{
  content:"";
  position:fixed;
  top:0;left:0;right:0;
  height:50px;
  pointer-events:none;
  z-index:50;
  background:linear-gradient(180deg, var(--bg) 0%, rgba(250,246,236,.7) 50%, transparent 100%);
}
@media (min-width: 1025px){
  /* PCは常時固定ヘッダーの直下にフェード */
  .d-wrap::before{top:62px;height:50px}
}
@media (max-width: 1024px){
  /* SPはヘッダー非表示中はフェードも隠す。スクロールでヘッダー出現と同時にフェードも表示 */
  .d-wrap::before{display:none}
  body.is-scrolled .d-wrap::before{display:block;top:52px;height:42px}
}
@media (max-width: 767px){
  body.is-scrolled .d-wrap::before{top:48px;height:38px}
}

/* ── FVスマホ：背景の動く円・点が文字とかぶるのを防止 ─────── */
@media (max-width: 1024px){
  .d-hero__deco .deco-flake,
  .d-hero__deco .deco-ripple,
  .d-hero__deco .svg-ripple{display:none !important}
}

/* ── 対象エリア グループ + チップ表示 ─────── */
.d-areas-groups{
  display:flex;flex-direction:column;gap:10px;
  margin-top:14px;padding-top:14px;
  border-top:1px solid var(--line);
}
.d-areas-group{
  display:grid;
  grid-template-columns:64px 1fr;
  gap:16px;
  align-items:center;
}
.d-areas-group__lbl{
  font-family:var(--fs);
  font-size:1rem;font-weight:700;color:var(--terra);
  letter-spacing:.1em;
}
.d-areas-group__chips{
  display:flex;flex-wrap:wrap;gap:5px;
}
.d-areas-group__chips span{
  display:inline-flex;align-items:center;
  padding:5px 12px;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:999px;
  font-family:var(--fs);
  font-size:.76rem;font-weight:500;
  color:var(--ink);
  letter-spacing:.02em;
  white-space:nowrap;
  transition:border-color .2s ease, color .2s ease, background .2s ease;
}
.d-areas-group__chips span:hover{
  border-color:var(--forest);
  color:var(--forest);
  background:rgba(40,73,56,.04);
}
@media (max-width: 767px){
  .d-areas-group{grid-template-columns:auto 1fr;gap:12px;align-items:center}
  .d-areas-group__lbl{font-size:.92rem;letter-spacing:.08em;min-width:46px}
  .d-areas-group__chips{gap:4px}
  .d-areas-group__chips span{padding:4px 10px;font-size:.7rem}
}

/* ── For You セクションの背景：3つの価値(--bg-s)との差別化 ─────── */
#foryou-sp{background:var(--bg-d) !important}
/* For Youカード自体の背景を維持 (--bg) → 濃いめ背景に対してカードが浮き立つ */
#foryou-sp .d-foryou-card{background:var(--bg)}
#foryou-sp .d-foryou-card__img-wrap{background:var(--bg-s)}

/* 生後4〜7ヶ月（For Youカード2番目）の画像位置：赤ちゃんが見切れないよう左寄せに */
.d-foryou-card:nth-child(2) .d-foryou-card__img{
  object-position:30% center;
}
@media (max-width: 767px){
  /* SP横並びでは特に左寄り表示で被写体を中央付近へ */
  .d-foryou-card:nth-child(2) .d-foryou-card__img{object-position:22% center}
}

/* ── 選考制バッジ（メインCTA用） ─────── */
.d-cta-badge{
  display:inline-flex;align-items:center;gap:8px;
  align-self:center;
  padding:6px 14px;
  background:rgba(196,102,63,.10);
  color:var(--terra);
  border:1px solid rgba(196,102,63,.32);
  border-radius:999px;
  font-family:var(--fs);
  font-size:.74rem;font-weight:700;letter-spacing:.1em;
  white-space:nowrap;
}
.d-cta-badge--center{margin:0 auto 18px}
.d-cta-badge__dot{
  display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--terra);
  position:relative;
  flex-shrink:0;
}
.d-cta-badge__dot::after{
  content:"";position:absolute;inset:-3px;
  border-radius:50%;border:1px solid rgba(196,102,63,.45);
  animation:cta-badge-pulse 1.6s ease-out infinite;
}
@keyframes cta-badge-pulse{
  0%{transform:scale(1);opacity:.8}
  100%{transform:scale(1.8);opacity:0}
}
@media (max-width: 767px){
  .d-cta-badge{font-size:.66rem;letter-spacing:.06em;padding:5px 11px;gap:6px}
  .d-cta-badge--center{margin-bottom:14px}
}

/* ── PC用 スティッキーフッターCTA ─────── */
@media (min-width: 1025px){
  .d-fixed-cta{
    display:flex;
    position:fixed;
    left:0;right:0;bottom:0;
    z-index:80;
    align-items:center;
    gap:20px;
    padding:12px 40px;
    background:rgba(250,246,236,.96);
    -webkit-backdrop-filter:saturate(180%) blur(14px);
    backdrop-filter:saturate(180%) blur(14px);
    border-top:1px solid rgba(166,138,78,.18);
    box-shadow:0 -10px 28px -12px rgba(40,50,40,.18);
    padding-bottom:12px;
  }
  .d-fixed-cta__price{
    display:flex;flex-direction:row;align-items:baseline;gap:10px;
    padding-right:24px;border-right:1px solid rgba(166,138,78,.22);
    flex-shrink:0;
  }
  .d-fixed-cta__lbl{
    font-size:.66rem;color:var(--ink-s);letter-spacing:.16em;text-transform:uppercase;font-weight:600;
    margin-bottom:0;
  }
  .d-fixed-cta__amt{
    font-family:var(--fs);font-size:1.45rem;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em;
  }
  .d-fixed-cta__amt span{font-size:.78rem;color:var(--ink-s);font-weight:500;margin-left:4px}
  .d-fixed-cta__msg{
    flex:1;
    font-family:var(--fs);font-size:.86rem;color:var(--ink);font-weight:500;letter-spacing:.04em;
  }
  .d-fixed-cta__msg b{color:var(--forest);font-weight:700}
  .d-fixed-cta__btn-group{
    display:flex;flex-direction:column;align-items:center;gap:3px;
    flex-shrink:0;
  }
  .d-fixed-cta__btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:11px 28px;
    background:var(--forest);color:var(--bg);
    border-radius:999px;text-decoration:none;
    font-family:var(--fs);font-size:.92rem;font-weight:700;letter-spacing:.08em;
    box-shadow:0 8px 18px -8px rgba(40,73,56,.5);
    transition:transform .2s ease, box-shadow .2s ease;
  }
  .d-fixed-cta__btn-note{
    font-size:.64rem;color:var(--ink-s);letter-spacing:.06em;font-weight:500;
    white-space:nowrap;
  }
  .d-fixed-cta__btn:hover{transform:translateY(-1px);box-shadow:0 12px 26px -10px rgba(40,73,56,.6)}
  .d-fixed-cta__btn span{font-weight:400;font-size:1rem}
  /* PC は本文末尾の余白も追加（フッターと重ならない） */
  body{padding-bottom:54px}
}

/* ── FV月額プラン料金 SP用スティッキーフッター（独立DOM） ─────── */
.d-fixed-cta{display:none}
@media (max-width: 1024px){
  /* PC用 hero内 pricectaは非表示。代わりに独立DOMで常時表示 */
  .d-hero__pricecta{display:none !important}

  .d-fixed-cta{
    display:flex;
    position:fixed;
    left:0;right:0;bottom:0;
    z-index:9990;
    align-items:center;
    gap:12px;
    padding:9px 16px;
    background:#F5EFDD;
    border-top:1px solid var(--line);
    box-shadow:0 -8px 24px -8px rgba(40,50,40,.22);
    /* iOS safe-area対応 */
    padding-bottom:calc(9px + env(safe-area-inset-bottom));
  }
  .d-fixed-cta__price{
    display:flex;flex-direction:column;align-items:flex-start;
    padding-right:12px;
    border-right:1px solid var(--line);
    flex-shrink:0;white-space:nowrap;
  }
  .d-fixed-cta__lbl{font-size:.56rem;color:var(--ink-s);letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:2px}
  .d-fixed-cta__amt{font-family:var(--fs);font-size:1.25rem;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em}
  .d-fixed-cta__amt span{font-size:.66rem;color:var(--ink-s);font-weight:500;margin-left:2px}
  .d-fixed-cta__btn-group{
    flex:1;
    display:flex;flex-direction:column;align-items:stretch;gap:3px;
  }
  .d-fixed-cta__btn{
    width:100%;
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:10px 14px;
    background:var(--forest);color:var(--bg);
    border-radius:999px;text-decoration:none;
    font-family:var(--fs);font-size:.9rem;font-weight:700;letter-spacing:.06em;
    box-shadow:0 6px 14px -6px rgba(40,73,56,.5);
    transition:transform .2s,box-shadow .2s;
  }
  .d-fixed-cta__btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px -8px rgba(40,73,56,.6)}
  .d-fixed-cta__btn span{font-weight:400;font-size:1rem}
  .d-fixed-cta__btn-note{
    text-align:center;
    font-size:.6rem;color:var(--ink-s);letter-spacing:.04em;font-weight:500;
    white-space:nowrap;
  }
  body{padding-bottom:calc(86px + env(safe-area-inset-bottom))}
}
@media (max-width: 767px){
  .d-fixed-cta{padding:7px 14px;padding-bottom:calc(7px + env(safe-area-inset-bottom));gap:10px}
  .d-fixed-cta__price{padding-right:10px}
  .d-fixed-cta__amt{font-size:1.15rem}
  .d-fixed-cta__btn{padding:8px 12px;font-size:.84rem}
  .d-fixed-cta__btn-note{font-size:.56rem;letter-spacing:.02em}
  body{padding-bottom:calc(80px + env(safe-area-inset-bottom))}
}

/* ── スマホ表示時 スクロールバー非表示 ─────── */
@media (max-width: 1024px){
  html,body{scrollbar-width:none;-ms-overflow-style:none}
  html::-webkit-scrollbar,
  body::-webkit-scrollbar{width:0;height:0;display:none;background:transparent}
  /* 内部スクロール領域も含めて全要素 */
  *{scrollbar-width:none;-ms-overflow-style:none}
  *::-webkit-scrollbar{width:0;height:0;display:none;background:transparent}
  /* iOS Safari: スクロール方向反転時のロック対策。ラバーバンド/連鎖スクロールを抑制 */
  html,body{overscroll-behavior-y:contain}
  /* 縦スクロールを明示。iOSがジェスチャー判定で迷うのを防ぐ */
  body{touch-action:pan-y}
}

/* ── 3つの価値カード 画像対応 ─────── */
.d-fv-bottom__card{
  padding:0 !important;
  overflow:hidden;
  display:flex;flex-direction:column;
}
.d-fv-bottom__img-wrap{
  width:100%;
  aspect-ratio:5/4;
  overflow:hidden;
  position:relative;
  background:var(--bg-s);
  border-radius:8px 8px 0 0;
}
.d-fv-bottom__img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .9s cubic-bezier(.2,.8,.25,1);will-change:transform;
}
.d-fv-bottom__img-wrap::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 65%,rgba(250,246,236,.15) 100%);
}
.d-fv-bottom__card:hover .d-fv-bottom__img{transform:scale(1.04)}
.d-fv-bottom__card > .d-fv-bottom__num,
.d-fv-bottom__card > .d-fv-bottom__t,
.d-fv-bottom__card > .d-fv-bottom__d{
  padding-left:30px;padding-right:30px;
}
.d-fv-bottom__card > .d-fv-bottom__num{margin-top:30px}
.d-fv-bottom__card > .d-fv-bottom__d{flex:1;padding-bottom:18px}
.d-fv-bottom__card > .d-fv-bottom__d:last-child{padding-bottom:64px}

@media (max-width: 767px){
  .d-fv-bottom__card > .d-fv-bottom__num,
  .d-fv-bottom__card > .d-fv-bottom__t,
  .d-fv-bottom__card > .d-fv-bottom__d{
    padding-left:22px;padding-right:22px;
  }
  .d-fv-bottom__card > .d-fv-bottom__num{margin-top:20px}
  .d-fv-bottom__card > .d-fv-bottom__d:last-child{padding-bottom:24px}
}

/* ── コンシェルジュ ヒーロー画像 ─────── */
.d-concierge__hero{
  max-width:880px;margin:0 auto 56px;
  border-radius:8px;overflow:hidden;
  position:relative;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.45);
  border:1px solid rgba(250,246,236,.08);
}
.d-concierge__hero-img{
  width:100%;height:auto;display:block;
  aspect-ratio:16/9;object-fit:cover;
  transition:transform 1.2s cubic-bezier(.2,.8,.25,1);
  will-change:transform;
}
.d-concierge__hero:hover .d-concierge__hero-img{transform:scale(1.03)}
.d-concierge__hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 60%,rgba(40,73,56,.18) 100%);
}
@media (max-width: 1024px){
  .d-concierge__hero{margin:0 auto 40px;border-radius:6px}
  .d-concierge__hero-img{aspect-ratio:4/3}
}
@media (max-width: 767px){
  .d-concierge__hero{margin:0 -8px 32px;border-radius:4px}
  .d-concierge__hero-img{aspect-ratio:3/2}
}

/* ── 比較表 SP：PCと同じ表レイアウトを維持しつつ、改行位置と字詰めを調整 ─────── */
@media (max-width: 767px){
  .d-cmpr__tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .d-cmpr__tbl thead th,
  .d-cmpr__tbl tbody td{
    padding:9px 8px;
    font-size:.78rem;
    word-break:keep-all;
    overflow-wrap:break-word;
    line-break:strict;
    font-feature-settings:"palt";
  }
  .d-cmpr__tbl thead th{font-size:.66rem;letter-spacing:.06em}
  .d-cmpr__tbl tbody td:nth-child(1){font-size:.82rem}
  /* 通常列：1文字だけ改行されないよう小さく＆濃く＆改行禁止 */
  .d-cmpr__tbl tbody td.d-cmpr__tbl-normal{
    font-size:.7rem;
    color:var(--ink);
    padding:9px 4px;
    white-space:nowrap;
    overflow-wrap:normal;
    letter-spacing:0;
  }
  .d-cmpr__tbl tbody td.d-cmpr__tbl-premium{font-size:.84rem}
  .d-cmpr__tbl tbody td .u{font-size:.66rem}
}

/* ── コンシェルジュ Split Layout（PCのみ：画像左 / ヘッド右） ─────── */
@media (min-width: 1025px){
  .d-concierge__split{
    display:grid;
    grid-template-columns:minmax(0,420px) 1fr;
    gap:56px;
    align-items:center;
    margin-bottom:64px;
    max-width:1100px;
    margin-left:auto;margin-right:auto;
  }
  .d-concierge__split .d-concierge__head{
    text-align:left;
    margin:0;
    max-width:none;
  }
  .d-concierge__split .d-concierge__title{font-size:2.1rem;line-height:1.55}
  .d-concierge__split .d-concierge__lede{margin:0;line-height:1.95}
  .d-concierge__split .d-concierge__hero{
    margin:0;
    max-width:none;
    width:100%;
  }
  .d-concierge__split .d-concierge__hero-img{
    aspect-ratio:4/5;
  }
}
@media (max-width: 1024px){
  .d-concierge__split{display:flex;flex-direction:column;gap:0}
}



/* ── FAQ末尾 お問い合わせブロック ─────── */
.d-faq-inquiry{
  margin-top:32px;padding:24px 28px;
  background:var(--bg);border:1px solid var(--line);border-radius:6px;
  text-align:center;
}
.d-faq-inquiry p{
  font-size:.86rem;color:var(--ink-s);margin-bottom:14px;letter-spacing:.02em;
}
.d-faq-inquiry__btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 22px;
  background:var(--bg);color:var(--forest);
  border:1px solid var(--forest);border-radius:999px;
  font-family:var(--fs);font-size:.86rem;font-weight:700;letter-spacing:.06em;
  text-decoration:none;
  transition:background .2s ease,color .2s ease,transform .2s ease;
}
.d-faq-inquiry__btn:hover{background:var(--forest);color:var(--bg);transform:translateY(-1px)}
.d-faq-inquiry__btn span{font-weight:400}
@media (max-width: 767px){
  .d-faq-inquiry{padding:18px 20px;margin-top:24px}
  .d-faq-inquiry p{font-size:.78rem}
  .d-faq-inquiry__btn{font-size:.8rem;padding:9px 18px}
}

/* ── SP用フォント追加調整（読みやすさ優先） ─────── */
@media (max-width: 767px){
  .d-scene__title{font-size:1.15rem;line-height:1.45;margin-bottom:6px}
  .d-req-txt{font-size:1rem;line-height:1.65}
  .d-req-txt small{font-size:.78rem;margin-top:4px}
}
