/* components.css — reusable UI: stepper, hub cards, search, accordion, steps, tips, reference */

/* ── stepper / pipeline (wayfinding, top of every page) ── */
.stepper{display:flex;align-items:flex-start;margin:0 0 var(--s8)}
.stepper .step{position:relative;flex:1 1 0;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;text-decoration:none}
.stepper .step::before{content:"";position:absolute;top:15px;right:50%;width:100%;height:1.5px;background:var(--line2);z-index:0}
.stepper .step:first-child::before{display:none}
.stepper .dot{position:relative;z-index:1;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:var(--fs-caption);font-weight:600;background:var(--bg);border:1.5px solid var(--line2);color:var(--muted)}
.stepper .lb{font-size:var(--fs-micro);text-transform:uppercase;letter-spacing:.08em;font-weight:600;color:var(--faint)}
.stepper .step.done .dot{color:var(--text)}
.stepper .step.current .dot{background:var(--accent);border-color:var(--accent);color:var(--bg)}
.stepper .step.current .lb{color:var(--accent)}
.stepper .step.soon{opacity:.4}
.stepper a.step:hover .dot{border-color:var(--accent)}
.stepper a.step:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}

/* ── home: hub cards ── */
.cardgrid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4)}
.scard{display:block;background:var(--surf);border:1px solid var(--line);border-radius:var(--radius);padding:var(--s5);text-decoration:none;color:inherit;transition:.15s}
.scard:hover{border-color:var(--faint);background:var(--surf2)}
.scard-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s4)}
.scard-ic{width:46px;height:46px;border-radius:12px;background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:18px;font-weight:600}
.scard-meta{font-size:var(--fs-micro);text-transform:uppercase;letter-spacing:.07em;color:var(--accent);border:1px solid var(--line2);border-radius:999px;padding:3px 11px}
.scard-t{font-family:var(--display);font-size:var(--fs-h3);font-weight:600;color:var(--text);margin:0 0 var(--s2);letter-spacing:-.01em}
.scard-d{font-size:var(--fs-body);line-height:1.6;color:var(--muted);margin:0}
.scard.soon{opacity:.55;pointer-events:none;border-style:dashed}
.scard.soon .scard-ic{background:var(--surf2);color:var(--faint)}
.scard.soon .scard-meta{color:var(--faint);border-color:var(--line)}
.scard.soon .scard-t{color:var(--muted)}
@media(max-width:560px){.cardgrid{grid-template-columns:1fr}}

/* ── header row (title + toggle) ── */
.head-row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--s4)}
.head-row.spaced-row{margin-top:var(--section-gap);margin-bottom:var(--s5);align-items:center}
.head-row.spaced-row .section-label{margin:0}
.head-row.spaced-row .toggle{margin-top:0}

/* expand/collapse toggle */
.toggle{flex:0 0 auto;display:inline-flex;align-items:center;gap:var(--s2);background:transparent;border:1px solid var(--line2);color:var(--accent);font:inherit;font-size:var(--fs-caption);font-weight:500;padding:7px 14px;border-radius:999px;cursor:pointer;transition:.15s;white-space:nowrap}
.toggle:hover{background:var(--surf2);border-color:var(--faint)}
.toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.tg-ic{width:7px;height:7px;border-right:1.7px solid var(--accent);border-bottom:1.7px solid var(--accent);transform:rotate(45deg);transition:transform .2s ease}
.toggle.open .tg-ic{transform:rotate(-135deg)}

/* ── search / filter ── */
.search{margin:0 0 var(--s4)}
.search input{width:100%;background:var(--surf);border:1px solid var(--line2);border-radius:12px;color:var(--text);font:inherit;font-size:var(--fs-body);padding:14px 16px;transition:.15s}
.search input::placeholder{color:var(--faint)}
.search input:focus{outline:none;border-color:var(--accent)}
.search input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.noresults{color:var(--muted);font-size:var(--fs-body);margin:0 0 18px}
.hint{color:var(--muted);font-size:var(--fs-body);margin:0 0 18px}
.hint .opts{margin:8px 0 0;padding-left:18px;list-style:none}
.hint .opts li{margin:5px 0;position:relative}
.hint .opts li::before{content:"→";position:absolute;left:-18px;color:var(--accent)}

