:root{
  --brand:#ff7a00; --ink:#222; --muted:#666; --bg:#f7f7fb; --card:#fff; --line:#ececf2;
  --shadow:0 10px 30px rgba(24,24,36,.08); --dark:#1a1a1a;
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Noto Sans JP",sans-serif;color:var(--ink);background:var(--bg);line-height:1.75;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.section{padding:80px 0;position:relative}
.section.alt{background:#fff}
.sec-title{font-size:28px;margin:0 0 28px;text-align:center}

/* Header */
.site-header{position:sticky;top:0;z-index:1000;background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.06);backdrop-filter:saturate(140%) blur(6px)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{font-weight:800;font-size:18px;color:var(--ink);text-decoration:none;letter-spacing:.02em}
.nav a{color:var(--ink);text-decoration:none;margin-left:18px;font-size:14px}
.nav .nav-btn{margin-left:24px}
.hamburger{display:none;background:none;border:0;padding:8px}
.hamburger span{display:block;width:22px;height:2px;background:#333;margin:5px 0;border-radius:2px}

/* Hero main */
.hero{position:relative;padding:56px 0 32px;color:var(--ink);background:
  radial-gradient(1200px 600px at 80% -10%, rgba(255,122,0,.12), transparent 60%),
  radial-gradient(900px 500px at -10% 10%, rgba(135,120,255,.10), transparent 55%),
  linear-gradient(180deg,#fff 0%,#fff 60%,#f5f6fb 100%);overflow:hidden}
.hero::before{content:"";position:absolute;inset:-40px -40px auto auto;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle at 20% 20%, rgba(255,122,0,.14) 0 30%, transparent 31% 100%),
             radial-gradient(circle at 70% 60%, rgba(135,120,255,.12) 0 28%, transparent 29% 100%);filter:blur(10px);pointer-events:none}
.hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg, rgba(255,255,255,.85) 0%, rgba(255,255,255,.92) 40%, rgba(247,247,251,.98) 100%),
  url('/assets/img/bg/hero.jpg') center/cover no-repeat;opacity:.65;pointer-events:none}
.hero-grid{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;z-index:1}
.eyebrow{color:var(--brand);font-weight:800;margin:0 0 6px;letter-spacing:.08em;text-transform:uppercase;font-size:12px}
.hero h1{font-size:38px;line-height:1.22;margin:0 0 12px;letter-spacing:.02em}
.lead{color:#4a4a55;margin:0 0 18px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0 12px}
.trust-list{display:flex;gap:12px;flex-wrap:wrap;padding:0;margin:12px 0;list-style:none}
.trust-list li{background:#fff;border:1px solid var(--line);border-radius:24px;padding:6px 12px;font-size:12px}
.price-pill{display:inline-block;margin-top:8px;background:#fff3e8;color:#7a3a00;border:1px solid #ffd9b5;border-radius:999px;padding:6px 12px;font-weight:800;font-size:14px}
.hero-visual img{border-radius:20px;box-shadow:var(--shadow)}

/* Section BG */
#features.section{background:linear-gradient(180deg,#f9fafc 0%,#fff 100%),repeating-linear-gradient(45deg,rgba(34,34,68,.02) 0 16px,rgba(34,34,68,.04) 16px 17px)}
.section.alt{background:linear-gradient(180deg,#fff 0%,#fbfbfe 100%),radial-gradient(800px 400px at 10% -20%,rgba(135,120,255,.06),透明 60%)}
.section.testimonials{background:linear-gradient(180deg,#fff7f1 0%,#fff 60%,#fff 100%)}

/* Cards */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.feature .icon{width:40px;height:40px;margin-bottom:8px}
.feature .icon svg{width:100%;height:100%;fill:var(--brand)}
.levels{text-align:center;margin-top:16px;color:#555}.level{font-weight:800}.dot{margin:0 8px;color:#ccc}

/* Flow */
.flow{counter-reset:step;display:grid;gap:10px;max-width:760px;margin:0 auto 18px;padding-left:0}
.flow li{list-style:none;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;position:relative}
.flow li::before{counter-increment:step;content:counter(step);position:absolute;left:-10px;top:-10px;width:28px;height:28px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px}

/* === Price: value-packed === */
.price-card--value{ position:relative; padding-top:32px; }
.ribbon{
  position:absolute; top:-10px; left:-10px;
  background:linear-gradient(90deg,#ff8a1a,#ff6a00);
  color:#fff; font-weight:900; font-size:12px; letter-spacing:.08em;
  padding:6px 10px; border-radius:10px; box-shadow: var(--shadow);
}
.price-row{ display:flex; gap:10px; align-items:baseline; justify-content:center; margin:2px 0 6px; }
.price-label{ font-weight:800; color:#666; }
.price-sub{ text-align:center; color:#777; margin:0 0 6px; }
.price-savings{ text-align:center; margin:0 0 10px; color:#6b4b2e; background:#fff7ed; border:1px solid #ffd9b5; border-radius:999px; padding:6px 10px; display:inline-block; margin-left:50%; transform:translateX(-50%); }
.price-savings strong{ font-weight:900; }

/* バッジ（“込み”の一目アピール） */
.badge-line{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:10px 0 6px; }
.chip{
  font-size:12px; font-weight:800; color:#7a3a00;
  background:#fff3e8; border:1px solid #ffd9b5; border-radius:999px; padding:4px 10px;
}

/* 含まれる内容グリッド */
.included-grid{
  list-style:none; padding:0; margin:10px 0 8px;
  display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:10px;
}
.included-grid li{
  display:grid; grid-template-columns:22px 1fr; gap:8px;
  background:#fff; border:1px solid var(--line); border-radius:12px; padding:10px 12px;
}
.included-grid .check{
  width:18px; height:18px; border-radius:50%;
  background:var(--brand); display:inline-grid; place-items:center; margin-top:2px;
  box-shadow:0 6px 14px rgba(0,0,0,.08);
  position:relative;
}
.included-grid .check::before{
  content:""; position:absolute; width:9px; height:5px; border-left:2px solid #fff; border-bottom:2px solid #fff; transform:translate(4px,4px) rotate(-45deg);
}
.ig-body strong{ line-height:1.4; display:block; }
.ig-body small{ color:#666; }

/* 注記 */
.price-footnote{ color:#888; text-align:center; font-size:12px; margin:6px 0 0; }

/* レスポンシブ */
@media (max-width: 720px){
  .included-grid{ grid-template-columns:1fr; }
  .price-savings{ white-space:nowrap; }
}
/* === Price (ALL-IN 強調) === */
.price-card--allin{
  position:relative; overflow:hidden; padding-top:42px;
}

/* 左上リボン（全部コミコミ） */
.ribbon--allin{
  position:absolute; top:-10px; left:-10px;
  background:linear-gradient(90deg,#ff8a1a,#ff6a00);
  color:#fff; font-weight:900; font-size:12px; letter-spacing:.08em;
  padding:8px 12px; border-radius:12px; box-shadow:var(--shadow);
  display:flex; gap:10px; align-items:center;
}
.ribbon--allin .ribbon-sub{ font-weight:800; opacity:.9; }

/* 右上スタンプ “NO EXTRA” */
.allin-stamp{
  position:absolute; right:16px; top:14px;
  width:84px; height:84px; border-radius:50%;
  border:3px solid var(--brand); color:var(--brand);
  font-weight:900; line-height:1.05; text-align:center;
  display:grid; place-items:center;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.08));
  transform:rotate(-12deg);
  background:transparent; opacity:.22; pointer-events:none;
}

/* 金額を特大化＆中央寄せ */
.price-card--allin .price-row{
  justify-content:center; gap:12px; margin:10px 0 6px;
}
.price-card--allin .price-label{ font-size:16px; color:#888; font-weight:800; }
.price-card--allin .price-main{
  font-size:56px; font-weight:900; letter-spacing:.01em; color:var(--ink);
}

/* 追加費用ゼロの強調チップ */
.noextra-line{
  display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin:8px 0 10px;
}
.noextra{
  font-size:12px; font-weight:800; color:#7a3a00;
  background:#fff3e8; border:1px solid #ffd9b5; border-radius:999px; padding:4px 10px;
}

/* 既存の“お得”補助文 */
.price-sub{ text-align:center; color:#777; margin:0 0 6px; }
.price-savings{
  text-align:center; margin:0 0 10px; color:#6b4b2e;
  background:#fff7ed; border:1px solid #ffd9b5; border-radius:999px;
  padding:6px 10px; display:inline-block; margin-left:50%; transform:translateX(-50%);
}

/* バッジ（込み項目） */
.badge-line{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:10px 0 6px; }
.chip{
  font-size:12px; font-weight:800; color:#7a3a00;
  background:#fff3e8; border:1px solid #ffd9b5; border-radius:999px; padding:4px 10px;
}

/* レスポンシブ調整 */
@media (max-width:720px){
  .price-card--allin .price-main{ font-size:42px; }
  .allin-stamp{ width:72px; height:72px; right:10px; top:10px; }
}



/* Testimonials bubble */
.voice{position:relative;padding:22px 18px 18px 66px;background:#fff;border:1px solid #ffe1cb;box-shadow:var(--shadow);border-radius:16px}
.voice-icon{position:absolute;left:16px;top:18px;width:42px;height:42px}
.voice-icon .bubble path{fill:#ffefe2;stroke:#ffcfa9;stroke-width:0}
.voice-icon .bubble circle{fill:#ff9a3a}
.voice cite{display:block;margin-top:10px;color:#888;font-size:12px}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin:10px 0}
.faq summary{cursor:pointer;font-weight:800}

/* CTA band */
.cta-band{position:relative;color:#fff;padding:46px 0;background:linear-gradient(180deg,rgba(26,26,26,.90) 0%,rgba(26,26,26,.92) 100%),url('/assets/img/bg/cta.jpg') center/cover no-repeat}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.cta-band h2{margin:0;font-size:22px;letter-spacing:.02em}

/* Waves */
.wave{line-height:0}
.wave svg{display:block;width:100%;height:60px}
.wave svg path{fill:currentColor}
.wave--to-white{color:#fff}
.wave--to-alt{color:#fff}
.wave--to-bg{color:var(--bg)}
.wave--to-dark{color:var(--dark)}
.wave-bottom{transform:translateY(-1px)}

/* Buttons */
.btn{display:inline-block;padding:10px 16px;border-radius:12px;border:1px solid var(--brand);text-decoration:none;font-weight:800;font-size:14px;letter-spacing:.02em}
.btn.solid{background:var(--brand);color:#fff}
.btn.outline{background:#fff;color:var(--brand)}
.btn.ghost{background:transparent;color:var(--brand);border-color:#ffd1ad}
.btn.lg{padding:12px 20px;font-size:16px}

/* Footer */
.site-footer{background:#fff;border-top:1px solid var(--line)}
.footer-inner{display:flex;justify-content:space-between;align-items:center;padding:16px 0}
.footer-nav a{margin-left:16px;color:#555;text-decoration:none}

/* Sub hero (readability boost) */
.hero--sub{position:relative;padding:64px 0 36px;overflow:hidden;color:#1f2937;background:
  radial-gradient(1000px 520px at 90% -10%, rgba(255,122,0,.10), transparent 60%),
  linear-gradient(180deg,#fff 0%,#fff 55%,#f6f7fb 100%)}
.hero--sub::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.96) 38%,rgba(255,255,255,.92) 55%,rgba(255,255,255,.60) 72%,rgba(255,255,255,0) 100%);z-index:0;pointer-events:none}
.hero--sub::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;background:url('/assets/img/bg/hero.jpg') center/cover no-repeat;opacity:.28}
.hero-sub-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:16px}
.hero--sub h1{margin:6px 0 10px;font-size:40px;line-height:1.2;font-weight:900;letter-spacing:.005em}
.hero--sub .lead{color:#475569;font-size:18px;max-width:820px}
.hero--sub .eyebrow{color:var(--brand);font-weight:800;opacity:.95}
.hero--sub .price-pill{background:#fff7ed;border-color:#fdba74;color:#92400e;box-shadow:0 6px 18px rgba(0,0,0,.06);font-weight:800}

/* Forms & layout (apply/contact) */
.apply-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:20px}
.form-card{padding:22px}
.form-title{margin:6px 0 10px;font-size:18px}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.form-group{display:block}
.form-group.--col2{grid-column:span 2}
.form-card input,.form-card select,.form-card textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:16px;background:#fff}
.form-card textarea{resize:vertical}
.req{background:#fff3e8;color:#7a3a00;border:1px solid #ffd9b5;font-size:11px;padding:2px 6px;border-radius:999px;margin-left:6px}
.hint{color:#888;font-size:12px}
.consent{margin:6px 0}
.consent--grid{display:grid;grid-template-columns:20px 1fr;align-items:start;gap:10px}
.consent--grid input[type="checkbox"]{margin:3px 0 0}
.consent--grid .consent-text{line-height:1.6}
.submit-row{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}
.sidebar{display:grid;gap:16px}
.side-card{padding:16px 16px 14px}
.side-card h3{margin:0 0 8px;font-size:16px}
.side-price{font-size:22px;font-weight:900;color:var(--brand);margin:6px 0 6px}
.side-list{list-style:none;padding:0;margin:8px 0 4px;display:grid;gap:6px}
.side-list li{position:relative;padding-left:18px}
.side-list li::before{content:"";position:absolute;left:0;top:.6em;width:8px;height:8px;border-radius:50%;background:var(--brand)}
.side-steps{margin:8px 0 0 18px}
.small{color:#777;font-size:12.5px}
.form-alert{border:1px solid #ffd0bf;background:#fff3ef;color:#7a3320;border-radius:12px;padding:10px 12px;margin-bottom:10px}
.form-alert ul{margin:6px 0 0 18px}

/* Thanks */
.hero--thanks{padding:64px 0 36px}
.hero--thanks::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:linear-gradient(90deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.9) 45%,rgba(255,255,255,.3) 75%,rgba(255,255,255,0) 100%)}
.thanks-head{position:relative;z-index:1}
.success-badge{width:56px;height:56px;border-radius:999px;background:#22c55e;display:grid;place-items:center;box-shadow:0 10px 24px rgba(34,197,94,.35);margin-bottom:10px}
.success-badge svg{width:28px;height:28px}
.success-badge svg path{fill:#fff}
.thanks-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:20px}
.thanks-main{padding:22px}
.thanks-main h2{margin:6px 0 10px;font-size:18px}
.side-list code{background:#f4f4f8;border:1px solid #ececf2;border-radius:6px;padding:2px 6px}

/* Responsive */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .cta-band-inner{flex-direction:column;text-align:center}
  .sp-hide{display:none}
  .hamburger{display:block}.nav{display:none}
  body.nav-open .nav{display:block;position:absolute;top:60px;right:0;background:#fff;box-shadow:var(--shadow);padding:12px;border-radius:12px}
  body.nav-open .nav a{display:block;padding:8px 10px;margin:6px 0}
  .hero--sub{padding:40px 0 26px}
  .hero--sub::before{background:linear-gradient(180deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.96) 60%,rgba(255,255,255,0) 100%)}
  .hero--sub h1{font-size:28px}.hero--sub .lead{font-size:15px}
  .apply-grid,.thanks-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .form-group.--col2{grid-column:span 1}
}

/* ===「理由」カードの縦3つステップ（写真枠つき）=== */
.feature-steps{
  margin:12px 0 0; padding:0;
  display:grid; gap:10px; counter-reset: feat;
}
.feature-steps li{
  list-style:none;
  display:grid; grid-template-columns:72px 1fr; gap:12px; align-items:center;
  border:1px dashed var(--line); border-radius:12px; padding:10px 12px; background:#fff;
  position:relative;
}
.feature-steps li::before{
  counter-increment: feat; content: counter(feat);
  position:absolute; left:-10px; top:-10px; width:24px; height:24px;
  display:grid; place-items:center; border-radius:50%;
  background: var(--brand); color:#fff; font-weight:800; font-size:12px;
  box-shadow: 0 6px 16px rgba(0,0,0,.08);
}

/* サムネ“枠だけ” */
.step-thumb{
  width:64px; height:64px; border-radius:12px;
  background: linear-gradient(180deg,#fff 0%,#fafafa 100%);
  border:2px solid #ffd9b5; box-shadow: var(--shadow);
  position:relative; overflow:hidden;
}
.step-thumb::after{
  content:""; position:absolute; inset:6px; border:1px dashed #ffbe8a; border-radius:10px;
}
img.step-thumb{
  object-fit:cover; width:64px; height:64px; border-radius:12px;
  border:2px solid #ffd9b5; box-shadow: var(--shadow);
}
.step-body strong{ display:block; line-height:1.3 }
.step-desc{ display:block; color:#666; font-size:13px; margin-top:2px }
@media (max-width:600px){
  .feature-steps li{ grid-template-columns:60px 1fr; }
  .step-thumb, img.step-thumb{ width:52px; height:52px; }
  .step-thumb::after{ inset:5px; }
}

/* === 詳細特徴セクション（別セクションで使う場合） === */
.feature-details{ background: linear-gradient(180deg,#fff 0%, #fbfbfe 100%); }
.detail-row{
  display:grid;
  grid-template-columns: minmax(0,460px) 1fr;
  gap:24px;
  align-items:center;
  padding:18px 0;
  border-top:1px solid var(--line);
}
.detail-row:first-of-type{ border-top:0; }
.detail-row.is-reverse{ grid-template-columns: 1fr minmax(0,460px); }
.detail-row.is-reverse .detail-media{ order:2; }
.detail-row.is-reverse .detail-body{ order:1; }
.detail-media{ width:100%; }
.detail-thumb{
  width:100%; aspect-ratio: 16 / 9; border-radius:16px;
  background: linear-gradient(180deg,#fff 0%,#fafafa 100%);
  border:2px solid #ffd9b5; box-shadow: var(--shadow);
  position:relative; overflow:hidden;
}
.detail-thumb::after{
  content:""; position:absolute; inset:10px;
  border:1px dashed #ffbe8a; border-radius:12px;
}
img.detail-thumb{
  display:block; width:100%; height:auto; aspect-ratio:16/9; object-fit:cover;
  border-radius:16px; border:2px solid #ffd9b5; box-shadow: var(--shadow);
}
.detail-body h3{ margin:0 0 8px; font-size:20px; }
.detail-lead{ color:#555; margin:0 0 10px; }
.checklist{ list-style:none; padding:0; margin:8px 0 0; display:grid; gap:6px; }
.checklist li{
  position:relative; padding-left:26px; line-height:1.7; background:#fff; border-radius:8px;
}
.checklist li::before{
  content:"✓"; position:absolute; left:8px; top:0; transform:translateY(4px);
  width:16px; height:16px; display:inline-grid; place-items:center;
  color:#fff; font-weight:800; font-size:12px; border-radius:50%; background:var(--brand);
  box-shadow: 0 4px 10px rgba(0,0,0,.08);
}
@media (max-width: 900px){
  .detail-row,
  .detail-row.is-reverse{
    grid-template-columns: 1fr;
  }
  .detail-row.is-reverse .detail-media,
  .detail-row.is-reverse .detail-body{
    order: unset;
  }
}

/* === 「こんな方に」写真枠 === */
.who-card h3{ margin: 0 0 10px; }
.who-thumb{
  width:100%;
  aspect-ratio: 16 / 9;
  border-radius:14px;
  background: linear-gradient(180deg,#fff 0%,#fafafa 100%);
  border:2px solid #ffd9b5;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
  margin-bottom:10px;
}
.who-thumb::after{
  content:"";
  position:absolute; inset:8px;
  border:1px dashed #ffbe8a;
  border-radius:12px;
}
img.who-thumb{
  display:block;
  width:100%; height:auto;
  aspect-ratio:16 / 9;
  object-fit:cover;
  border-radius:14px;
  border:2px solid #ffd9b5;
  box-shadow: var(--shadow);
  margin-bottom:10px;
}
@media (max-width: 600px){
  .who-thumb, img.who-thumb{
    border-radius:12px;
  }
  .who-thumb::after{ inset:7px; border-radius:10px; }
}

/* === Teachers（自慢の講師陣） === */
.teachers-grid{ align-items:stretch; }

.teacher-card{
  display:grid;
  grid-template-columns: 96px 1fr;
  gap:14px;
  padding:16px;
}

.teacher-avatar{
  width:96px; height:96px; border-radius:50%;
  background: linear-gradient(180deg,#fff 0%,#fafafa 100%);
  border:2px solid #ffd9b5; box-shadow: var(--shadow);
  position:relative; overflow:hidden; flex:0 0 auto;
}
.teacher-avatar::after{
  content:""; position:absolute; inset:8px;
  border:1px dashed #ffbe8a; border-radius:50%;
}

/* 実画像に差し替える場合 */
img.teacher-avatar{
  display:block; width:96px; height:96px; object-fit:cover;
  border-radius:50%; border:2px solid #ffd9b5; box-shadow: var(--shadow);
}

.teacher-body{ display:flex; flex-direction:column; gap:6px; }
.teacher-name{ margin:0; font-size:18px; line-height:1.2; }
.teacher-name small.teacher-meta{
  display:inline-block; margin-left:6px; font-weight:600; color:#777; font-size:12px;
}
.teacher-tags{
  display:flex; flex-wrap:wrap; gap:6px; list-style:none; padding:0; margin:0;
}
.tag{
  display:inline-block; padding:4px 8px; font-size:12px; font-weight:800;
  color:#7a3a00; background:#fff7ed; border:1px solid #ffd9b5; border-radius:999px;
}
.teacher-bio{ margin:4px 0 0; color:#555; font-size:14px; }

@media (max-width: 600px){
  .teacher-card{ grid-template-columns:72px 1fr; gap:12px; }
  .teacher-avatar, img.teacher-avatar{ width:72px; height:72px; }
  .teacher-avatar::after{ inset:6px; }
}


/* === Flow（サムネ枠つき） === */
.flow.flow--with-thumb li{
  display:grid;
  grid-template-columns: 72px 1fr;
  gap:12px;
  align-items:center;
  padding:12px 14px;
}
.flow-thumb{
  width:64px; height:64px; border-radius:12px;
  background: linear-gradient(180deg,#fff 0%,#fafafa 100%);
  border:2px solid #ffd9b5; box-shadow: var(--shadow);
  position:relative; overflow:hidden;
}
.flow-thumb::after{
  content:""; position:absolute; inset:6px;
  border:1px dashed #ffbe8a; border-radius:10px;
}
.flow-body{ font-size:16px; }
img.flow-thumb{
  object-fit:cover; width:64px; height:64px; border-radius:12px;
  border:2px solid #ffd9b5; box-shadow: var(--shadow);
}
@media (max-width:600px){
  .flow.flow--with-thumb li{ grid-template-columns: 60px 1fr; }
  .flow-thumb, img.flow-thumb{ width:52px; height:52px; }
  .flow-thumb::after{ inset:5px; }
}

/* === Testimonials 顔写真の枠 === */
.voice{ position:relative; padding-right:98px; }
.voice-avatar{
  position:absolute; right:16px; top:16px;
  width:64px; height:64px; border-radius:50%;
  background: linear-gradient(180deg,#fff 0%,#fafafa 100%);
  border:2px solid #ffd9b5; box-shadow: var(--shadow);
}
.voice-avatar::after{
  content:""; position:absolute; inset:6px;
  border-radius:50%; border:1px dashed #ffbe8a;
}
img.voice-avatar{
  object-fit: cover; width:64px; height:64px; border-radius:50%;
  position:absolute; right:16px; top:16px;
  border:2px solid #ffd9b5; box-shadow: var(--shadow);
}
@media (max-width: 600px){
  .voice{ padding-right:80px; }
  .voice-avatar, img.voice-avatar{ width:52px; height:52px; right:12px; top:12px; }
  .voice-avatar::after{ inset:5px; }
}

/* === Features: カード内の「詳しい特徴」（←今回追加） === */
.feature-details-inline{ margin-top:12px; }
.fd-title{ margin:8px 0 6px; font-size:14px; color:#555; font-weight:800; letter-spacing:.02em; }
.fd-list{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.fd-item{
  display:grid; grid-template-columns: 88px 1fr; gap:12px; align-items:center;
  background:#fff; border:1px dashed var(--line); border-radius:12px; padding:10px 12px;
}
.fd-thumb{
  width:88px; aspect-ratio: 16 / 10; border-radius:12px;
  background: linear-gradient(180deg,#fff 0%,#fafafa 100%);
  border:2px solid #ffd9b5; box-shadow: var(--shadow);
  position:relative; overflow:hidden;
}
.fd-thumb::after{
  content:""; position:absolute; inset:6px; border:1px dashed #ffbe8a; border-radius:10px;
}
img.fd-thumb{
  display:block; width:88px; aspect-ratio:16 / 10; height:auto; object-fit:cover;
  border-radius:12px; border:2px solid #ffd9b5; box-shadow: var(--shadow);
}
.fd-body strong{ display:block; line-height:1.35; }
.fd-desc{ margin:2px 0 0; color:#666; font-size:13px; }
@media (max-width:600px){
  .fd-item{ grid-template-columns: 72px 1fr; }
  .fd-thumb, img.fd-thumb{ width:72px; }
  .fd-thumb::after{ inset:5px; }
}
/* Feature cover image */
.feature-cover{
  width:100%; aspect-ratio:16/9; height:auto; object-fit:cover;
  border-radius:14px; border:2px solid #ffd9b5; box-shadow:var(--shadow);
  margin:8px 0 12px;
}
/* === Compact 3-up grid (カードを細め・中央寄せ) === */
.grid-3.grid-compact{
  --cardW: 320px;   /* ←お好みで 300〜340px に調整 */
  --gap: 16px;
}

/* PC：固定幅3列で中央寄せ */
@media (min-width: 961px){
  .grid-3.grid-compact{
    grid-template-columns: repeat(3, var(--cardW));
    gap: var(--gap);
    justify-content: center; /* 余白を左右に逃して中央寄せ */
  }
}

/* 画像がはみ出さないよう保険（任意） */
.grid-3.grid-compact .card{
  width: 100%;
  max-width: var(--cardW);
}
/* === Price: ALL-IN リボン & スタンプ（レスポンシブ対応） === */

/* カード：上部にリボンを載せる余白を確保 */
.price-card--value,
.price-card--allin{
  position:relative;
  padding-top:66px;   /* リボンぶんの余白を少し広めに */
  overflow:hidden;
}

/* 左上リボン（「全部コミコミ 追加料金なし」） */
.ribbon,
.ribbon--allin{
  position:absolute;
  top:14px; left:14px;
  display:inline-flex;            /* 背景がテキストにフィット */
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;            /* きれいな pill 形状 */
  background:linear-gradient(90deg,#ff8a1a,#ff6a00);
  color:#fff;
  font-weight:900;
  font-size:13px;
  letter-spacing:.06em;
  box-shadow:var(--shadow);
  white-space:nowrap;             /* 行折返しで背景が割れないように */
  line-height:1.1;
}

/* スマホで窮屈なら、縦積み＋少し縮小 */
@media (max-width: 420px){
  .ribbon,
  .ribbon--allin{
    flex-direction:column;
    align-items:flex-start;
    gap:4px;
    padding:8px 10px;
    font-size:12px;
    white-space:normal;           /* 縦に折り返し可 */
  }
}

/* 右上の “NO EXTRA” スタンプ。テキストが素のまま出ないよう厳格に丸型化 */
.allin-stamp{
  position:absolute;
  right:14px; top:12px;
  width:88px; height:88px;
  display:grid; place-items:center;
  border-radius:50%;
  border:3px solid var(--brand);
  color:var(--brand);
  font-weight:900;
  font-size:14px;
  line-height:1.05;
  text-align:center;
  background:transparent;
  opacity:.22;
  transform:rotate(-12deg);
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.08));
  pointer-events:none;
}
.allin-stamp *{ display:block; }  /* <br> でもレイアウトが崩れない保険 */

/* スマホでは小さくして被りを軽減、必要なら右下へ退避 */
@media (max-width: 600px){
  .allin-stamp{ width:74px; height:74px; font-size:12px; right:10px; top:10px; }
}
@media (max-width: 380px){
  .allin-stamp{ width:64px; height:64px; font-size:11px; right:8px; top:auto; bottom:8px; }
}

/* 金額の視認性（特大化） */
.price-card--value .price-main,
.price-card--allin .price-main{
  font-size:56px; font-weight:900; letter-spacing:.01em; color:var(--ink);
}
@media (max-width:720px){
  .price-card--value .price-main,
  .price-card--allin .price-main{ font-size:42px; }
}

/* 追加費用ゼロの小チップ（行崩れ防止 & 余白調整） */
.noextra-line{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin:8px 0 10px; }
.noextra{ font-size:12px; font-weight:800; color:#7a3a00; background:#fff3e8; border:1px solid #ffd9b5; border-radius:999px; padding:4px 10px; }

/* 既存のバッジ・サブ文そのまま利用 */
.price-sub{ text-align:center; color:#777; margin:0 0 6px; }
.price-savings{
  text-align:center; margin:0 0 10px; color:#6b4b2e;
  background:#fff7ed; border:1px solid #ffd9b5; border-radius:999px;
  padding:6px 10px; display:inline-block; margin-left:50%; transform:translateX(-50%);
}

/* 参考：.section.alt の gradient に混ざっている「透明」は CSS 無効語なので transparent に */
.section.alt{
  background:linear-gradient(180deg,#fff 0%,#fbfbfe 100%),
             radial-gradient(800px 400px at 10% -20%,rgba(135,120,255,.06),transparent 60%);
}

/* === Strengths（英検の特徴） === */
.strengths{
  background:
    linear-gradient(180deg,#fff 0%, #fbfbfe 100%),
    repeating-linear-gradient(0deg, rgba(34,34,68,.03) 0 30px, transparent 30px 60px),
    repeating-linear-gradient(90deg, rgba(34,34,68,.02) 0 30px, transparent 30px 60px);
}

.strength-row{
  display:grid;
  grid-template-columns:minmax(0,520px) 1fr;
  gap:26px;
  align-items:center;
  padding:18px;
  margin:18px 0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow);
}
.strength-row.is-reverse{
  grid-template-columns:1fr minmax(0,520px);
}
.strength-row.is-reverse .strength-media{ order:2; }
.strength-row.is-reverse .strength-body{ order:1; }

.strength-media{ width:100%; }
.strength-photo{
  width:100%; aspect-ratio:16/9; border-radius:16px;
  background:linear-gradient(180deg,#fff 0%,#fafafa 100%);
  border:2px solid #ffd9b5; box-shadow:var(--shadow);
  position:relative; overflow:hidden;
}
.strength-photo::after{
  content:""; position:absolute; inset:10px;
  border:1px dashed #ffbe8a; border-radius:12px;
}

/* 実画像に差し替える場合 */
img.strength-photo{
  display:block; width:100%; height:auto; aspect-ratio:16/9; object-fit:cover;
  border-radius:16px; border:2px solid #ffd9b5; box-shadow:var(--shadow);
}

.strength-body h3{ margin:0 0 8px; font-size:22px; }
.strength-lead{ margin:0 0 10px; color:#555; }
.strength-points{
  list-style:none; padding:0; margin:8px 0 0; display:grid; gap:6px;
}
.strength-points li{
  position:relative; padding-left:24px; background:#fff; border-radius:8px; line-height:1.7;
}
.strength-points li::before{
  content:""; position:absolute; left:6px; top:.65em;
  width:10px; height:10px; border-radius:50%; background:var(--brand);
  box-shadow:0 4px 10px rgba(0,0,0,.08);
}

/* 左側の大きな番号 */
.strength-no{
  font-weight:900; font-size:44px; line-height:1; color:var(--brand);
  letter-spacing:.02em; margin:0 0 6px;
}

/* レスポンシブ */
@media (max-width: 960px){
  .strength-row,
  .strength-row.is-reverse{
    grid-template-columns:1fr;
  }
  .strength-no{ font-size:34px; }
}
@media (max-width: 600px){
  .strength-row{ padding:14px; gap:16px; }
  .strength-no{ font-size:28px; }
  .strength-body h3{ font-size:18px; }
}
/* === Trial CTA (セクション間の無料体験バナー) === */
.trial-cta{
  background:linear-gradient(180deg,#fff7ed 0%,#fff 100%);
  border:1px solid #ffd9b5; border-radius:16px; box-shadow:var(--shadow);
  padding:16px 18px; display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.trial-cta .tc-copy{ display:flex; flex-direction:column; gap:6px; }
.trial-cta .tc-badge{
  display:inline-block; font-weight:900; font-size:12px; letter-spacing:.06em;
  color:#7a3a00; background:#fff3e8; border:1px solid #ffd9b5; border-radius:999px; padding:4px 10px;
}
.trial-cta h3{ margin:0; font-size:18px; letter-spacing:.01em; }
.trial-cta .tc-meta{ display:flex; flex-wrap:wrap; gap:8px; }
.trial-cta .tc-meta .chip{ background:#fff; } /* 既存 .chip を利用 */
.trial-cta .tc-note{ color:#8a6b49; font-size:12px; }

.trial-section{ padding:36px 0; } /* 通常セクションより控えめな上下マージン */

@media (max-width: 720px){
  .trial-cta{ flex-direction:column; align-items:flex-start; }
  .trial-cta .btn{ width:100%; text-align:center; }
}
