/* ===== goodeli.jp デザイントークン（実サイトCSSより抽出） ===== */
:root{
  --color-accent:#fb503b;       /* CTA / 価格強調 */
  --color-green:#85a37e;        /* セカンダリ */
  --color-tan:#ca956d;          /* テキストアクセント */
  --color-yellow:#dda83b;       /* バッジ・ハイライト */
  --color-base:#fff;
  --color-bg-primary:#f5f2e9;   /* クリーム背景 */
  --color-bg-secondary:#ece4da; /* 一段濃いベージュ */
  --color-text-main:#1a1a19;
  --color-text-sub:#6b6b66;
  --font-main:"Zen Kaku Gothic New",sans-serif;
  --font-en:"Figtree",sans-serif;
  --maxw:1080px;
  --radius:18px;
  --shadow:0 18px 50px rgba(26,26,25,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-main);
  color:var(--color-text-main);
  background:var(--color-bg-primary);
  line-height:1.85;
  font-weight:500;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.en{font-family:var(--font-en);letter-spacing:.04em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.accent{color:var(--color-accent)}
.green{color:var(--color-green)}

/* ===== Header ===== */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(245,242,233,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(26,26,25,.06);
}
header.site .inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;
}
header.site .logo img{height:26px;width:auto}
header.site .h-cta{
  font-family:var(--font-en);font-weight:700;font-size:14px;
  background:var(--color-accent);color:#fff;
  padding:11px 22px;border-radius:999px;letter-spacing:.06em;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 6px 18px rgba(251,80,59,.30);
}
header.site .h-cta:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(251,80,59,.40)}
@media(max-width:680px){header.site .h-cta{display:none}}

/* ===== Buttons ===== */
.btn-primary{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--color-accent);color:#fff;font-weight:700;
  font-size:clamp(17px,2.4vw,21px);
  padding:20px 46px;border-radius:999px;
  box-shadow:0 14px 32px rgba(251,80,59,.34);
  transition:transform .2s, box-shadow .2s;
  position:relative;
}
.btn-primary::after{content:"›";font-family:var(--font-en);font-size:1.4em;line-height:0;transform:translateY(-1px)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 40px rgba(251,80,59,.44)}
.btn-sub{font-size:13px;color:var(--color-text-sub);margin-top:14px;font-weight:500}

/* ===== Hero ===== */
.hero{
  position:relative;
  background:linear-gradient(180deg,#f7f4ec 0%, #f0eadd 100%);
  padding:48px 0 0;
  overflow:hidden;
}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center}
.hero .eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--color-green);color:#fff;
  font-size:13px;font-weight:700;letter-spacing:.08em;
  padding:7px 16px;border-radius:999px;margin-bottom:22px;
}
.hero h1{
  font-size:clamp(30px,5.4vw,52px);
  font-weight:900;line-height:1.34;letter-spacing:.01em;
  margin-bottom:22px;
}
.hero h1 .big{
  font-family:var(--font-en);font-weight:800;
  color:var(--color-accent);font-size:1.32em;letter-spacing:0;
}
.hero h1 .mark{
  background:linear-gradient(transparent 62%, rgba(221,168,59,.42) 62%);
}
.hero p.lead{font-size:clamp(15px,2vw,17px);color:#4a4a45;margin-bottom:30px;font-weight:500}
.hero .photo{
  position:relative;border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow);aspect-ratio:1/1;
}
.hero .photo img{width:100%;height:100%;object-fit:cover}
.hero .price-badge{
  position:absolute;right:-6px;bottom:-6px;
  width:148px;height:148px;
  display:grid;place-content:center;text-align:center;
  background:var(--color-accent);color:#fff;border-radius:50%;
  box-shadow:0 12px 30px rgba(251,80,59,.4);
  border:4px solid #fff;transform:rotate(-6deg);
}
.price-badge .s{font-size:12px;font-weight:700;letter-spacing:.04em}
.price-badge .n{font-family:var(--font-en);font-weight:800;font-size:34px;line-height:1.1}
.price-badge .n small{font-size:15px}
.hero .strip{
  margin-top:42px;background:var(--color-text-main);color:#fff;
  border-radius:18px 18px 0 0;
}
.hero .strip ul{
  list-style:none;display:flex;justify-content:center;flex-wrap:wrap;gap:8px 40px;
  padding:20px 24px;max-width:var(--maxw);margin:0 auto;
  font-size:14px;font-weight:700;letter-spacing:.04em;
}
.hero .strip li{display:flex;align-items:center;gap:9px}
.hero .strip li::before{content:"✓";color:var(--color-yellow);font-weight:900}
@media(max-width:780px){
  .hero .wrap{grid-template-columns:1fr;gap:8px}
  .hero .photo{order:-1;max-width:420px;margin:0 auto 6px}
  .hero{text-align:center}
  .hero .eyebrow{margin-inline:auto}
  .hero .strip ul{gap:8px 22px;font-size:12.5px}
}