/* example chips (seed the search) */
.chips{display:flex;flex-wrap:wrap;gap:var(--s2);margin:0 0 var(--s4)}
.chip{font-family:var(--mono);font-size:var(--fs-caption);color:var(--accent);background:var(--accent-bg);border:1px solid var(--line2);border-radius:999px;padding:5px 13px;cursor:pointer;transition:.15s}
.chip:hover{border-color:var(--accent)}
.chip:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ── accordion (cards reserved for clickable affordances) ── */
.acc{display:flex;flex-direction:column;gap:var(--s2)}
.item{background:var(--surf);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.head{display:flex;align-items:center;gap:var(--s3);width:100%;background:transparent;border:0;cursor:pointer;text-align:left;font:inherit;color:inherit;padding:16px 20px}
.head:hover{background:var(--surf2)}
.head:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}
.chev{flex:0 0 auto;width:8px;height:8px;border-right:1.6px solid var(--accent);border-bottom:1.6px solid var(--accent);transform:rotate(-45deg);transition:transform .22s ease;margin:0 1px}
.item.open>.head .chev{transform:rotate(45deg)}
.fn{font-family:var(--mono);font-size:var(--fs-body);font-weight:600;color:var(--text)}
.tag{font-size:var(--fs-caption);color:var(--muted);margin-left:auto;text-align:right}
.match>.head{background:var(--accent-bg)}

.body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .26s ease}
.item.open>.body{grid-template-rows:1fr}
.inner{overflow:hidden}
.pad{padding:0 20px 18px 42px}

/* nested tree (subfolders) */
.tree{margin:6px 0 0;padding-left:20px;border-left:1px solid var(--line2);display:flex;flex-direction:column}
.tree>.item{position:relative;background:transparent;border:0;border-radius:0;overflow:visible}
.tree>.item::before{content:"";position:absolute;left:-20px;top:19px;width:15px;height:1px;background:var(--line2)}
.tree .head{padding:10px 0}
.tree .head:hover{background:transparent}
.tree .head:hover .sn{color:var(--accent)}
.sn{font-family:var(--mono);font-size:var(--fs-caption);font-weight:600;color:var(--text);transition:color .15s}
.tree .pad{padding:0 0 10px 20px}
.sd{font-size:var(--fs-caption);color:var(--muted);margin:0;line-height:1.65}

/* ── numbered steps (the DO zone — editorial, borderless) ── */
.steps{list-style:none;counter-reset:s;padding:0;margin:0;display:grid;gap:var(--s6)}
.steps li{counter-increment:s;display:grid;grid-template-columns:auto 1fr;gap:var(--s4);align-items:start}
.steps li::before{content:counter(s);font-family:var(--mono);font-size:var(--fs-lead);font-weight:600;color:var(--accent);line-height:1.35;min-width:18px}
.steps .st{display:block;font-size:var(--fs-body);color:var(--text);font-weight:600}
.steps .sx{display:block;font-size:var(--fs-body);color:var(--muted);margin-top:var(--s1);line-height:1.7;max-width:var(--measure)}
.steps b{color:var(--text);font-weight:600}

/* ── tag / naming legend (tasks inside each board column) ── */
.legend{list-style:none;padding:0;margin:0;display:grid;gap:var(--s3)}
.legend li{display:grid;grid-template-columns:88px 1fr;gap:var(--s4);align-items:baseline;font-size:var(--fs-body);color:var(--muted);line-height:1.6}
.legend .lc{font-family:var(--mono);color:var(--text);font-weight:600;font-size:var(--fs-caption)}
.legend b{color:var(--text);font-weight:600}
@media(max-width:560px){.legend li{grid-template-columns:1fr;gap:2px}}

/* ── tips (+ / −) ── */
.tips{display:flex;flex-direction:column;gap:var(--s3);margin-top:var(--s4);padding-top:var(--s4);border-top:1px solid var(--line2)}
.tips.first{margin-top:var(--s2);padding-top:0;border-top:0}
.tip{display:grid;grid-template-columns:18px 1fr;gap:var(--s3);align-items:start;font-size:var(--fs-body);color:var(--muted);line-height:1.65}
.tip .ic{font-size:17px;font-weight:600;line-height:1.3;text-align:center}
.tip.ok .ic{color:var(--ok)}
.tip.no .ic{color:var(--no)}
.tip b{color:var(--text);font-weight:600}

