:root{
  --navy:#0f1c2e; --navy-2:#16294a; --navy-line:#27395c;
  --green:#1f8a4c; --green-deep:#136336; --green-soft:#e7f4ec;
  --orange:#e2691c; --orange-deep:#c4540f;
  --prime-cyan:#00a8e1; --prime-gold:#febd69;
  --ink:#15202b; --ink-soft:#475569; --ink-mute:#8290a0;
  --bg:#f5f7fa; --card:#ffffff; --line:#e3e8ef;
  --shadow:0 1px 3px rgba(15,28,46,.06),0 8px 24px rgba(15,28,46,.05);
  --shadow-lg:0 4px 12px rgba(15,28,46,.08),0 20px 48px rgba(15,28,46,.10);
  --head:'Fraunces',Georgia,serif; --body:'Manrope',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--body);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---- Header ---- */
.site-header{background:var(--navy);position:sticky;top:0;z-index:50;border-bottom:3px solid var(--green)}
.header-inner{max-width:1180px;margin:0 auto;padding:0 24px;height:62px;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--head);font-weight:800;font-size:1.35rem;color:#fff;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}
.logo .dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(31,138,76,.25)}
.logo .accent{color:var(--green)}
.nav{display:flex;gap:28px}
.nav a{color:#c2cede;font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;transition:color .15s}
.nav a:hover{color:#fff}
@media(max-width:760px){.nav{display:none}}

/* ---- Breadcrumb ---- */
.crumb{max-width:1180px;margin:0 auto;padding:16px 24px 0;font-size:.8rem;color:var(--ink-mute);font-weight:500}
.crumb a:hover{color:var(--green)}
.crumb span{margin:0 7px;opacity:.5}

/* ---- Layout ---- */
.wrap{max-width:1180px;margin:0 auto;padding:24px;display:grid;grid-template-columns:1fr 332px;gap:36px;align-items:start}
@media(max-width:920px){.wrap{grid-template-columns:1fr;gap:28px}}

/* ---- Hero ---- */
.hero{margin-bottom:30px}
.eyebrow{display:inline-flex;align-items:center;gap:7px;background:var(--green-soft);color:var(--green-deep);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;padding:6px 13px;border-radius:30px;margin-bottom:16px}
h1{font-family:var(--head);font-weight:700;font-size:2.7rem;line-height:1.08;letter-spacing:-.02em;margin-bottom:14px}
@media(max-width:560px){h1{font-size:2rem}}
.lede{font-size:1.12rem;color:var(--ink-soft);max-width:62ch;margin-bottom:22px}
.meta-row{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:8px 13px;font-size:.82rem;font-weight:600;box-shadow:var(--shadow)}
.chip .k{color:var(--ink-mute);font-weight:500}
.chip .v{color:var(--ink)}

/* ---- Hero visual ---- */
.hero-visual{position:relative;border-radius:18px;overflow:hidden;margin:26px 0 0;box-shadow:var(--shadow-lg);background:linear-gradient(135deg,#16294a,#0f1c2e)}
.hero-visual svg{width:100%;height:auto;display:block}
.hero-tag{position:absolute;left:18px;bottom:16px;background:rgba(15,28,46,.82);backdrop-filter:blur(6px);color:#fff;font-size:.74rem;font-weight:600;padding:7px 13px;border-radius:8px;letter-spacing:.02em}

/* ---- Content cards ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:28px;margin-bottom:22px;box-shadow:var(--shadow)}
.card h2{font-family:var(--head);font-weight:600;font-size:1.5rem;letter-spacing:-.01em;margin-bottom:8px;display:flex;align-items:center;gap:11px}
.card h2 .icon{width:30px;height:30px;border-radius:8px;background:var(--green-soft);color:var(--green-deep);display:grid;place-items:center;font-size:.95rem;flex-shrink:0}
.card p{color:var(--ink-soft);margin-bottom:12px}
.card p:last-child{margin-bottom:0}

/* ---- Steps ---- */
.steps{list-style:none;counter-reset:s;margin-top:8px}
.steps li{position:relative;padding:14px 0 14px 52px;border-bottom:1px solid var(--line)}
.steps li:last-child{border-bottom:none;padding-bottom:0}
.steps li::before{counter-increment:s;content:counter(s);position:absolute;left:0;top:12px;width:34px;height:34px;border-radius:10px;background:var(--navy);color:#fff;font-family:var(--head);font-weight:700;font-size:.95rem;display:grid;place-items:center}

/* ---- Coaching points ---- */
.cp-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:6px}
@media(max-width:560px){.cp-grid{grid-template-columns:1fr}}
.cp{border-radius:13px;padding:18px}
.cp.praise{background:var(--green-soft);border:1px solid #c5e6d2}
.cp.correct{background:#fbeee0;border:1px solid #f3d6b5}
.cp h3{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-bottom:11px;display:flex;align-items:center;gap:7px}
.cp.praise h3{color:var(--green-deep)}
.cp.correct h3{color:var(--orange-deep)}
.cp ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.cp li{font-size:.92rem;color:var(--ink);padding-left:22px;position:relative;line-height:1.45}
.cp.praise li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}
.cp.correct li::before{content:"!";position:absolute;left:2px;color:var(--orange);font-weight:800}

/* ---- Comparison table ---- */
.compare h2{margin-bottom:18px}
.ctable{width:100%;border-collapse:separate;border-spacing:0;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.ctable thead th{background:var(--navy);color:#fff;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;padding:13px 14px;text-align:left}
.ctable tbody td{padding:15px 14px;border-bottom:1px solid var(--line);vertical-align:middle;font-size:.9rem}
.ctable tbody tr:last-child td{border-bottom:none}
.ctable tbody tr:nth-child(even){background:#fafbfc}
.pick{display:inline-block;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:4px 9px;border-radius:20px;white-space:nowrap;background:#eef1f5;color:var(--navy)}
.pick.top{background:var(--orange);color:#fff}
.ctable .pname{font-weight:700;color:var(--ink)}
.ctable .pfor{color:var(--ink-soft);font-size:.85rem}
.buy-sm{display:inline-flex;align-items:center;gap:5px;background:var(--orange);color:#fff;padding:8px 13px;border-radius:8px;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;transition:background .15s}
.buy-sm:hover{background:var(--orange-deep)}
.disc{font-size:.76rem;color:var(--ink-mute);margin-top:11px;font-style:italic}

/* ---- FAQ ---- */
.faq{border:1px solid var(--line);border-radius:12px;margin-bottom:11px;overflow:hidden}
.faq summary{padding:16px 18px;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;font-size:.96rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--head);font-size:1.4rem;color:var(--green);font-weight:600}
.faq[open] summary::after{content:"−"}
.faq .ans{padding:0 18px 16px;color:var(--ink-soft);font-size:.92rem}

/* ---- Sidebar ---- */
.side{display:flex;flex-direction:column;gap:20px;position:sticky;top:82px}
@media(max-width:920px){.side{position:static}}
.swidget{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow)}
.swidget h3{font-family:var(--head);font-weight:600;font-size:1.1rem;margin-bottom:15px}
.gear{display:flex;flex-direction:column;gap:13px}
.gcard{border:1px solid var(--line);border-radius:11px;padding:14px;transition:border-color .15s,box-shadow .15s}
.gcard:hover{border-color:var(--green);box-shadow:var(--shadow)}
.gcard .gtop{display:flex;justify-content:space-between;align-items:start;margin-bottom:5px}
.gcard h4{font-size:.92rem;font-weight:700;line-height:1.3}
.gcard p{font-size:.8rem;color:var(--ink-soft);margin:5px 0 11px;line-height:1.4}
.buy{display:block;text-align:center;background:var(--orange);color:#fff;padding:9px;border-radius:8px;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;transition:background .15s}
.buy:hover{background:var(--orange-deep)}
.swidget .sdisc{font-size:.72rem;color:var(--ink-mute);margin-top:11px}

/* ---- Prime card ---- */
.prime{background:linear-gradient(140deg,#16294a,#0c1626);border-radius:16px;padding:20px;border:1px solid var(--navy-line)}
.prime-badge{display:inline-block;font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;background:var(--prime-cyan);color:#012a38;padding:4px 10px;border-radius:20px;margin-bottom:11px}
.prime h4{color:#fff;font-family:var(--head);font-weight:600;font-size:1.15rem;margin-bottom:7px}
.prime p{color:#aebed4;font-size:.83rem;margin-bottom:15px;line-height:1.45}
.prime-cta{display:block;text-align:center;background:var(--prime-gold);color:#0c1626;padding:11px;border-radius:9px;font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.02em;transition:filter .15s}
.prime-cta:hover{filter:brightness(1.06)}

/* ---- Related ---- */
.related h2{font-family:var(--head);font-weight:600;font-size:1.5rem;margin-bottom:18px}
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:760px){.rgrid{grid-template-columns:1fr}}
.rcard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;transition:transform .15s,box-shadow .15s,border-color .15s}
.rcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--green)}
.rcard .rage{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--green-deep);background:var(--green-soft);padding:3px 9px;border-radius:20px;display:inline-block;margin-bottom:10px}
.rcard h4{font-family:var(--head);font-weight:600;font-size:1.08rem;margin-bottom:5px;line-height:1.2}
.rcard p{font-size:.84rem;color:var(--ink-soft);margin-bottom:12px}
.rcard .rarrow{color:var(--green);font-weight:700;font-size:.85rem}

/* ---- Quick actions bar ---- */
.actions{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0 0}
.act{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:9px 15px;font-size:.83rem;font-weight:700;color:var(--ink);cursor:pointer;transition:all .15s;box-shadow:var(--shadow)}
.act:hover{border-color:var(--green);color:var(--green-deep);transform:translateY(-1px)}
.act.wa:hover{border-color:#25d366;color:#128c3e}
.act svg{width:16px;height:16px}

/* ---- Key cue callout ---- */
.keycue{background:linear-gradient(135deg,var(--green-deep),var(--green));border-radius:14px;padding:20px 24px;margin-bottom:22px;color:#fff;display:flex;align-items:center;gap:18px;box-shadow:var(--shadow-lg)}
.keycue .kc-icon{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:1.3rem;flex-shrink:0}
.keycue .kc-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;opacity:.85;margin-bottom:2px}
.keycue .kc-text{font-family:var(--head);font-size:1.18rem;font-weight:600;line-height:1.25}
@media(max-width:560px){.keycue{flex-direction:column;text-align:center;gap:12px}.keycue .kc-text{font-size:1.02rem}}

/* ---- Equipment checklist ---- */
.eqlist{list-style:none;display:flex;flex-direction:column;gap:2px}
.eqlist li{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:9px;cursor:pointer;transition:background .15s;user-select:none}
.eqlist li:hover{background:var(--bg)}
.eqbox{width:21px;height:21px;border:2px solid var(--line);border-radius:6px;flex-shrink:0;display:grid;place-items:center;transition:all .15s}
.eqbox svg{width:13px;height:13px;opacity:0;transition:opacity .15s}
.eqlist li.done .eqbox{background:var(--green);border-color:var(--green)}
.eqlist li.done .eqbox svg{opacity:1}
.eqlist li.done .eqname{color:var(--ink-mute);text-decoration:line-through}
.eqname{font-weight:600;font-size:.94rem}
.eqqty{margin-left:auto;font-size:.8rem;color:var(--ink-mute);font-weight:600;background:var(--bg);padding:3px 10px;border-radius:20px}

/* ---- Difficulty dots ---- */
.chip .dots{display:inline-flex;gap:3px;margin-left:2px}
.chip .dots i{width:6px;height:6px;border-radius:50%;background:var(--line)}
.chip .dots i.on{background:var(--green)}

/* ---- Mobile-responsive comparison table ---- */
@media(max-width:560px){
  .ctable thead{display:none}
  .ctable,.ctable tbody,.ctable tr,.ctable td{display:block;width:100%}
  .ctable tr{border:1px solid var(--line);border-radius:11px;margin-bottom:12px;padding:6px;background:#fff}
  .ctable tbody tr:nth-child(even){background:#fff}
  .ctable td{border:none;padding:7px 10px}
  .buy-sm{width:100%;justify-content:center;padding:11px}
}

/* ---- Load animation ---- */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.hero,.card,.related,.swidget,.prime{animation:rise .5s cubic-bezier(.2,.7,.3,1) backwards}
.hero{animation-delay:.02s}
main .card:nth-of-type(1){animation-delay:.08s}
main .card:nth-of-type(2){animation-delay:.12s}
main .card:nth-of-type(3){animation-delay:.16s}
.side .swidget:nth-of-type(1){animation-delay:.14s}
.side .prime{animation-delay:.20s}
@media(prefers-reduced-motion:reduce){*{animation:none!important}}

/* ---- Phase strip (multi-frame illustration) ---- */
.phases{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
@media(max-width:620px){.phases{grid-template-columns:1fr}}
.phase{border:1px solid var(--line);border-radius:13px;overflow:hidden;background:#fff}
.phase .ptitle{display:flex;align-items:center;gap:8px;padding:11px 14px;background:var(--bg);border-bottom:1px solid var(--line);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.phase .pnum{width:22px;height:22px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-size:.72rem;font-weight:800;flex-shrink:0}
.phase .pviz{aspect-ratio:4/3;background:linear-gradient(160deg,#1f8a4c,#136336)}
.phase .pviz svg{width:100%;height:100%;display:block}
.phase .pcap{padding:11px 14px;font-size:.83rem;color:var(--ink-soft);line-height:1.4}

/* ---- Step diagrams inline ---- */
.steps li .stepviz{margin-top:11px;border-radius:9px;overflow:hidden;border:1px solid var(--line);max-width:260px;background:linear-gradient(160deg,#1f8a4c,#136336)}
.steps li .stepviz svg{width:100%;display:block}

/* ---- Total time badge ---- */
.chip.total{background:var(--navy);border-color:var(--navy)}
.chip.total .k,.chip.total .v{color:#fff}
.chip.total .v{font-weight:800}

/* ---- Visual legend ---- */
.legend{display:flex;flex-wrap:wrap;gap:16px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.legend span{display:inline-flex;align-items:center;gap:7px;font-size:.8rem;color:var(--ink-soft);font-weight:600}
.legend .dot-l{width:16px;height:16px;border-radius:50%;display:inline-block}
.legend .ln{width:22px;height:0;border-top:3px solid;display:inline-block}

/* ---- Save to session ---- */
.act.save.added{background:var(--green);color:#fff;border-color:var(--green)}

/* ---- Print: clean A4 drill card with QR ---- */
.print-only{display:none}
@media print{
  .site-header,.crumb,.side,.related,.actions,.site-footer,.compare,.faq-card{display:none!important}
  body{background:#fff}
  .wrap{display:block;max-width:100%;padding:0}
  .card{box-shadow:none;border:1px solid #ccc;break-inside:avoid;page-break-inside:avoid}
  h1{font-size:1.8rem}
  .hero-visual{box-shadow:none}
  .print-only{display:block}
  .print-header{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--green);padding-bottom:12px;margin-bottom:16px}
  .print-qr{text-align:center}
  .print-qr svg{border:1px solid #eee;border-radius:6px}
  .print-qr p{font-size:.66rem;color:#666;margin-top:4px;max-width:120px}
  *{animation:none!important}
}

/* ---- Footer ---- */
.site-footer{background:var(--navy);color:#aebed4;margin-top:48px;padding:42px 24px 30px}
.footer-inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:36px}
@media(max-width:760px){.footer-inner{grid-template-columns:1fr;gap:26px}}
.site-footer h5{color:#fff;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px;font-weight:700}
.site-footer p,.site-footer a{font-size:.86rem;line-height:1.9}
.site-footer a:hover{color:#fff}
.footer-net a{display:block}
.footer-bottom{max-width:1180px;margin:30px auto 0;padding-top:20px;border-top:1px solid var(--navy-line);font-size:.78rem;color:var(--ink-mute)}
/* ---- Session timeline ---- */
.timeline{display:flex;border-radius:10px;overflow:hidden;border:1px solid var(--line);height:42px}
.tl-seg{display:grid;place-items:center;border-right:2px solid #fff;background:var(--green-soft);transition:background .15s;min-width:32px}
.tl-seg:nth-child(3n+1){background:#d8ebe0}.tl-seg:nth-child(3n+2){background:var(--green-soft)}.tl-seg:nth-child(3n){background:#e8f0e0}
.tl-seg:hover{background:var(--green);}.tl-seg:hover span{color:#fff}
.tl-seg span{font-size:.74rem;font-weight:700;color:var(--green-deep)}
.tl-seg:last-child{border-right:none}
/* ---- Session blocks ---- */
.sblock{border:1px solid var(--line);border-radius:12px;padding:18px;margin-bottom:14px}
.sblock-h{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.sblock-n{width:34px;height:34px;border-radius:10px;background:var(--navy);color:#fff;font-family:var(--head);font-weight:700;display:grid;place-items:center;flex-shrink:0}
.sblock-h h3{font-family:var(--head);font-weight:600;font-size:1.12rem;margin:0}
.sblock-t{font-size:.78rem;color:var(--ink-mute);font-weight:600}
.sblock p{color:var(--ink-soft);font-size:.92rem;margin:0}
/* ---- Article body ---- */
.article-body{max-width:none}
.article-body h2{font-family:var(--head);font-weight:600;font-size:1.5rem;margin:28px 0 12px;letter-spacing:-.01em}
.article-body h2:first-child{margin-top:0}
.article-body h3{font-family:var(--head);font-weight:600;font-size:1.18rem;margin:22px 0 10px}
.article-body p{color:var(--ink-soft);margin-bottom:14px;line-height:1.7}
.article-body ul,.article-body ol{margin:0 0 16px 22px;color:var(--ink-soft)}
.article-body li{margin-bottom:7px;line-height:1.6}
.article-body strong{color:var(--ink)}

/* ---- Homepage ---- */
.home-hero{background:linear-gradient(150deg,#0f1c2e,#16294a);color:#fff;padding:64px 24px 72px;position:relative;overflow:hidden}
.home-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(31,138,76,.25),transparent 55%);pointer-events:none}
.home-hero-inner{max-width:1180px;margin:0 auto;position:relative}
.home-hero h1{font-family:var(--head);font-weight:700;font-size:3.4rem;line-height:1.05;letter-spacing:-.02em;margin:16px 0 18px;color:#fff;max-width:18ch}
@media(max-width:600px){.home-hero h1{font-size:2.3rem}}
.home-lede{font-size:1.2rem;color:#c2cede;max-width:60ch;margin-bottom:28px;line-height:1.6}
.home-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{display:inline-block;background:var(--green);color:#fff;padding:13px 26px;border-radius:10px;font-weight:700;font-size:.95rem;transition:background .15s}
.btn-primary:hover{background:var(--green-deep)}
.btn-ghost{display:inline-block;background:rgba(255,255,255,.1);color:#fff;padding:13px 26px;border-radius:10px;font-weight:700;font-size:.95rem;border:1px solid rgba(255,255,255,.2);transition:background .15s}
.btn-ghost:hover{background:rgba(255,255,255,.18)}
.home-h2{font-family:var(--head);font-weight:600;font-size:1.85rem;letter-spacing:-.01em;margin-bottom:20px}
.home-p{color:var(--ink-soft);font-size:1.05rem;margin-bottom:18px;line-height:1.6}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.cat-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px 16px;text-align:center;transition:transform .15s,box-shadow .15s,border-color .15s;box-shadow:var(--shadow)}
.cat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--green)}
.cat-ico{font-size:1.8rem;display:block;margin-bottom:8px}
.cat-card h3{font-family:var(--head);font-weight:600;font-size:1.05rem;margin-bottom:4px}
.cat-count{font-size:.8rem;color:var(--ink-mute);font-weight:600}
.home-split{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:48px;padding:32px;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}
@media(max-width:680px){.home-split{grid-template-columns:1fr;gap:24px}}
.home-tools{margin-top:48px;padding:32px;background:linear-gradient(150deg,var(--green-soft),#fff);border:1px solid var(--line);border-radius:18px}

/* ---- Training blocks ---- */
.week{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;margin-bottom:16px;box-shadow:var(--shadow)}
.week-h{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.week-n{background:var(--navy);color:#fff;font-family:var(--head);font-weight:700;font-size:.82rem;padding:5px 12px;border-radius:8px;white-space:nowrap;flex-shrink:0}
.week-h h3{font-family:var(--head);font-weight:600;font-size:1.25rem;margin:0}
.week-desc{color:var(--ink-soft);margin-bottom:14px;line-height:1.6}
.wk-drills{border-top:1px solid var(--line);padding-top:14px}
.wk-label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--ink-mute);margin-bottom:10px}
.wk-drill{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--line);border-radius:9px;margin-bottom:7px;transition:border-color .15s,background .15s}
.wk-drill:hover{border-color:var(--green);background:var(--green-soft)}
.wk-drill-age{font-size:.7rem;font-weight:700;color:var(--green-deep);background:var(--green-soft);padding:3px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}
.wk-drill-name{font-weight:600;font-size:.92rem;flex:1}
.wk-arrow{color:var(--green);font-weight:700}

/* ---- Read-next cross-links ---- */
.readnext{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:22px}
@media(max-width:560px){.readnext{grid-template-columns:1fr}}
.readnext-card{display:flex;flex-direction:column;gap:4px;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:18px;transition:border-color .15s,box-shadow .15s,transform .15s;box-shadow:var(--shadow)}
.readnext-card:hover{border-color:var(--green);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.rn-k{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--green-deep);background:var(--green-soft);padding:3px 9px;border-radius:20px;align-self:flex-start}
.rn-t{font-family:var(--head);font-weight:600;font-size:1.05rem;line-height:1.25;margin-top:4px}
.readnext-card .rarrow{color:var(--green);font-weight:700;font-size:.85rem;margin-top:auto}

/* ---- Start-here page ---- */
.start-hero{background:linear-gradient(150deg,#136336,#1f8a4c);color:#fff;padding:64px 24px 56px;position:relative;overflow:hidden}
.start-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 30%,rgba(255,255,255,.12),transparent 55%);pointer-events:none}
.start-hero-inner{max-width:920px;margin:0 auto;position:relative;text-align:center}
.start-eyebrow{display:inline-block;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;background:rgba(255,255,255,.18);color:#fff;padding:7px 16px;border-radius:30px;margin-bottom:18px}
.start-hero h1{font-family:var(--head);font-weight:700;font-size:3rem;line-height:1.08;letter-spacing:-.02em;color:#fff;margin-bottom:18px}
@media(max-width:600px){.start-hero h1{font-size:2.1rem}}
.start-lede{font-size:1.18rem;color:#e8f4ec;max-width:65ch;margin:0 auto 24px;line-height:1.6}
.start-trust{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;font-size:.85rem;color:#c5e6d2;font-weight:600}
.start-trust span{white-space:nowrap}

.start-h2{font-family:var(--head);font-weight:600;font-size:1.85rem;letter-spacing:-.01em;margin-bottom:14px}
.start-p{color:var(--ink-soft);font-size:1.05rem;margin-bottom:24px;max-width:70ch}

/* Age starter cards */
.age-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:48px}
@media(max-width:760px){.age-grid{grid-template-columns:1fr}}
.age-starter{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:var(--shadow);transition:box-shadow .15s,transform .15s}
.age-starter:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.age-band{display:inline-block;font-family:var(--head);font-weight:700;font-size:1.3rem;color:var(--green-deep);background:var(--green-soft);padding:6px 16px;border-radius:30px;margin-bottom:10px}
.age-tagline{color:var(--ink-soft);font-size:.95rem;margin-bottom:18px;line-height:1.5}
.starter-block{padding:14px 0;border-top:1px solid var(--line)}
.starter-block:first-of-type{padding-top:14px}
.starter-block h4{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-mute);margin-bottom:9px}
.starter-link{color:var(--green-deep);font-weight:700;font-size:.95rem;display:inline-block}
.starter-link:hover{color:var(--green)}
.starter-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.starter-list li a{color:var(--ink);font-weight:600;font-size:.92rem;display:inline-flex;align-items:center;gap:6px;padding-left:14px;position:relative}
.starter-list li a::before{content:"•";position:absolute;left:0;color:var(--green);font-weight:800}
.starter-list li a:hover{color:var(--green-deep)}

/* How it works */
.how-it-works{margin:48px 0 56px;padding:36px;background:linear-gradient(150deg,var(--green-soft),#fff);border:1px solid var(--line);border-radius:20px}
.hiw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:20px}
@media(max-width:760px){.hiw-grid{grid-template-columns:1fr}}
.hiw-step{background:#fff;border-radius:14px;padding:22px;border:1px solid var(--line)}
.hiw-num{width:38px;height:38px;background:var(--green);color:#fff;border-radius:50%;display:grid;place-items:center;font-family:var(--head);font-weight:800;font-size:1.15rem;margin-bottom:12px}
.hiw-step h3{font-family:var(--head);font-weight:600;font-size:1.15rem;margin-bottom:6px}
.hiw-step p{color:var(--ink-soft);font-size:.92rem;line-height:1.55}

/* Essential 5 drills */
.essentials{display:flex;flex-direction:column;gap:14px;margin-bottom:48px}
.essential-card{display:flex;gap:18px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;transition:border-color .15s,box-shadow .15s,transform .15s}
.essential-card:hover{border-color:var(--green);box-shadow:var(--shadow);transform:translateY(-1px)}
.essential-num{flex-shrink:0;width:42px;height:42px;background:var(--navy);color:#fff;border-radius:12px;display:grid;place-items:center;font-family:var(--head);font-weight:800;font-size:1.2rem}
.essential-card h3{font-family:var(--head);font-weight:600;font-size:1.18rem;margin-bottom:6px}
.essential-card p{color:var(--ink-soft);font-size:.92rem;margin-bottom:10px;line-height:1.55}
.essential-card .rarrow{color:var(--green);font-weight:700;font-size:.85rem}

.start-faq{margin-bottom:48px;max-width:760px}
.start-next{padding:36px;background:var(--card);border:1px solid var(--line);border-radius:18px;text-align:center;box-shadow:var(--shadow)}
.start-next .home-cta{justify-content:center;margin-top:8px}
