/* FractionSteps — shared styles. Palette: graph paper & pencil. */
@import url('https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,400;0,600;0,700;1,500&family=JetBrains+Mono:wght@400;500;700&display=swap');
:root{
  --ink:#1d2433;--ink-soft:#465067;--paper:#fbfaf6;--paper-2:#f3f1e8;--line:#e4e0d2;
  --amber:#e0892b;--amber-d:#b9650f;--num:#2f6f9f;--den:#b8537a;--good:#3f8f5e;
  --radius:14px;--maxw:1080px;
  --mono:'JetBrains Mono',ui-monospace,monospace;--serif:'Spectral',Georgia,serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:26px 26px;background-position:-1px -1px;line-height:1.6;-webkit-font-smoothing:antialiased}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
a{color:var(--amber-d);text-decoration:none}a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

header{background:rgba(251,250,246,.86);backdrop-filter:saturate(140%) blur(6px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.bar{display:flex;align-items:center;justify-content:space-between;height:62px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:700;font-size:21px;color:var(--ink)}
.logo .frac{display:inline-flex;flex-direction:column;align-items:center;font-family:var(--mono);font-weight:700;font-size:12px;line-height:1.05;color:var(--amber-d)}
.logo .frac span:first-child{border-bottom:2px solid var(--amber);padding:0 3px}
.logo .frac span:last-child{padding-top:1px}
nav.links{display:flex;gap:26px;font-size:14px;font-weight:500}
nav.links a{color:var(--ink-soft)}nav.links a:hover{color:var(--amber-d);text-decoration:none}
.menu-btn{display:none;background:none;border:0;font-size:24px;color:var(--ink);cursor:pointer}
@media(max-width:760px){nav.links{display:none}.menu-btn{display:block}}

.crumbs{font-family:var(--mono);font-size:12px;color:var(--ink-soft);padding:18px 0 0}
.crumbs a{color:var(--ink-soft)}

.pagehead{padding:26px 0 20px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-d);font-weight:500;margin-bottom:14px}
.pagehead h1{font-family:var(--serif);font-weight:700;font-size:clamp(30px,4.6vw,46px);line-height:1.05;letter-spacing:-.01em;color:var(--ink)}
.pagehead h1 em{font-style:italic;color:var(--amber-d)}
.pagehead p.lead{font-size:clamp(16px,2vw,18px);color:var(--ink-soft);margin-top:14px;max-width:56ch}
h1 em{font-style:italic;color:var(--amber-d)}

/* calculator shell */
.calc-shell{margin-top:8px;display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 1px 0 #fff inset,0 18px 50px -28px rgba(29,36,51,.45);overflow:hidden}
@media(max-width:820px){.calc-shell{grid-template-columns:1fr}}
.calc-input{padding:26px;border-right:1px solid var(--line);background:var(--paper-2)}
@media(max-width:820px){.calc-input{border-right:0;border-bottom:1px solid var(--line)}}
.calc-input h2,.calc-work h2{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-bottom:18px}
.expr{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.frac-input{display:flex;flex-direction:column;align-items:center;gap:4px}
.frac-input input{width:74px;text-align:center;font-family:var(--mono);font-weight:700;font-size:22px;color:var(--ink);background:var(--paper);border:1.5px solid var(--line);border-radius:9px;padding:9px 6px;outline:none;transition:border-color .15s,box-shadow .15s}
.frac-input input:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(224,137,43,.18)}
.frac-input input.num{color:var(--num)}.frac-input input.den{color:var(--den)}
.frac-bar-line{width:74px;height:0;border-top:2.5px solid var(--ink);margin:2px 0}
.op-select{display:flex;gap:6px}
.op-btn{font-family:var(--mono);font-weight:700;font-size:20px;width:42px;height:42px;border:1.5px solid var(--line);background:var(--paper);border-radius:9px;color:var(--ink-soft);cursor:pointer;transition:all .14s;display:flex;align-items:center;justify-content:center}
.op-btn:hover{border-color:var(--amber);color:var(--amber-d)}
.op-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.eq{font-family:var(--mono);font-weight:700;font-size:24px;color:var(--ink-soft)}
.hint{margin-top:18px;font-size:13px;color:var(--ink-soft)}
.hint code{font-family:var(--mono);background:var(--paper);border:1px solid var(--line);border-radius:5px;padding:1px 6px;color:var(--amber-d)}
.calc-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.btn{font-family:var(--sans);font-weight:600;font-size:14px;border-radius:10px;padding:11px 18px;cursor:pointer;border:1.5px solid var(--ink);transition:all .15s;display:inline-flex;align-items:center;gap:8px}
.btn.primary{background:var(--ink);color:var(--paper)}.btn.primary:hover{background:#000;text-decoration:none}
.btn.ghost{background:transparent;color:var(--ink)}.btn.ghost:hover{background:var(--ink);color:var(--paper);text-decoration:none}

.calc-work{padding:26px;background:var(--paper);min-height:300px}
.result-top{display:flex;align-items:baseline;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.result-top .label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.result-frac{display:inline-flex;flex-direction:column;align-items:center;font-family:var(--mono);font-weight:700;line-height:1.05}
.result-frac .rn{font-size:30px;color:var(--ink);padding:0 8px}
.result-frac .rb{height:0;border-top:3px solid var(--amber);width:100%}
.result-frac .rd{font-size:30px;color:var(--ink);padding:2px 8px 0}
.result-dec{font-family:var(--mono);font-size:14px;color:var(--ink-soft);align-self:center}
.steps{list-style:none;display:flex;flex-direction:column;gap:14px}
.step{display:grid;grid-template-columns:26px 1fr;gap:12px;align-items:start;opacity:0;transform:translateY(6px);animation:rise .42s ease forwards}
@keyframes rise{to{opacity:1;transform:none}}
.step .n{font-family:var(--mono);font-weight:700;font-size:12px;color:var(--paper);background:var(--ink);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;margin-top:2px}
.step .body{font-size:14.5px;color:var(--ink)}
.step.err .n{background:var(--den)}
.f{display:inline-flex;flex-direction:column;vertical-align:middle;text-align:center;font-family:var(--mono);font-weight:700;font-size:13px;line-height:1.02;margin:0 2px}
.f .t{border-bottom:2px solid var(--ink);padding:0 4px}.f .b{padding:0 4px}
.viz{margin-top:22px;padding-top:20px;border-top:1px dashed var(--line)}
.viz h3{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:12px;font-weight:700}
.bars{display:flex;flex-direction:column;gap:10px}
.barrow{display:flex;align-items:center;gap:12px}
.barrow .cap{font-family:var(--mono);font-size:12px;color:var(--ink-soft);width:52px;text-align:right}
.barsvg{flex:1}

/* content sections */
.section{padding:44px 0}
.section h2{font-family:var(--serif);font-weight:700;font-size:clamp(24px,3.2vw,30px);color:var(--ink);margin-bottom:14px}
.section h3{font-family:var(--serif);font-weight:600;font-size:21px;margin:26px 0 8px}
.section p{color:var(--ink-soft);max-width:64ch;margin-bottom:14px}
.section .prose strong{color:var(--ink)}
.examples{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:8px}
.exq{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:14px;font-family:var(--mono);font-size:14px}
.exq .q{color:var(--ink-soft);margin-bottom:6px}
.exq .a{color:var(--amber-d);font-weight:700}

.faq{display:flex;flex-direction:column;gap:0}
.faq details{border-bottom:1px solid var(--line);padding:14px 0}
.faq summary{font-weight:600;cursor:pointer;color:var(--ink);font-size:15.5px;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:'+';color:var(--amber-d);font-family:var(--mono);font-weight:700;margin-right:10px}
.faq details[open] summary::before{content:'−'}
.faq p{margin-top:10px}

.related{padding:24px 0 0}
.related h2{font-family:var(--serif);font-size:22px;margin-bottom:14px}
.oplist{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media(max-width:820px){.oplist{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.oplist{grid-template-columns:1fr}}
.opcard{display:flex;align-items:center;gap:11px;background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:13px 14px;color:var(--ink);font-weight:600;font-size:14px;transition:border-color .15s,background .15s}
.opcard:hover{border-color:var(--amber);background:var(--paper-2);text-decoration:none}
.opcard .sym{font-family:var(--mono);font-weight:700;color:var(--amber-d);font-size:16px;width:20px;text-align:center}

footer{border-top:1px solid var(--line);background:var(--paper-2);padding:46px 0 28px;font-size:14px;color:var(--ink-soft);margin-top:48px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:30px}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-col{display:flex;flex-direction:column;gap:9px}
.foot-col h4{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);font-weight:700;margin-bottom:4px}
.foot-col a{color:var(--ink-soft);font-weight:600;font-size:14px}
.foot-col a:hover{color:var(--amber-d);text-decoration:none}
.foot-brand .logo{margin-bottom:12px}
.foot-tag{font-family:var(--sans);font-weight:400;color:var(--ink-soft);font-size:13.5px;max-width:34ch;line-height:1.55}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:34px;padding-top:20px;border-top:1px solid var(--line);font-size:13px}
.foot-bottom a{color:var(--ink-soft)}

.ad-slot:empty{display:none}
#ad-desktop,#ad-mobile{margin:24px auto;display:flex;align-items:center;justify-content:center}
#ad-desktop{max-width:728px}
#ad-mobile{display:none;max-width:320px}
@media(max-width:760px){#ad-desktop{display:none}#ad-mobile:not(:empty){display:flex}}

/* ---------- worksheet generator ---------- */
.ws-config{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;align-items:end;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin-bottom:16px}
.ws-field{display:flex;flex-direction:column;gap:6px}
.ws-field label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.ws-field select,.ws-field input{font-family:var(--sans);font-size:15px;padding:10px;border:1.5px solid var(--line);border-radius:9px;background:var(--paper);color:var(--ink);outline:none}
.ws-field select:focus,.ws-field input:focus{border-color:var(--amber)}
.ws-config .btn{height:42px}
.ws-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.ws-sheets{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.ws-sheets{grid-template-columns:1fr}}
.ws-sheet{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:0 14px 40px -30px rgba(29,36,51,.5)}
.ws-keysheet{background:var(--paper-2)}
.ws-h{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-bottom:16px;border-bottom:1px solid var(--line);padding-bottom:10px}
.ws-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px}
@media(max-width:480px){.ws-grid{grid-template-columns:1fr}}
.ws-cell{display:flex;align-items:center;gap:6px;font-size:15px;color:var(--ink)}
.ws-num{font-family:var(--mono);color:var(--ink-soft);font-size:13px;min-width:22px}
.ws-prob{display:inline-flex;align-items:center;gap:5px}
.ws-cell .f{font-size:14px}
@media print{
  header,footer,.crumbs,.related,.ws-config,.ws-actions,#ad-desktop,#ad-mobile,.pagehead .lead,.faq,.section h2{display:none!important}
  body{background:#fff}
  .ws-sheets{grid-template-columns:1fr}
  .ws-sheet{box-shadow:none;border:none;page-break-after:always}
}

/* ---------- animated walkthrough ---------- */
.anim-panel{margin-top:16px;background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:14px}
.anim-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.anim-label{font-size:13px;color:var(--ink-soft);flex:1}
.anim-play{font-family:var(--mono);font-size:12px;font-weight:700;border:1.5px solid var(--ink);background:var(--ink);color:var(--paper);border-radius:8px;padding:6px 12px;cursor:pointer;transition:background .15s}
.anim-play:hover{background:#000}
.anim-svg{display:block}

/* ---------- practice mode ---------- */
.pr-config{display:flex;flex-wrap:wrap;gap:16px;align-items:end;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin-bottom:18px}
.pr-stats{display:flex;gap:22px;margin-left:auto}
.pr-stat{display:flex;flex-direction:column;align-items:center}
.pr-statn{font-family:var(--mono);font-weight:700;font-size:22px;color:var(--amber-d)}
.pr-statl{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.pr-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;box-shadow:0 18px 50px -32px rgba(29,36,51,.5)}
.pr-question{font-family:var(--mono);font-weight:700;font-size:30px;color:var(--ink);display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:26px}
.pr-question .f{font-size:30px}
.pr-question .pr-op{color:var(--amber-d)}.pr-question .pr-eq{color:var(--ink-soft)}
.pr-answer{display:flex;align-items:center;gap:16px;justify-content:center;flex-wrap:wrap}
.pr-feedback{margin-top:22px;padding:18px 20px;border-radius:10px;font-size:15px}
.pr-feedback.ok{background:#edf6ef;border:1px solid #bfe0c8;color:#256b3c}
.pr-feedback.no{background:#fdeef2;border:1px solid #f0c5d3;color:#9a3354}
.pr-feedback.warn{background:var(--paper-2);border:1px solid var(--line);color:var(--ink-soft)}
.pr-feedback .f{font-size:14px}
.pr-steps{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:9px}
.pr-steps li{display:flex;gap:10px;align-items:flex-start;color:var(--ink);font-size:14px}
.pr-sn{font-family:var(--mono);font-weight:700;font-size:11px;background:var(--ink);color:var(--paper);border-radius:50%;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}

/* ---------- word problems ---------- */
.wp-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;box-shadow:0 18px 50px -32px rgba(29,36,51,.5)}
.wp-cat{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-d);font-weight:700;margin-bottom:12px}
.wp-story{font-family:var(--serif);font-size:21px;line-height:1.5;color:var(--ink);max-width:60ch;margin-bottom:20px}
.wp-setup{font-family:var(--mono);font-weight:700;font-size:24px;color:var(--ink-soft);display:flex;align-items:center;gap:12px;margin-bottom:24px}
.wp-setup .wp-op{color:var(--amber-d)}
.wp-solution{margin-top:24px;padding-top:22px;border-top:1px dashed var(--line)}
.wp-answer{margin-top:18px;padding:14px 18px;background:#edf6ef;border:1px solid #bfe0c8;border-radius:10px;color:#256b3c;font-size:16px}
.wp-answer .f{font-size:14px}
.wp-actions{margin-top:18px}

/* ---------- embed page ---------- */
.embed-code{background:var(--ink);color:#f3f1e8;border-radius:10px;padding:18px 20px;overflow-x:auto;font-family:var(--mono);font-size:13px;line-height:1.6;margin:6px 0 18px}
.embed-code code{white-space:pre}

/* ---------- number pages (Phase 4) ---------- */
.np-answer{display:flex;flex-direction:column;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 24px;margin-bottom:20px;box-shadow:0 14px 40px -30px rgba(29,36,51,.5)}
.np-q{font-family:var(--mono);font-size:13px;letter-spacing:.06em;color:var(--ink-soft)}
.np-big{font-family:var(--mono);font-weight:700;font-size:46px;color:var(--amber-d)}
.np-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

/* ---------- consent banner ---------- */
.consent-bar{position:fixed;left:0;right:0;bottom:0;z-index:200;background:var(--ink);color:#f3f1e8;box-shadow:0 -8px 30px -16px rgba(0,0,0,.5)}
.consent-inner{max-width:var(--maxw);margin:0 auto;padding:16px 22px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.consent-inner p{margin:0;font-size:13.5px;color:#e8e5da;flex:1;min-width:240px;line-height:1.5}
.consent-inner a{color:var(--amber);font-weight:600}
.consent-btns{display:flex;gap:10px;flex-wrap:wrap}
.consent-reject,.consent-accept{font-family:var(--sans);font-weight:600;font-size:13.5px;border-radius:8px;padding:9px 16px;cursor:pointer;border:1.5px solid #4a5266}
.consent-reject{background:transparent;color:#e8e5da}
.consent-reject:hover{background:#2a3142}
.consent-accept{background:var(--amber);color:#241502;border-color:var(--amber)}
.consent-accept:hover{background:#ed9a3f}

/* ---------- legal/contact prose pages ---------- */
.legal{padding:10px 0 30px}
.legal h2{font-family:var(--serif);font-weight:700;font-size:24px;margin:28px 0 10px;color:var(--ink)}
.legal h3{font-family:var(--serif);font-weight:600;font-size:18px;margin:20px 0 6px}
.legal p,.legal li{color:var(--ink-soft);max-width:68ch;font-size:15px;line-height:1.65}
.legal ul{margin:8px 0 14px 22px;display:flex;flex-direction:column;gap:6px}
.legal a{color:var(--amber-d)}
.legal .updated{font-family:var(--mono);font-size:12px;color:var(--ink-soft);margin-bottom:8px}

/* worksheet count validation note */
.ws-note{display:block;margin-top:5px;font-family:var(--mono);font-size:11px;color:var(--den);font-weight:600}

/* ---------- fraction playground (kids' learning) ---------- */
.pg-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.pg-toolgroup{display:flex;align-items:center;gap:8px}
.pg-toollabel{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.pg-toggle{font-family:var(--sans);font-weight:700;font-size:14px;border:2px solid var(--line);background:var(--paper);border-radius:10px;padding:8px 16px;cursor:pointer;color:var(--ink-soft);transition:all .14s}
.pg-toggle:hover{border-color:var(--amber)}
.pg-toggle.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.pg-stage{display:grid;grid-template-columns:1fr auto 1fr;gap:20px;align-items:center}
@media(max-width:720px){.pg-stage{grid-template-columns:1fr;gap:14px}}
.pg-shape-card{background:#fff;border:2px solid var(--line);border-radius:18px;padding:22px 20px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 16px 44px -30px rgba(29,36,51,.5)}
.pg-shape{width:100%;display:flex;justify-content:center;align-items:center;min-height:96px;touch-action:none}
.pg-svg{max-width:100%}
.pg-svg .pg-cell{transition:fill .12s}
.pg-controls{display:flex;align-items:center;gap:14px}
.pg-dbtn{font-family:var(--mono);font-weight:700;font-size:24px;width:46px;height:46px;border:2px solid var(--ink);background:var(--paper);border-radius:12px;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .14s;-webkit-tap-highlight-color:transparent}
.pg-dbtn:hover{background:var(--ink);color:var(--paper)}
.pg-dbtn:active{transform:scale(.94)}
.pg-dwrap{font-family:var(--mono);font-size:14px;color:var(--ink-soft);min-width:74px;text-align:center}
.pg-dval{font-weight:700;font-size:18px;color:var(--ink)}
.pg-bigfrac{margin-top:2px}

.pg-frac{display:inline-flex;flex-direction:column;align-items:center;font-family:var(--mono);font-weight:700;line-height:1.05}
.pg-frac .pg-n{font-size:30px;color:var(--ink);padding:0 8px}
.pg-frac .pg-bar{height:0;border-top:3px solid var(--ink);width:100%}
.pg-frac .pg-d{font-size:30px;color:var(--ink);padding:2px 8px 0}

.pg-ops{display:flex;flex-direction:column;gap:8px;align-items:center}
@media(max-width:720px){.pg-ops{flex-direction:row;justify-content:center}}
.pg-op{font-family:var(--mono);font-weight:700;font-size:24px;width:52px;height:52px;border:2px solid var(--line);background:var(--paper);border-radius:14px;color:var(--ink-soft);cursor:pointer;transition:all .14s;-webkit-tap-highlight-color:transparent}
.pg-op:hover{border-color:var(--amber);color:var(--amber-d)}
.pg-op:active{transform:scale(.94)}
.pg-op.on{background:var(--amber);color:#241502;border-color:var(--amber)}

.pg-equals{text-align:center;font-family:var(--mono);font-weight:700;font-size:34px;color:var(--ink-soft);margin:18px 0}
.pg-resultcard{background:var(--paper-2);border:2px solid var(--line);border-radius:18px;padding:26px;display:flex;justify-content:center}
.pg-result{display:flex;flex-direction:column;align-items:center;gap:16px}
.pg-result-shape{width:100%;max-width:360px;display:flex;justify-content:center}
.pg-result-num{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;justify-content:center}
.pg-result-num .pg-frac .pg-n,.pg-result-num .pg-frac .pg-d{color:var(--amber-d)}
.pg-result-num .pg-frac .pg-bar{border-top-color:var(--amber)}
.pg-result-dec{font-family:var(--mono);font-size:16px;color:var(--ink-soft)}
.pg-result-msg{font-size:15px;color:var(--ink-soft)}

.pg-howto{margin-top:34px}
.pg-howlist{list-style:none;display:flex;flex-direction:column;gap:10px;counter-reset:pg}
.pg-howlist li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-soft);font-size:15px;counter-increment:pg}
.pg-howlist li::before{content:counter(pg);font-family:var(--mono);font-weight:700;font-size:12px;background:var(--amber);color:#241502;border-radius:50%;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.pg-howlist strong{color:var(--ink)}
.pg-steps-wrap{margin-top:30px}

/* ---------- guided (scaffolded) practice ---------- */
.gp-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;box-shadow:0 18px 50px -32px rgba(29,36,51,.5)}
.gp-setup{font-family:var(--mono);font-weight:700;font-size:26px;color:var(--ink-soft);display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:18px;padding-bottom:18px;border-bottom:1px dashed var(--line)}
.gp-setup .gp-op{color:var(--amber-d)}.gp-setup .gp-eq{color:var(--ink-soft)}
.gp-setup .f{font-size:26px}
.gp-stepno{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-d);font-weight:700;text-align:center;margin-bottom:8px}
.gp-prompt{font-family:var(--serif);font-size:20px;line-height:1.45;color:var(--ink);text-align:center;max-width:50ch;margin:0 auto 6px}
.gp-prompt .f{font-size:16px}
.gp-hint{font-size:13px;color:var(--ink-soft);text-align:center;max-width:48ch;margin:0 auto 20px}
.gp-input-area{display:flex;justify-content:center;margin-bottom:18px;min-height:48px}
.gp-num{width:90px;text-align:center;font-family:var(--mono);font-weight:700;font-size:24px;color:var(--ink);background:var(--paper);border:1.5px solid var(--line);border-radius:9px;padding:9px 6px;outline:none}
.gp-num:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(224,137,43,.18)}
.gp-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.gp-feedback{margin-top:20px;padding:16px 18px;border-radius:10px;font-size:15px;text-align:center}
.gp-feedback.ok{background:#edf6ef;border:1px solid #bfe0c8;color:#256b3c}
.gp-feedback.no{background:#fdeef2;border:1px solid #f0c5d3;color:#9a3354}
.gp-feedback.warn{background:var(--paper-2);border:1px solid var(--line);color:var(--ink-soft)}
.gp-feedback .f{font-size:14px}
.gp-trail-wrap{margin-top:30px}
.gp-trail{list-style:none;display:flex;flex-direction:column;gap:8px}
.gp-trail li{display:flex;gap:11px;align-items:flex-start;font-size:14px;color:var(--ink-soft);padding:8px 0;border-bottom:1px solid var(--line)}
.gp-tnum{font-family:var(--mono);font-weight:700;font-size:11px;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--paper)}
.gp-trail-ok .gp-tnum{background:var(--good)}
.gp-trail-no .gp-tnum{background:var(--den)}
.gp-trail .f{font-size:13px}

/* ---------- method switch (LCD / butterfly) ---------- */
.method-switch{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.method-label{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.method-btn{font-family:var(--sans);font-weight:600;font-size:12.5px;border:1.5px solid var(--line);background:var(--paper);border-radius:8px;padding:6px 12px;cursor:pointer;color:var(--ink-soft);transition:all .14s}
.method-btn:hover{border-color:var(--amber)}
.method-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.method-info{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:1.5px solid var(--line);color:var(--ink-soft);font-family:var(--mono);font-weight:700;font-size:12px;text-decoration:none}
.method-info:hover{border-color:var(--amber-d);color:var(--amber-d);text-decoration:none}

/* ---------- real-world view ---------- */
.rwv{margin-top:18px}
.rwv-toggle{font-family:var(--sans);font-weight:600;font-size:14px;border:1.5px solid var(--line);background:var(--paper-2);border-radius:10px;padding:10px 16px;cursor:pointer;color:var(--ink);width:100%;text-align:left;transition:all .14s;display:flex;align-items:center;gap:8px}
.rwv-toggle:hover{border-color:var(--amber)}
.rwv-toggle::after{content:'▾';margin-left:auto;color:var(--ink-soft);transition:transform .2s}
.rwv-toggle.open::after{transform:rotate(180deg)}
.rwv-body{margin-top:12px;display:flex;flex-direction:column;gap:10px}
.rwv-item{display:flex;align-items:center;gap:12px;background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:11px 14px}
.rwv-ic{width:34px;height:34px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;font-family:var(--mono);font-weight:700;background:var(--paper-2)}
.rwv-ic-pct{background:#e7f0f6;color:#2f6f9f}
.rwv-ic-money{background:#e9f4ec;color:#256b3c}
.rwv-ic-time{background:#f6efe2;color:#b9650f}
.rwv-txt{font-size:14px;color:var(--ink);line-height:1.4}
.rwv-kind{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-bottom:2px}

/* ---------- multi-fraction calculator ---------- */
.mf-ops{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.mf-opbtn{font-family:var(--sans);font-weight:600;font-size:13.5px;border:1.5px solid var(--line);background:var(--paper);border-radius:9px;padding:8px 14px;cursor:pointer;color:var(--ink-soft);transition:all .14s}
.mf-opbtn:hover{border-color:var(--amber)}
.mf-opbtn.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.mf-terms{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.mf-term{display:flex;align-items:center;gap:10px}
.mf-op{font-family:var(--mono);font-weight:700;font-size:22px;color:var(--amber-d)}
.mf-controls{display:flex;gap:10px;flex-wrap:wrap}
.mf-controls .btn{font-size:13.5px;padding:8px 14px}
.mf-controls .btn:disabled{opacity:.4;cursor:not-allowed}
.mf-msg{font-size:14px;color:var(--ink-soft)}

/* ---------- proportion / solve-for-x ---------- */
.prop-expr{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.prop-expr .frac-input input{width:70px}

/* ---------- PDF download button ---------- */
.pdf-row{margin-top:18px}
.pdf-btn{font-size:14px;font-weight:600}

/* ---------- guides hub + guide pages ---------- */
.guide-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px}
@media(max-width:680px){.guide-grid{grid-template-columns:1fr}}
.guide-card{display:flex;flex-direction:column;gap:6px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 22px;text-decoration:none;transition:all .15s;box-shadow:0 14px 40px -34px rgba(29,36,51,.5)}
.guide-card:hover{border-color:var(--amber);transform:translateY(-2px);text-decoration:none}
.guide-card-h{font-family:var(--serif);font-weight:700;font-size:18px;color:var(--ink);line-height:1.25}
.guide-card-d{font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.guide-lead{font-family:var(--serif);font-size:20px;line-height:1.5;color:var(--ink);max-width:62ch;margin-bottom:20px}
.guide-cta{margin-bottom:28px}
.guide-steps{list-style:none;display:flex;flex-direction:column;gap:14px;margin:10px 0 26px}
.guide-steps li{display:flex;gap:14px;align-items:flex-start;color:var(--ink-soft);font-size:15px;line-height:1.55}
.guide-steps .pr-sn{font-family:var(--mono);font-weight:700;font-size:12px;background:var(--ink);color:var(--paper);border-radius:50%;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.guide-steps strong{color:var(--ink)}
.guide-example{background:var(--paper-2);border:1px solid var(--line);border-left:3px solid var(--amber);border-radius:10px;padding:16px 18px;font-size:15px;color:var(--ink);max-width:64ch;margin-bottom:26px}
.guide-mistakes{margin:10px 0 26px 20px;display:flex;flex-direction:column;gap:8px;color:var(--ink-soft);font-size:15px}
.guide h2.ws-h{margin-top:28px}

/* ---------- article extras (guide tables, prose, related) ---------- */
.guide-p{color:var(--ink-soft);font-size:15.5px;line-height:1.65;max-width:64ch;margin:6px 0 8px}
.guide-table{border-collapse:collapse;margin:14px 0 24px;font-family:var(--mono);font-size:14px;min-width:280px}
.guide-table th{background:var(--ink);color:var(--paper);text-align:left;padding:9px 18px;font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.guide-table td{padding:9px 18px;border-bottom:1px solid var(--line);color:var(--ink)}
.guide-table tbody tr:nth-child(even){background:var(--paper-2)}
.guide-related{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.guide-related a{display:inline-block;background:var(--paper-2);border:1px solid var(--line);border-radius:9px;padding:9px 16px;font-weight:600;font-size:14px;color:var(--ink);text-decoration:none;transition:all .14s}
.guide-related a:hover{border-color:var(--amber);color:var(--amber-d);text-decoration:none}

/* ---------- free tools / network directory ---------- */
.ft-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px}
@media(max-width:680px){.ft-grid{grid-template-columns:1fr}}
.ft-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:0 14px 40px -34px rgba(29,36,51,.5)}
.ft-name{display:block;font-family:var(--serif);font-weight:700;font-size:17px;color:var(--ink);text-decoration:none;margin-bottom:2px}
.ft-name:hover{color:var(--amber-d)}
.ft-url{display:block;font-family:var(--mono);font-size:12.5px;color:#1a55d6;text-decoration:underline;word-break:break-all;margin-bottom:8px}
.ft-url:hover{color:#0b3aa6}
.ft-desc{font-size:14px;color:var(--ink-soft);line-height:1.55;margin:0}