/* ── reference rows ── */
.ref{display:flex;flex-direction:column;gap:2px}
.ref>.item{background:transparent;border:0;border-radius:0;overflow:hidden}
.ref>.item>.head{padding:16px 4px}
.ref>.item>.head:hover{background:transparent}
.ref>.item>.head:hover .rl{color:var(--accent)}
.rl{font-size:var(--fs-body);font-weight:500;color:var(--text);transition:color .15s}
.ref .pad{padding:0 4px 18px 26px}
.rules{list-style:none;padding:0;margin:0;display:grid;gap:var(--s4)}
.rules li{font-size:var(--fs-body);color:var(--muted);line-height:1.65;padding-left:var(--s4);border-left:2px solid var(--line2)}
.rules li b{color:var(--accent)}

/* ── download card ── */
.download{display:flex;align-items:center;gap:var(--s4);padding:16px 20px;background:var(--surf);border:1px solid var(--line);border-radius:var(--radius);text-decoration:none;color:inherit;transition:.15s}
.download:hover{border-color:var(--accent);background:var(--surf2)}
.download .dl-ic{flex:0 0 auto;width:38px;height:38px;border-radius:var(--radius-sm);background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:19px;font-weight:600}
.download .dl-t{display:block;font-size:var(--fs-body);font-weight:500;color:var(--text)}
.download .dl-d{display:block;font-size:var(--fs-caption);color:var(--muted);margin-top:2px}

/* ── prev / next stage footer ── */
.pagenav{display:flex;justify-content:space-between;gap:18px;margin-top:var(--section-gap);padding-top:var(--s5);border-top:1px solid var(--line)}
.pagenav a,.pagenav .end{display:flex;flex-direction:column;gap:4px;text-decoration:none;max-width:49%}
.pagenav .end{margin-left:auto;text-align:right}
.pagenav .dir{font-size:var(--fs-micro);font-weight:600;text-transform:uppercase;letter-spacing:.13em;color:var(--faint)}
.pagenav .pt{font-size:var(--fs-body);font-weight:500;color:var(--muted);transition:color .15s}
.pagenav a:hover .pt{color:var(--accent)}
.pagenav .soon .pt{color:var(--faint);opacity:.7}

/* ── dismissible setup banner ── */
.banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--accent-bg);border:1px solid var(--line2);border-radius:11px;padding:12px 15px;margin:0 0 var(--s5)}
.banner a{font-size:var(--fs-body);color:var(--accent);text-decoration:none}
.banner a:hover{text-decoration:underline}
.banner .bx{background:none;border:0;color:var(--faint);font:inherit;font-size:19px;cursor:pointer;line-height:1;padding:0 2px}
.banner .bx:hover{color:var(--text)}

/* ── focus flow (the DO-NOW deck: one action at a time) ── */
.flow-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s2)}
.flow-counter{font-family:var(--mono);font-size:var(--fs-caption);font-weight:600;color:var(--accent)}
.flow-back{background:none;border:0;color:var(--faint);font:inherit;font-size:var(--fs-caption);cursor:pointer;padding:0}
.flow-back:hover{color:var(--text)}
.flow-bar{height:4px;background:var(--surf2);border-radius:999px;overflow:hidden;margin-bottom:var(--s5)}
.flow-bar-fill{height:100%;width:25%;background:var(--accent);border-radius:999px;transition:width .25s ease}
.flow-trail{display:flex;flex-direction:column;gap:var(--s2);margin-bottom:var(--s4)}
.flow-trail:empty{display:none}
.flow-trail .done{display:flex;align-items:center;gap:10px;font-size:var(--fs-body);color:var(--faint)}
.flow-trail .done .tk{color:var(--ok)}
.flow-trail .done .tt{text-decoration:line-through}