/* ===== Section base ===== */
section{padding:clamp(60px,9vw,108px) 0}
.sec-label{
  font-family:var(--font-en);font-weight:700;font-size:13px;
  letter-spacing:.18em;color:var(--color-tan);text-transform:uppercase;
  display:block;text-align:center;margin-bottom:14px;
}
.sec-title{
  text-align:center;font-size:clamp(24px,4vw,38px);font-weight:900;
  line-height:1.4;margin-bottom:14px;
}
.sec-lead{text-align:center;color:#5a5a54;font-size:15px;max-width:640px;margin:0 auto 52px}

/* ===== Why cheap (price impact) ===== */
.why{background:var(--color-bg-secondary)}
.compare{
  display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;
  max-width:760px;margin:0 auto 36px;
}
.compare .card{
  background:#fff;border-radius:var(--radius);padding:30px 24px;text-align:center;
  box-shadow:0 8px 24px rgba(26,26,25,.06);
}
.compare .card.old{opacity:.8;border:2px dashed #c9bfae}
.compare .card.new{border:3px solid var(--color-accent);position:relative}
.compare .card h4{font-size:15px;font-weight:700;margin-bottom:10px;color:#73726c}
.compare .card.new h4{color:var(--color-accent)}
.compare .card .yen{font-family:var(--font-en);font-weight:800;font-size:clamp(30px,6vw,46px);line-height:1.1}
.compare .card.old .yen{text-decoration:line-through;text-decoration-color:#bbb;color:#9a988f}
.compare .card .per{font-size:13px;color:#8a887f;margin-top:6px}
.compare .arrow{font-family:var(--font-en);font-size:40px;color:var(--color-accent);font-weight:800}
.compare .card.new .tag{
  position:absolute;top:-15px;left:50%;transform:translateX(-50%);
  background:var(--color-accent);color:#fff;font-size:12px;font-weight:700;
  padding:5px 16px;border-radius:999px;white-space:nowrap;
}
.why-note{text-align:center;font-size:14px;color:#5a5a54;max-width:680px;margin:0 auto;font-weight:700;line-height:1.7}
.why-note .fine{display:inline-block;margin-top:6px;font-size:11.5px;font-weight:400;color:#9a988f}
@media(max-width:680px){
  .compare{grid-template-columns:1fr;gap:8px}
  .compare .arrow{transform:rotate(90deg);margin:2px auto}
}
/* ===== VS比較表（初回限定型 vs 月額制） ===== */
.vstable-wrap{max-width:680px;margin:54px auto 0;overflow-x:auto}
.vstable{
  width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0;background:#fff;
  border-radius:16px;overflow:hidden;box-shadow:0 10px 30px rgba(26,26,25,.08);font-size:14px;
}
.vstable th,.vstable td{padding:16px 12px;text-align:center;border-bottom:1px solid #efeae0;vertical-align:middle}
.vstable thead th{font-size:13.5px;font-weight:800;line-height:1.4}
.vstable thead th:first-child{background:var(--color-bg-secondary)}
.vstable thead .col-bad{background:#ece7dd;color:#8a887f}
.vstable thead .col-good{background:var(--color-accent);color:#fff}
.vstable col.vs-c-key{width:78px}
.vstable col.vs-c-good{width:40%}
.vstable tbody th{background:var(--color-bg-secondary);font-weight:900;font-size:12.5px;color:#5a5a54;line-height:1.4}
.vstable td{line-height:1.55}
.vstable td.vs-bad{color:#9a988f;font-size:13px}
.vstable td.vs-good{color:var(--color-text-main);background:#fff7f5;font-size:13.5px}
.vstable td.vs-good b{color:var(--color-accent);font-weight:800}
.vstable td.vs-bad::before{content:"\00D7";display:block;color:#c2b9a6;font-weight:900;font-size:18px;margin-bottom:4px;line-height:1}
.vstable td.vs-good::before{content:"\25CB";display:block;color:var(--color-accent);font-weight:900;font-size:18px;margin-bottom:4px;line-height:1}
.vstable tr:last-child th,.vstable tr:last-child td{border-bottom:0}
@media(max-width:680px){
  .vstable{font-size:12.5px}
  .vstable th,.vstable td{padding:13px 6px}
  .vstable col.vs-c-key{width:58px}
  .vstable tbody th{font-size:11px}
  .vstable td.vs-bad{font-size:12px}.vstable td.vs-good{font-size:12.5px}
}

/* ===== What is goodeli ===== */
.about{background:var(--color-bg-primary)}
.about-tagline{text-align:center;color:var(--color-tan);font-weight:700;font-size:clamp(15px,2.2vw,19px);letter-spacing:.05em;margin:-2px 0 22px}
.goods{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.good{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 8px 24px rgba(26,26,25,.06);border-top:5px solid var(--color-green);display:flex;flex-direction:column}
.good:nth-child(2){border-top-color:var(--color-accent)}
.good:nth-child(3){border-top-color:var(--color-yellow)}
.good-pic{aspect-ratio:16/10;overflow:hidden;position:relative}
.good-pic img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.good:hover .good-pic img{transform:scale(1.05)}
.good-body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1}
.good-no{font-family:var(--font-en);font-weight:800;font-size:13px;letter-spacing:.1em;color:var(--color-green);text-transform:uppercase}
.good:nth-child(2) .good-no{color:var(--color-accent)}
.good:nth-child(3) .good-no{color:#c08e1f}
.good h3{font-size:22px;font-weight:900;margin:9px 0 8px}
.good h3 .g{color:var(--color-accent)}
.good .good-sub{font-size:14px;font-weight:700;color:var(--color-text-main);margin-bottom:12px}
.good p{font-size:13.5px;color:#5a5a54;line-height:1.85}
.nutri{list-style:none;display:flex;gap:8px;margin-top:auto;padding-top:18px;margin-top:20px;border-top:1px dashed #e3dccd}
.nutri li{flex:1;text-align:center}
.nutri b{display:block;font-family:var(--font-en);font-weight:800;font-size:23px;color:var(--color-text-main);line-height:1.1}
.nutri b small{font-family:var(--font-main);font-size:10px;font-weight:700;color:#8a887f;margin-left:1px}
.nutri span{font-size:11px;color:#8a887f;font-weight:700}
@media(max-width:760px){.goods{grid-template-columns:1fr;gap:18px;margin-top:34px}}

/* ===== Why goodeli (選ばれる理由) ===== */
.reasons{background:var(--color-bg-secondary)}
.check-box{background:#fff;border-radius:20px;padding:30px 30px 32px;max-width:760px;margin:0 auto 46px;box-shadow:0 8px 24px rgba(26,26,25,.06)}
.check-lead{text-align:center;font-weight:900;font-size:clamp(17px,2.6vw,22px);margin-bottom:22px}
.check-lead .mk{background:linear-gradient(transparent 60%, rgba(221,168,59,.4) 60%)}
.checks{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:13px 28px;max-width:660px;margin:0 auto}
.checks li{position:relative;padding-left:30px;font-weight:700;font-size:14.5px;line-height:1.5}
.checks li::before{content:"✓";position:absolute;left:0;top:1px;color:#fff;background:var(--color-green);width:21px;height:21px;border-radius:50%;display:grid;place-content:center;font-size:12px;font-weight:900}
.reason-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.reason{background:#fff;border-radius:18px;padding:26px 22px;box-shadow:0 8px 24px rgba(26,26,25,.06)}
.reason .rno{font-family:var(--font-en);font-weight:800;font-size:32px;line-height:1;display:block;margin-bottom:13px}
.reason:nth-child(1) .rno{color:#e06a55}
.reason:nth-child(2) .rno{color:var(--color-yellow)}
.reason:nth-child(3) .rno{color:#5fa29c}
.reason:nth-child(4) .rno{color:var(--color-green)}
.reason h3{font-size:15.5px;font-weight:900;line-height:1.5;margin-bottom:10px}
.reason p{font-size:13px;color:#5a5a54;line-height:1.8}
@media(max-width:880px){.reason-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.reason-grid{grid-template-columns:1fr}.checks{grid-template-columns:1fr;max-width:340px}}

/* ===== Chef (鳥羽周作 監修) ===== */
.chef{background:var(--color-text-main);color:#fff;overflow:hidden}
.chef-inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:center}
.chef-photo{position:relative}
.chef-photo img{border-radius:20px;width:100%;aspect-ratio:1/1;object-fit:cover;box-shadow:0 20px 50px rgba(0,0,0,.4)}
.chef-photo .sign{
  position:absolute;left:-6px;bottom:-14px;background:var(--color-accent);color:#fff;
  font-weight:700;font-size:13px;padding:9px 18px;border-radius:999px;box-shadow:0 10px 24px rgba(251,80,59,.4);
}
.chef-txt .sec-label{text-align:left;color:var(--color-yellow)}
.chef-badge{
  display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.08);
  border:1.5px solid var(--color-yellow);color:var(--color-yellow);
  font-size:12.5px;font-weight:700;padding:7px 16px;border-radius:999px;margin-bottom:18px;
}
.chef-txt h2{font-size:clamp(26px,4.6vw,44px);font-weight:900;line-height:1.4;margin-bottom:16px}
.chef-name{font-size:14.5px;font-weight:700;color:#fff;margin-bottom:16px}
.chef-name .role{display:block;font-weight:500;font-size:13px;color:#b5b3ac;margin-top:3px}
.chef-txt p.desc{font-size:15px;color:#cfcdc6;line-height:1.9}
@media(max-width:760px){
  .chef-inner{grid-template-columns:1fr;gap:30px;text-align:center}
  .chef-photo{max-width:330px;margin:0 auto}
  .chef-txt .sec-label,.chef-txt .chef-badge{text-align:center}
}

/* ===== Forever (ずっとこの価格) — light contrast cards ===== */
.why-sub{text-align:center;font-size:clamp(19px,2.8vw,26px);font-weight:900;margin:60px 0 26px;line-height:1.5}
.forever-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:760px;margin:0 auto}
.fc{background:#fff;border-radius:16px;padding:28px 26px;box-shadow:0 8px 22px rgba(26,26,25,.06)}
.fc.bad{border-left:5px solid #c9bfae;opacity:.92}
.fc.good{border-left:5px solid var(--color-accent)}
.fc .lbl{font-size:13px;font-weight:700;letter-spacing:.04em;color:#9a988f;margin-bottom:9px}
.fc.good .lbl{color:var(--color-accent)}
.fc strong{font-size:17.5px;font-weight:700;display:block;margin-bottom:7px;line-height:1.5}
.fc span{font-size:13.5px;color:#6b6b66}
@media(max-width:640px){.forever-cards{grid-template-columns:1fr}}

/* ===== Plan table ===== */
.plans{background:var(--color-bg-primary)}
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch;max-width:980px;margin:0 auto}
.plan{
  background:#fff;border-radius:20px;padding:34px 24px 30px;text-align:center;
  box-shadow:0 8px 24px rgba(26,26,25,.06);border:2px solid transparent;
  display:flex;flex-direction:column;position:relative;
}
.plan.reco{border-color:var(--color-accent);box-shadow:0 22px 50px rgba(251,80,59,.20);transform:translateY(-12px);padding-top:60px}
.plan .badge{
  position:absolute;top:-30px;left:50%;transform:translateX(-50%);width:84px;height:84px;
  filter:drop-shadow(0 6px 14px rgba(251,80,59,.3));
}
.plan-ico{width:62px;height:62px;border-radius:50%;display:grid;place-content:center;margin:0 auto 14px}
.plan-ico svg{width:34px;height:34px}
.plan:nth-child(1) .plan-ico{background:rgba(133,163,126,.15);color:var(--color-green)}
.plan:nth-child(2) .plan-ico{background:rgba(251,80,59,.12);color:var(--color-accent)}
.plan:nth-child(3) .plan-ico{background:rgba(221,168,59,.18);color:#c08e1f}
.plan .cname{font-size:18px;font-weight:900;margin-bottom:4px}
.plan .cmeals{font-family:var(--font-en);font-weight:700;color:var(--color-tan);font-size:14px;margin-bottom:18px}
.plan .ppm{font-size:13px;color:#8a887f;margin-bottom:2px}
.plan .pmain{font-family:var(--font-en);font-weight:800;font-size:46px;line-height:1;color:var(--color-text-main)}
.plan.reco .pmain{color:var(--color-accent)}
.plan .pmain small{font-size:18px;margin-left:2px}
.plan .ptotal{font-size:13px;color:#7a786f;margin:12px 0 18px;padding-top:14px;border-top:1px dashed #e3dccd}
.plan .ptotal b{color:var(--color-text-main);font-family:var(--font-en)}
.plan .forwhom{
  background:var(--color-bg-primary);border-radius:12px;padding:14px;font-size:13.5px;
  font-weight:700;line-height:1.6;margin-bottom:22px;flex-grow:1;display:flex;align-items:center;justify-content:center;
}
.plan.reco .forwhom{background:#fff4f2}
.plan .pbtn{
  display:block;background:var(--color-bg-secondary);color:var(--color-text-main);
  font-weight:700;padding:14px;border-radius:999px;font-size:15px;transition:.2s;
}
.plan.reco .pbtn{background:var(--color-accent);color:#fff;box-shadow:0 10px 24px rgba(251,80,59,.32)}
.plan .pbtn:hover{transform:translateY(-2px)}
.plan .psave{display:inline-block;background:#fff4f2;color:var(--color-accent);font-size:12.5px;font-weight:700;padding:6px 14px;border-radius:999px;margin:-2px 0 14px}
.plan.reco .psave{background:#fff}
.plan .psave b{font-family:var(--font-en)}
/* detailed price table */
.ptable-wrap{max-width:720px;margin:56px auto 0;overflow-x:auto}
.ptable-cap{text-align:center;font-weight:900;font-size:clamp(18px,2.6vw,22px);margin-bottom:18px}
.ptable{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 8px 24px rgba(26,26,25,.06);font-size:14px}
.ptable th,.ptable td{padding:13px 8px;text-align:center;border-bottom:1px solid #efeae0}
.ptable thead th{background:var(--color-text-main);color:#fff;font-size:12px;font-weight:700}
.ptable tbody th{background:var(--color-bg-secondary);font-weight:900}
.ptable .web{color:#9a988f;text-decoration:line-through}
.ptable .sp{color:var(--color-accent);font-weight:800;font-family:var(--font-en);font-size:16px}
.ptable tr:last-child td,.ptable tr:last-child th{border-bottom:0}
.ptable .save-row td{background:#fff7ec;color:#bd8a1d;font-weight:800;font-size:12.5px;line-height:1.6}
/* selects */
.selects{margin-top:58px}
.selects-cap{text-align:center;font-weight:900;font-size:clamp(18px,2.6vw,23px);margin-bottom:6px}
.selects-sub{text-align:center;color:#7a786f;font-size:14px;margin-bottom:30px}
.select-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:880px;margin:0 auto}
.select{background:#fff;border-radius:18px;padding:26px 22px;text-align:center;box-shadow:0 8px 24px rgba(26,26,25,.06);border:2px solid transparent}
.select.mid{border-color:var(--color-accent);box-shadow:0 14px 34px rgba(251,80,59,.16)}
.select .sname{font-size:18px;font-weight:900;margin-bottom:4px}
.select.mid .sname{color:var(--color-accent)}
.select .sdesc{font-size:13px;color:#6b6b66;min-height:38px;margin-bottom:14px}
.select .sprices{font-size:13px;color:#5a5a54;line-height:1.95;border-top:1px dashed #e3dccd;padding-top:13px}
.select .sprices b{font-family:var(--font-en);color:var(--color-text-main)}
.select .swho{font-size:12.5px;font-weight:700;color:var(--color-green);margin-top:13px}
.select.mid .swho{color:var(--color-accent)}
@media(max-width:760px){.select-grid{grid-template-columns:1fr;max-width:380px}.ptable{font-size:13px}}
.plan-note{text-align:center;font-size:12.5px;color:#8a887f;margin-top:30px;line-height:1.7}
@media(max-width:760px){
  .plan-grid{grid-template-columns:1fr;gap:34px;max-width:380px}
  .plan.reco{transform:none}
}

/* ===== Menu grid ===== */
.menu{background:var(--color-bg-secondary)}
.dish-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:1000px;margin:0 auto}
.dish{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 6px 18px rgba(26,26,25,.06)}
.dish img{aspect-ratio:1/1;object-fit:cover;width:100%}
.dish .cap{padding:13px 14px}
.dish .cap .jc{font-size:14px;font-weight:700;line-height:1.4}
.dish .cap .ec{font-family:var(--font-en);font-size:11px;color:#a8a59c;margin-top:3px}
.dish .cap .gen{display:inline-block;font-size:11px;font-weight:700;color:var(--color-tan);background:rgba(202,149,109,.13);padding:3px 11px;border-radius:999px;margin-top:8px}
@media(max-width:860px){.dish-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== Rich menu (HIBISTRO) ===== */
.rich{background:var(--color-bg-primary)}
.rich-inner{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:46px;align-items:center;
  max-width:980px;margin:0 auto;
}
.rich .txt .tag{
  display:inline-block;background:var(--color-text-main);color:#fff;font-family:var(--font-en);
  font-weight:700;font-size:12px;letter-spacing:.1em;padding:6px 16px;border-radius:999px;margin-bottom:18px;
}
.rich .txt h3{font-size:clamp(22px,3.4vw,30px);font-weight:900;line-height:1.45;margin-bottom:16px}
.rich .txt p{font-size:15px;color:#5a5a54}
.rich .img img{border-radius:18px;box-shadow:var(--shadow)}
@media(max-width:760px){.rich-inner{grid-template-columns:1fr;gap:26px}.rich .img{order:-1}}

/* ===== Quality ===== */
.quality{background:var(--color-text-main);color:#fff;position:relative;overflow:hidden;padding:0}
.quality .photo-band{position:relative}
.quality .photo-band img{width:100%;height:clamp(300px,42vw,460px);object-fit:cover;opacity:.92}
.quality .photo-band::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,26,25,.1),rgba(26,26,25,.75))}
.quality .q-body{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.quality .q-content{position:relative;margin-top:-120px;z-index:2;padding-bottom:clamp(60px,9vw,100px)}
.quality .sec-label{color:var(--color-yellow);text-align:left}
.quality h2{font-size:clamp(24px,4vw,38px);font-weight:900;line-height:1.45;margin-bottom:34px;max-width:730px}
.q-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.q-feat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:26px 22px}
.q-feat .n{font-family:var(--font-en);font-weight:800;color:var(--color-yellow);font-size:14px;margin-bottom:10px;letter-spacing:.1em}
.q-feat h4{font-size:17px;font-weight:700;margin-bottom:8px}
.q-feat p{font-size:13.5px;color:#c9c7c0}
@media(max-width:760px){.q-feats{grid-template-columns:1fr}.quality .q-content{margin-top:-80px}}

/* ===== Steps ===== */
.steps{background:var(--color-bg-secondary)}
.step-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:920px;margin:0 auto}
.step{text-align:center;position:relative}
.step .pic{border-radius:16px;overflow:hidden;box-shadow:0 8px 22px rgba(26,26,25,.08);margin-bottom:18px;aspect-ratio:4/3}
.step .pic img{width:100%;height:100%;object-fit:cover}
.step .no{
  font-family:var(--font-en);font-weight:800;font-size:13px;color:#fff;background:var(--color-green);
  width:34px;height:34px;border-radius:50%;display:grid;place-content:center;margin:0 auto 12px;
}
.step h4{font-size:17px;font-weight:700;margin-bottom:6px}
.step p{font-size:13.5px;color:#6b6b66}
@media(max-width:760px){.step-grid{grid-template-columns:1fr;max-width:340px}}

/* ===== FAQ ===== */
.faq{background:var(--color-bg-primary)}
.faq-list{max-width:760px;margin:0 auto}
.faq details{background:#fff;border-radius:14px;margin-bottom:14px;box-shadow:0 4px 14px rgba(26,26,25,.05);overflow:hidden}
.faq summary{
  list-style:none;cursor:pointer;padding:22px 56px 22px 24px;font-weight:700;font-size:15.5px;
  position:relative;display:flex;gap:12px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"Q";font-family:var(--font-en);color:var(--color-accent);font-weight:800}
.faq summary::after{
  content:"+";position:absolute;right:24px;top:50%;transform:translateY(-50%);
  font-family:var(--font-en);font-size:24px;color:var(--color-green);transition:.2s;
}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq .a{padding:0 24px 24px 50px;font-size:14px;color:#5a5a54}

/* ===== Final CTA ===== */
.final{
  background:linear-gradient(135deg,#fb503b 0%, #e0432f 100%);
  color:#fff;text-align:center;position:relative;overflow:hidden;
}
.final h2{font-size:clamp(26px,4.6vw,44px);font-weight:900;line-height:1.4;margin-bottom:14px}
.final p{font-size:16px;opacity:.94;margin-bottom:14px}
.final .price-line{font-family:var(--font-en);font-weight:800;font-size:clamp(22px,4vw,34px);margin-bottom:34px}
.final .btn-primary{background:#fff;color:var(--color-accent);box-shadow:0 16px 40px rgba(0,0,0,.22)}
.final .btn-primary:hover{box-shadow:0 22px 50px rgba(0,0,0,.3)}
.final .fnote{font-size:12.5px;opacity:.82;margin-top:18px}

/* ===== Entry form（フォーム一体型） ===== */
.entry{background:var(--color-bg-secondary);scroll-margin-top:70px}
.entry .form-card{
  max-width:880px;margin:0 auto;background:#fff;border-radius:24px;
  box-shadow:var(--shadow);overflow:hidden;border:1px solid rgba(26,26,25,.06);
}
.entry .form-head{background:var(--color-accent);color:#fff;text-align:center;padding:26px 24px}
.entry .form-head h3{font-size:clamp(20px,3vw,26px);font-weight:900}
.entry .form-head p{font-size:13.5px;opacity:.92;margin-top:6px}
.entry .form-frame{width:100%;background:#fff}
.entry .form-frame iframe{width:100%;height:1180px;border:0;display:block}
.entry .form-fallback{text-align:center;padding:24px;background:var(--color-bg-primary);border-top:1px solid rgba(26,26,25,.06)}
.entry .form-fallback p{font-size:13px;color:#6b6b66;margin-bottom:12px}
.entry .form-fallback a{
  display:inline-flex;align-items:center;gap:8px;background:var(--color-accent);color:#fff;
  font-weight:700;padding:14px 32px;border-radius:999px;font-size:15px;box-shadow:0 10px 24px rgba(251,80,59,.3);
  transition:transform .2s;
}
.entry .form-fallback a:hover{transform:translateY(-2px)}
@media(max-width:680px){.entry .form-frame iframe{height:1480px}}

/* ===== Footer ===== */
footer.site{background:var(--color-text-main);color:#cfcdc6;padding:50px 0 120px;text-align:center}
footer.site img{height:30px;margin:0 auto 18px}
footer.site .fnav{display:flex;justify-content:center;flex-wrap:wrap;gap:10px 26px;font-size:13px;margin-bottom:22px}
footer.site .fnav a{color:#cfcdc6;opacity:.85}
footer.site small{font-family:var(--font-en);font-size:11px;color:#7c7a73}

/* ===== Sticky mobile CTA ===== */
.mobile-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:60;
  background:rgba(245,242,233,.95);backdrop-filter:blur(8px);
  padding:10px 16px;display:none;box-shadow:0 -6px 20px rgba(26,26,25,.12);
}
.mobile-cta a{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--color-accent);color:#fff;font-weight:700;font-size:16px;
  padding:15px;border-radius:999px;box-shadow:0 8px 20px rgba(251,80,59,.4);
}
.mobile-cta a small{font-size:11px;opacity:.85;font-weight:500}
@media(max-width:680px){.mobile-cta{display:block}}

.cta-center{text-align:center;margin-top:48px}

/* ===== Plan selector（動的導線） ===== */
.selector{max-width:920px;margin:0 auto}
.sel-step{margin-bottom:34px}
.sel-step-head{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:18px}
.step-badge{font-weight:800;font-size:12px;letter-spacing:.1em;background:var(--color-text-main);color:#fff;padding:6px 14px;border-radius:999px}
.sel-step-head h3{font-size:clamp(19px,3vw,24px);font-weight:900}
.meal-grid,.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;border-radius:18px}
.meal-card{
  cursor:pointer;background:#fff;border:2.5px solid #e7ddcd;border-radius:18px;
  font-family:inherit;text-align:center;position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:22px 14px 18px;gap:7px;
  transition:transform .15s, border-color .15s, box-shadow .15s;
}
.course-card{
  cursor:pointer;background:#fff;border:2.5px solid #e7ddcd;border-radius:18px;overflow:hidden;padding:0;
  font-family:inherit;text-align:center;position:relative;display:flex;flex-direction:column;
  box-shadow:0 8px 24px rgba(26,26,25,.07);
  transition:transform .15s, border-color .15s, box-shadow .15s;
}
.meal-card:hover,.course-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(26,26,25,.12)}
.meal-card.is-active{border-color:var(--color-accent);background:#fffaf8;box-shadow:0 14px 30px rgba(251,80,59,.18)}
.course-card.is-active{border-color:var(--color-accent);box-shadow:0 14px 32px rgba(251,80,59,.22)}
.meal-card.is-active::after,.course-card.is-active::after{content:"✓";position:absolute;top:10px;right:10px;width:26px;height:26px;border-radius:50%;background:var(--color-accent);color:#fff;font-weight:900;font-size:14px;display:grid;place-content:center;z-index:3;box-shadow:0 2px 8px rgba(0,0,0,.22)}
.meal-num{font-weight:800;font-size:clamp(40px,9vw,58px);line-height:1;color:var(--color-text-main)}
.meal-num small{font-family:var(--font-main);font-size:.32em;font-weight:900;margin-left:2px}
.meal-num small.pm{font-size:.24em;font-weight:800;color:#8a887f;margin-left:1px}
.meal-per{font-size:13px;font-weight:700;color:#7a786f}
.meal-per b{font-family:var(--font-en);font-size:19px;color:var(--color-accent)}
.meal-tag{font-size:11px;font-weight:700;color:#fff;background:var(--color-green);padding:3px 12px;border-radius:999px}
.meal-card.reco .meal-tag{background:var(--color-accent)}
.course-pic{position:relative;aspect-ratio:4/3;overflow:hidden;display:block}
.course-pic img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.course-card:hover .course-pic img{transform:scale(1.04)}
.course-chip{position:absolute;left:11px;top:11px;font-family:var(--font-en);font-weight:800;font-size:10.5px;letter-spacing:.14em;color:#fff;padding:5px 12px;border-radius:999px;z-index:2}
.course-card[data-course="otoku"] .course-chip{background:linear-gradient(135deg,#c08a52,#8a5526)}
.course-card[data-course="ninki"] .course-chip{background:linear-gradient(135deg,#aab0b7,#787f88)}
.course-card[data-course="chef"] .course-chip{background:linear-gradient(135deg,#dcba4e,#a17b14)}
.course-body{padding:15px 16px 18px}
.course-name{display:block;font-size:17px;font-weight:900;margin-bottom:2px}
.course-desc{display:block;font-size:12.5px;color:#7a786f;font-weight:700}
.selector.flash .meal-grid,.selector.flash .course-grid{animation:selflash 1.1s ease 1}
@keyframes selflash{0%{box-shadow:0 0 0 0 rgba(251,80,59,.5)}100%{box-shadow:0 0 0 16px rgba(251,80,59,0)}}
/* lineup */
.lineup{max-width:1000px;margin:44px auto 0}
.lineup-cap{text-align:center;font-weight:900;font-size:clamp(18px,2.6vw,23px);margin-bottom:18px}
.lineup-summary{text-align:center;margin:0 auto 26px;max-width:560px;background:#fff;border:2px solid var(--color-accent);border-radius:16px;padding:18px 20px;box-shadow:0 10px 26px rgba(251,80,59,.12)}
.lineup-summary .ls-line{font-size:16px;font-weight:900}
.lineup-summary .ls-line b{color:var(--color-accent)}
.lineup-summary .ls-price{font-family:var(--font-en);font-weight:800;font-size:clamp(28px,6vw,38px);color:var(--color-accent);line-height:1.2;margin-top:6px}
.lineup-summary .ls-price small{font-family:var(--font-main);font-size:14px;color:#7a786f;font-weight:700}
.lineup-summary .ls-per{font-size:13px;color:#7a786f;font-weight:700}
.lineup-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.lineup-item{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 6px 18px rgba(26,26,25,.06)}
.lineup-item img{aspect-ratio:1/1;object-fit:cover;width:100%}
.lineup-item .li-name{padding:10px 12px;font-size:12.5px;font-weight:700;line-height:1.45}
.lineup-note{text-align:center;font-size:12px;color:#8a887f;margin-top:12px}
.lineup-empty{text-align:center;color:#9a988f;font-size:14px;font-weight:700;line-height:1.7;background:#fff;border:2px dashed #d8cdb8;border-radius:16px;padding:30px 20px;max-width:560px;margin:40px auto 0}
@media(max-width:860px){.lineup-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){
  .meal-grid,.course-grid{
    display:flex;flex-wrap:nowrap;gap:12px;
    overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;
    scroll-snap-type:x proximity;
    margin:0 -24px;padding:6px 24px 14px;
    scrollbar-width:none;
  }
  .meal-grid::-webkit-scrollbar,.course-grid::-webkit-scrollbar{display:none}
  .meal-card{flex:0 0 46%;scroll-snap-align:start}
  .course-card{flex:0 0 76%;scroll-snap-align:start}
  .course-pic{aspect-ratio:16/10}
}
/* rich note（独立・コンパクト） */
.rich-note{display:grid;grid-template-columns:160px 1fr;gap:22px;align-items:center;max-width:720px;margin:50px auto 0;background:#fff;border-radius:18px;padding:20px;box-shadow:0 8px 24px rgba(26,26,25,.06)}
.rich-note-img img{border-radius:12px;aspect-ratio:1/1;object-fit:cover}
.rich-note-txt .tag{display:inline-block;background:var(--color-text-main);color:#fff;font-weight:700;font-size:11px;letter-spacing:.1em;padding:5px 13px;border-radius:999px;margin-bottom:10px}
.rich-note-txt h4{font-size:18px;font-weight:900;line-height:1.5;margin-bottom:8px}
.rich-note-txt p{font-size:13.5px;color:#5a5a54;line-height:1.8}
.rich-note-txt b{color:var(--color-accent);font-family:var(--font-en)}
@media(max-width:560px){.rich-note{grid-template-columns:1fr;text-align:center}.rich-note-img{max-width:200px;margin:0 auto}}
/* mock order form */
.order-form{padding:30px clamp(20px,4vw,44px) 36px}
.order-form .of-row{margin-bottom:18px}
.order-form label{display:block;font-size:13.5px;font-weight:700;margin-bottom:7px}
.order-form label .req{color:#fff;background:var(--color-accent);font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;margin-left:7px;vertical-align:middle}
.order-form input,.order-form select{
  width:100%;font-family:inherit;font-size:15px;padding:13px 15px;border:1.5px solid #ddd3c2;border-radius:10px;background:#fdfcf8;color:var(--color-text-main);
}
.order-form input:focus,.order-form select:focus{outline:none;border-color:var(--color-accent)}
.order-form .of-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.order-form .of-plan{background:var(--color-bg-primary);border:2px solid var(--color-accent);border-radius:14px;padding:18px 20px;margin:8px 0 24px}
.order-form .of-plan .ofp-cap{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.04em;color:var(--color-accent);margin-bottom:9px}
.order-form .of-plan .ofp-cap .ofp-edit{margin-left:auto;font-size:12px;font-weight:700;color:var(--color-accent);text-decoration:underline}
.order-form .of-plan .ofp-body{font-size:16px;font-weight:900;line-height:1.7}
.order-form .of-plan .ofp-body .nosel{color:#b6ada0;font-weight:700;font-size:13.5px}
.order-form .of-submit{width:100%;border:0;cursor:pointer;background:var(--color-accent);color:#fff;font-weight:800;font-size:18px;padding:18px;border-radius:999px;box-shadow:0 14px 32px rgba(251,80,59,.34);transition:transform .2s}
.order-form .of-submit:hover{transform:translateY(-2px)}
.order-form .of-mocknote{text-align:center;font-size:11.5px;color:#a8a59c;margin-top:14px}
@media(max-width:560px){.order-form .of-2{grid-template-columns:1fr}}
