/* =========================================================
   そだちびより — サブページ共通（園 / 保護者 / スポンサー）
   sodachi.css を読み込んだ上で追加で使用
   ========================================================= */

/* ページごとのアクセント（body[data-page]で切替） */
body{--accent:var(--leaf);--accent-deep:#2c5e36;--accent-soft:rgba(58,122,69,.12);}
body[data-page="parents"]{--accent:var(--wood-deep);--accent-deep:#7c5226;--accent-soft:rgba(242,168,58,.16);}
body[data-page="sponsor"]{--accent:var(--coral-deep);--accent-deep:#a8542f;--accent-soft:rgba(224,130,90,.14);}
body[data-page="try"]{--accent:var(--wood-deep);--accent-deep:#7c5226;--accent-soft:rgba(242,168,58,.18);}

/* ---------- 体験アカウント・カード ---------- */
.cred-card{max-width:880px;margin:clamp(28px,4vw,44px) auto 0;padding:0 24px;}
.cred-card .inner{border:2px dashed var(--accent);border-radius:1.75rem;background:var(--accent-soft);
  padding:clamp(26px,3.5vw,40px);display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.cred-card .ck-head{grid-column:1/-1;display:flex;align-items:center;gap:12px;font-family:var(--font-serif);
  font-weight:700;font-size:1.2rem;color:var(--ink);}
.cred-card .ck-head .ic{width:34px;height:34px;border-radius:10px;background:var(--accent);color:#fff;display:grid;place-items:center;}
.cred-card .ck-head .ic svg{width:18px;height:18px;}
.cred-row{background:var(--card);border:1px solid var(--border);border-radius:1rem;padding:16px 20px;}
.cred-row .lab{font-size:.7rem;letter-spacing:.16em;font-weight:700;color:var(--ink-mute);margin:0 0 .4rem;}
.cred-row .val{font-family:var(--font-serif);font-weight:700;font-size:1.1rem;color:var(--ink);word-break:break-all;}
.cred-note{grid-column:1/-1;font-size:.8rem;color:var(--ink-soft);margin:0;line-height:1.7;}

/* ---------- プラットフォーム導線 ---------- */
.platforms{max-width:880px;margin:clamp(24px,3vw,32px) auto 0;padding:0 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.plat-btn{display:flex;align-items:center;gap:14px;border:1px solid var(--border);background:var(--card);border-radius:1.25rem;
  padding:18px 22px;transition:transform .3s cubic-bezier(.34,1.3,.6,1),box-shadow .3s,border-color .3s;}
.plat-btn:hover{transform:translateY(-4px);box-shadow:0 22px 40px -26px rgba(58,40,23,.45);border-color:var(--accent);}
.plat-btn .pic{width:42px;height:42px;flex:none;border-radius:12px;background:var(--accent-soft);color:var(--accent-deep);display:grid;place-items:center;}
.plat-btn .pic svg{width:22px;height:22px;}
.plat-btn .pt{font-size:.72rem;color:var(--ink-mute);font-weight:700;letter-spacing:.06em;}
.plat-btn .pn{font-family:var(--font-serif);font-weight:700;font-size:1.02rem;color:var(--ink);}
@media (max-width:680px){.cred-card .inner{grid-template-columns:1fr;}.platforms{grid-template-columns:1fr;}}

/* ---------- パンくず ---------- */
.crumbs{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:10px;
  font-size:.82rem;color:var(--ink-mute);}
.crumbs a{color:var(--ink-soft);transition:color .2s;}
.crumbs a:hover{color:var(--accent);}
.crumbs .sep{opacity:.5;}

/* ---------- ページヒーロー ---------- */
.page-hero{position:relative;overflow:hidden;padding-top:clamp(116px,15vw,168px);}
.page-hero-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(28px,4vw,44px) 24px clamp(48px,7vw,86px);
  display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(32px,5vw,60px);align-items:center;}
.page-hero .tagline{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1.1rem;border-radius:999px;white-space:nowrap;
  background:var(--accent-soft);color:var(--accent-deep);font-size:.78rem;font-weight:700;letter-spacing:.06em;}
.page-hero h1{font-family:var(--font-serif);font-weight:700;line-height:1.4;letter-spacing:.03em;
  font-size:clamp(2.1rem,4.4vw,3.3rem);margin:1.3rem 0 0;color:var(--ink);text-wrap:balance;}
.page-hero .lead{margin-top:1.6rem;}
.page-hero-photo{position:relative;}
.page-hero-photo .frame-photo{aspect-ratio:4/3;}
.page-hero-photo .frame-photo img{width:100%;height:100%;object-fit:cover;}
.page-hero-photo .badge-float{position:absolute;border-radius:18px;background:#fff;border:1px solid var(--border);
  padding:12px 16px;display:flex;align-items:center;gap:10px;}

/* ---------- 無料バッジ（保護者） ---------- */
.free-hero-badge{position:absolute;right:-14px;top:-18px;z-index:3;width:128px;height:128px;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,#fbe0a0,var(--sun));color:var(--wood-deep);
  display:grid;place-items:center;text-align:center;transform:rotate(8deg);
  box-shadow:0 18px 40px -18px rgba(154,102,51,.6);border:3px solid #fff;}
.free-hero-badge b{font-family:var(--font-serif);font-size:1.9rem;font-weight:700;line-height:1;display:block;}
.free-hero-badge small{font-size:.62rem;letter-spacing:.14em;font-weight:700;margin-top:4px;display:block;}
.free-strip{background:var(--accent);color:#fff;}
.free-strip .inner{max-width:var(--maxw);margin:0 auto;padding:18px 24px;display:flex;flex-wrap:wrap;
  align-items:center;justify-content:center;gap:10px 22px;text-align:center;}
.free-strip .big{font-family:var(--font-serif);font-weight:700;font-size:clamp(1.1rem,2vw,1.45rem);letter-spacing:.04em;}
.free-strip .sub{font-size:.86rem;opacity:.92;}

/* ---------- セクション見出し（サブページ） ---------- */
.sub-head{max-width:var(--maxw);margin:0 auto clamp(34px,5vw,56px);padding:0 24px;}
.sub-head.center{text-align:center;}
.sub-head .eyebrow{color:var(--accent);}
.sub-head h2{font-family:var(--font-serif);font-weight:700;letter-spacing:.03em;line-height:1.42;
  font-size:clamp(1.6rem,3vw,2.4rem);margin:1rem 0 0;color:var(--ink);text-wrap:balance;}
.sub-head p{margin:1.2rem auto 0;}

/* ---------- 料金：単一ハイライト（園 開始/成立後） ---------- */
.price-duo{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr auto 1fr;
  gap:clamp(20px,3vw,36px);align-items:stretch;}
.price-box{border-radius:1.75rem;border:1px solid var(--border);background:var(--card);padding:clamp(28px,3.5vw,42px);
  display:flex;flex-direction:column;}
.price-box.start{}
.price-box.after{border:2px solid var(--accent);background:linear-gradient(180deg,var(--accent-soft),var(--card));position:relative;}
.price-box .ptag{font-size:.72rem;letter-spacing:.2em;font-weight:700;color:var(--accent-deep);margin:0;}
.price-box .pname{font-family:var(--font-serif);font-weight:700;font-size:1.2rem;margin:.5rem 0 0;color:var(--ink);}
.price-box .pamount{font-family:var(--font-serif);display:block;margin:1.3rem 0 .4rem;color:var(--ink);line-height:1.05;}
.price-box .pamount b{font-size:clamp(2.4rem,4.6vw,3.3rem);font-weight:700;}
.price-box .pamount .yen{font-size:1.6rem;font-weight:700;margin-right:.1rem;}
.price-box .pamount .per{display:block;font-size:.9rem;color:var(--ink-soft);font-family:var(--font-sans);margin-top:.5rem;}
.price-box .pnote{font-size:.86rem;color:var(--ink-soft);margin:.2rem 0 0;line-height:1.7;}
.price-box .save{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;margin-top:auto;padding-top:1.2rem;
  font-weight:700;color:var(--accent-deep);font-size:.95rem;}
.price-arrow{display:grid;place-items:center;color:var(--accent);}
.price-arrow svg{width:34px;height:34px;}
.price-arrow .lbl{font-size:.66rem;letter-spacing:.16em;color:var(--ink-mute);margin-top:6px;font-weight:700;text-align:center;}

/* 含まれる範囲・追加料金テーブル */
.rate-table{max-width:var(--maxw);margin:clamp(28px,4vw,44px) auto 0;padding:0 24px;}
.rate-grid{border:1px solid var(--border);border-radius:1.5rem;overflow:hidden;background:var(--card);}
.rate-row{display:grid;grid-template-columns:1.3fr 1fr;gap:16px;padding:20px 26px;border-bottom:1px solid var(--border-soft);align-items:center;}
.rate-row:last-child{border-bottom:none;}
.rate-row .k{font-weight:700;color:var(--ink);font-size:.98rem;}
.rate-row .k small{display:block;font-weight:500;color:var(--ink-mute);font-size:.8rem;margin-top:3px;}
.rate-row .v{text-align:right;font-family:var(--font-serif);font-weight:700;color:var(--accent-deep);font-size:1.05rem;}
.rate-row .v.free{color:var(--leaf);}

/* ---------- スポンサー：3プランカード ---------- */
.plan-grid{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;align-items:stretch;}
.plan-card{position:relative;border:1px solid var(--border);background:var(--card);border-radius:1.75rem;
  padding:clamp(26px,3vw,34px) clamp(24px,2.6vw,30px) clamp(28px,3vw,36px);display:flex;flex-direction:column;
  transition:transform .35s,box-shadow .35s;}
.plan-card:hover{transform:translateY(-6px);box-shadow:0 30px 56px -30px rgba(58,40,23,.4);}
.plan-card.featured{border:2px solid var(--accent);box-shadow:0 26px 50px -28px rgba(197,102,61,.5);}
.plan-card .reco{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;
  font-size:.72rem;font-weight:700;letter-spacing:.12em;padding:.4rem 1.2rem;border-radius:999px;white-space:nowrap;}
.plan-card .pen{font-size:.7rem;letter-spacing:.24em;font-weight:700;color:var(--accent);margin:0;}
.plan-card .pjp{font-family:var(--font-serif);font-weight:700;font-size:1.5rem;margin:.5rem 0 0;color:var(--ink);}
.plan-card .pprice{font-family:var(--font-serif);display:block;margin:1.1rem 0 .3rem;color:var(--ink);line-height:1.05;}
.plan-card .pprice .yen{font-size:1.1rem;font-weight:700;margin-right:.05rem;}
.plan-card .pprice b{font-size:clamp(2rem,3.6vw,2.7rem);font-weight:700;}
.plan-card .pprice .per{font-size:.82rem;color:var(--ink-soft);font-family:var(--font-sans);margin-left:.3rem;}
.plan-card .ptax{font-size:.74rem;color:var(--ink-mute);margin:0 0 1.4rem;}
.plan-card .pdesc{font-size:.86rem;color:var(--ink-soft);line-height:1.75;margin:0 0 1.4rem;padding-bottom:1.4rem;border-bottom:1px dashed var(--border);}
.plan-feats{list-style:none;margin:0 0 1.8rem;padding:0;display:grid;gap:12px;}
.plan-feats li{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;line-height:1.6;color:var(--ink);}
.plan-feats .ck{margin-top:2px;width:20px;height:20px;flex:none;border-radius:50%;background:var(--accent-soft);
  color:var(--accent-deep);display:grid;place-items:center;}
.plan-feats .ck svg{width:12px;height:12px;}
.plan-card .pbtn{margin-top:auto;}
.plan-option{max-width:var(--maxw);margin:24px auto 0;padding:0 24px;}
.plan-option .inner{border:1px dashed var(--accent);border-radius:1.5rem;background:var(--accent-soft);
  padding:22px 28px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;}
.plan-option .ttl{font-family:var(--font-serif);font-weight:700;color:var(--ink);font-size:1.1rem;}
.plan-option .ttl small{display:block;font-family:var(--font-sans);font-weight:500;color:var(--ink-soft);font-size:.82rem;margin-top:3px;}
.plan-option .amt{font-family:var(--font-serif);font-weight:700;color:var(--accent-deep);font-size:1.3rem;white-space:nowrap;}

/* ---------- 広告枠 / 価値（アイコンリスト） ---------- */
.spec-grid{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);}
.spec-grid.three{grid-template-columns:repeat(3,1fr);}
.spec-card{display:flex;gap:18px;border:1px solid var(--border);background:var(--card);border-radius:1.5rem;padding:26px 28px;
  transition:transform .35s cubic-bezier(.34,1.3,.6,1),box-shadow .35s,border-color .35s;}
.spec-card:hover{transform:translateY(-6px);box-shadow:0 28px 50px -30px rgba(58,40,23,.4);border-color:var(--accent);}
.spec-card .si{width:46px;height:46px;flex:none;border-radius:14px;background:var(--accent-soft);color:var(--accent-deep);
  display:grid;place-items:center;font-family:var(--font-serif);font-weight:700;font-size:1.1rem;transition:transform .35s cubic-bezier(.34,1.6,.6,1),background .35s;}
.spec-card:hover .si{transform:rotate(-6deg) scale(1.1);background:var(--accent);color:#fff;}
.spec-card h4{font-family:var(--font-serif);font-weight:700;font-size:1.1rem;margin:0;color:var(--ink);}
.spec-card p{margin:.5rem 0 0;font-size:.86rem;line-height:1.75;color:var(--ink-soft);}

/* 数字バッジ（リーチ） */
.reach-grid{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.reach-card{border:1px solid var(--border);background:var(--card);border-radius:1.75rem;padding:34px 30px;text-align:center;
  transition:transform .4s cubic-bezier(.34,1.3,.6,1),box-shadow .4s;}
.reach-card:hover{transform:translateY(-6px);box-shadow:0 28px 50px -30px rgba(58,40,23,.4);}
.reach-card .num{font-family:var(--font-serif);font-weight:700;color:var(--accent-deep);font-size:clamp(2.2rem,4vw,3rem);line-height:1;
  transition:transform .4s cubic-bezier(.34,1.6,.6,1);}
.reach-card:hover .num{transform:scale(1.08);}
.reach-card .cap{font-weight:700;color:var(--ink);margin:1rem 0 .5rem;}
.reach-card p{font-size:.84rem;color:var(--ink-soft);line-height:1.7;margin:0;}

/* ---------- QA アコーディオン ---------- */
.qa-wrap{max-width:880px;margin:0 auto;padding:0 24px;display:grid;gap:14px;}
.qa{border:1px solid var(--border);background:var(--card);border-radius:1.25rem;overflow:hidden;}
.qa summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:16px;padding:22px 26px;
  font-weight:700;color:var(--ink);font-size:1rem;transition:background .25s;}
.qa:hover{border-color:var(--accent);}
.qa summary:hover{background:var(--accent-soft);}
.qa summary::-webkit-details-marker{display:none;}
.qa summary .q{width:30px;height:30px;flex:none;border-radius:50%;background:var(--accent-soft);color:var(--accent-deep);
  display:grid;place-items:center;font-family:var(--font-serif);font-weight:700;}
.qa summary .qt{flex:1;line-height:1.5;}
.qa summary .chev{width:20px;height:20px;flex:none;color:var(--ink-mute);transition:transform .3s;}
.qa[open] summary .chev{transform:rotate(180deg);}
.qa .ans{padding:0 26px 24px 72px;color:var(--ink-soft);font-size:.92rem;line-height:1.9;}
.qa .ans.free-ans{color:var(--ink);}
.qa .ans .hl{background:linear-gradient(var(--sun-soft),var(--sun-soft)) bottom/100% .5em no-repeat;font-weight:700;color:var(--ink);}

/* ---------- ステップ（導入の流れ） ---------- */
.steps{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:grid;gap:18px;grid-template-columns:repeat(5,1fr);}
.step{position:relative;border:1px solid var(--border);background:var(--card);border-radius:1.5rem;padding:26px 22px;
  transition:transform .35s cubic-bezier(.34,1.3,.6,1),box-shadow .35s;}
.step:hover{transform:translateY(-5px);box-shadow:0 24px 44px -28px rgba(58,40,23,.4);}
.step .sn{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;
  font-family:var(--font-serif);font-weight:700;transition:transform .35s cubic-bezier(.34,1.6,.6,1);}
.step:hover .sn{transform:rotate(-8deg) scale(1.12);}
.step h4{font-family:var(--font-serif);font-weight:700;font-size:1rem;margin:.9rem 0 .5rem;color:var(--ink);}
.step p{font-size:.8rem;line-height:1.7;color:var(--ink-soft);margin:0;}
.steps.four{grid-template-columns:repeat(4,1fr);}
.steps.three{grid-template-columns:repeat(3,1fr);max-width:840px;}

/* ---------- アプリ画面（縦並びショット） ---------- */
.app-shots{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.app-shot{text-align:center;}
.app-shot .ph{position:relative;margin:0 auto 18px;width:min(220px,100%);background:#1f1810;border-radius:30px;padding:8px;
  border:1px solid rgba(0,0,0,.2);box-shadow:0 30px 60px -34px rgba(58,40,23,.6);
  transition:transform .45s cubic-bezier(.34,1.4,.6,1),box-shadow .45s;}
.app-shot:nth-child(odd) .ph{transform:rotate(-2deg);}
.app-shot:nth-child(even) .ph{transform:rotate(2deg);}
.app-shot .ph:hover{transform:rotate(0) translateY(-10px) scale(1.03);box-shadow:0 44px 70px -34px rgba(58,40,23,.7);}
.app-shot .ph::before{content:"";position:absolute;top:15px;left:50%;transform:translateX(-50%);width:42px;height:5px;
  border-radius:5px;background:rgba(255,255,255,.32);z-index:2;}
.app-shot .scr{border-radius:23px;overflow:hidden;aspect-ratio:520/1131;background:#000;}
.app-shot .scr img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.app-shot h4{font-family:var(--font-serif);font-weight:700;font-size:1.05rem;margin:0 0 .4rem;color:var(--ink);}
.app-shot p{font-size:.84rem;color:var(--ink-soft);line-height:1.7;margin:0;}

/* ---------- 帯CTA ---------- */
.band-cta{position:relative;overflow:hidden;background:var(--accent);color:#fff;}
.band-cta .inner{max-width:var(--maxw);margin:0 auto;padding:clamp(48px,7vw,84px) 24px;text-align:center;}
.band-cta h2{font-family:var(--font-serif);font-weight:700;font-size:clamp(1.7rem,3.2vw,2.6rem);line-height:1.42;margin:0;letter-spacing:.03em;}
.band-cta p{margin:1.4rem auto 0;max-width:40em;opacity:.94;line-height:2;}
.band-cta .btns{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:14px;justify-content:center;}
.band-cta .btn-fill{background:#fff;color:var(--accent-deep);}
.band-cta .btn-fill:hover{background:var(--bg-soft);}
.band-cta .btn-line{background:transparent;color:#fff;border-color:rgba(255,255,255,.55);}
.band-cta .btn-line:hover{background:rgba(255,255,255,.12);}

/* ---------- 注記 ---------- */
.fineprint{max-width:var(--maxw);margin:clamp(24px,3vw,36px) auto 0;padding:0 24px;font-size:.78rem;color:var(--ink-mute);line-height:1.8;text-wrap:pretty;}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media (max-width:1000px){
  .page-hero-inner{grid-template-columns:1fr;gap:30px;}
  .page-hero-photo{max-width:460px;margin:0 auto;}
  .price-duo{grid-template-columns:1fr;gap:30px;}
  .price-arrow{transform:rotate(90deg);padding:6px 0;}
  .plan-grid{grid-template-columns:1fr;max-width:440px;}
  .spec-grid,.spec-grid.three{grid-template-columns:1fr;}
  .reach-grid{grid-template-columns:1fr;max-width:420px;}
  .steps,.steps.four,.steps.three{grid-template-columns:1fr 1fr;}
  .app-shots{grid-template-columns:1fr;max-width:340px;}
}
@media (max-width:560px){
  .rate-row{grid-template-columns:1fr;gap:6px;}
  .rate-row .v{text-align:left;}
  .steps,.steps.four,.steps.three{grid-template-columns:1fr;}
  .plan-option .inner{flex-direction:column;align-items:flex-start;}
  .free-hero-badge{width:104px;height:104px;right:6px;top:-12px;}
  .free-hero-badge b{font-size:1.5rem;}
  .qa .ans{padding-left:26px;}
}