.fcard{display:none}
.fcard.active{display:block}
.fcard .fc{background:var(--surf2);border:1px solid var(--line2);border-radius:var(--radius);padding:var(--s5) var(--s5) var(--s4)}
.fc-t{font-size:var(--fs-lead);font-weight:600;color:var(--text);margin:0 0 var(--s2)}
.fc-b{font-size:var(--fs-body);line-height:1.65;color:var(--muted);margin:0 0 var(--s4)}
.fc-b b{color:var(--text);font-weight:600}
.path{display:inline-flex;align-items:center;gap:8px;background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:8px 13px;font-family:var(--mono);font-size:var(--fs-caption);color:var(--accent);margin:0 0 var(--s4)}
.path .sep{color:var(--faint)}
.watch{display:flex;gap:10px;background:var(--no-bg);border:1px solid var(--no-line);border-radius:9px;padding:11px 14px;margin:0 0 var(--s4);font-size:var(--fs-caption);line-height:1.55;color:var(--no)}
.branch{background:var(--surf);border:1px dashed var(--line);border-radius:9px;padding:13px 15px;margin:0 0 var(--s4)}
.branch .bl{font-size:var(--fs-micro);text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--accent)}
.branch p{font-size:var(--fs-caption);line-height:1.6;color:var(--muted);margin:5px 0 0}
.why{background:none;border:0;color:var(--faint);font:inherit;font-size:var(--fs-caption);cursor:pointer;padding:0;margin:0 0 var(--s3);display:block}
.why:hover{color:var(--text)}
.why-body{font-size:var(--fs-caption);line-height:1.6;color:var(--faint);margin:0 0 var(--s4);border-left:2px solid var(--line2);padding-left:12px;display:none}
.why-body.open{display:block}
.next-btn{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:var(--bg);border:0;border-radius:9px;padding:11px 19px;font:inherit;font-size:var(--fs-body);font-weight:600;cursor:pointer;transition:.15s}
.next-btn:hover{filter:brightness(1.06)}
.next-btn:focus-visible{outline:2px solid var(--text);outline-offset:2px}

.flow-done{display:none;background:var(--surf);border:1px solid var(--line2);border-radius:var(--radius);padding:var(--s6) var(--s5);text-align:center}
.flow-done.show{display:block}
.flow-done .fd-ok{font-size:var(--fs-body);color:var(--ok);margin:0 0 var(--s1)}
.flow-done .fd-t{font-family:var(--display);font-size:var(--fs-h3);font-weight:600;color:var(--text);margin:0 0 var(--s4);letter-spacing:-.01em}
.flow-done .fd-next{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:var(--bg);border-radius:9px;padding:11px 19px;font-size:var(--fs-body);font-weight:600;text-decoration:none}
.flow-done .fd-next.soon{background:var(--surf2);color:var(--faint)}

/* ── file router (Stage 01: pick what it is → its folder) ── */
.router{background:var(--surf2);border:1px solid var(--line2);border-radius:var(--radius);padding:var(--s5)}
.router-trail{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-bottom:var(--s4)}
.router-trail:empty{display:none}
.rcrumb{background:none;border:0;color:var(--faint);font:inherit;font-size:var(--fs-caption);cursor:pointer;padding:0}
.rcrumb:hover{color:var(--accent)}
.rcrumb-sep{color:var(--line2);font-size:var(--fs-caption)}
.router-q{font-size:var(--fs-lead);font-weight:600;color:var(--text);margin:0 0 var(--s4)}
.router-opts{display:flex;flex-wrap:wrap;gap:var(--s3)}
.router-opt{font:inherit;font-size:var(--fs-body);color:var(--text);background:var(--surf);border:1px solid var(--line2);border-radius:999px;padding:11px 18px;cursor:pointer;transition:.15s;text-align:left}
.router-opt:hover{border-color:var(--accent);color:var(--accent)}
.router-opt:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.router-dest-paths{display:flex;flex-wrap:wrap;gap:var(--s2);margin:0 0 var(--s3)}
.router-why{font-size:var(--fs-caption);line-height:1.6;color:var(--muted);margin:0 0 var(--s4);max-width:var(--measure)}
.router-reset{background:none;border:0;color:var(--faint);font:inherit;font-size:var(--fs-caption);cursor:pointer;padding:0;text-decoration:underline}
.router-reset:hover{color:var(--text)}

/* reference shelf label (Zone C) */
.shelf-label{font-size:var(--fs-micro);text-transform:uppercase;letter-spacing:.1em;color:var(--faint);margin:var(--section-gap) 0 var(--s3)}

/* ── component responsive tweaks ── */
@media (max-width:860px){
  .tag{flex-basis:100%;margin-left:0;text-align:left;padding-left:20px;margin-top:3px}
  .pad{padding-left:32px}
  .stepper .lb{font-size:10.5px}
}
