/* Supplemental styles for the FastAPI build.
   The Direction C prototype set selected-state via JS (aria-checked); here we use
   native radio inputs inside labels and map :checked to the same look via :has(). */

/* printer cards */
.fc-printer{position:relative}
.fc-printer input{position:absolute;opacity:0;pointer-events:none}
.fc-printer:has(input:checked){background:var(--ink);border-color:var(--ink)}
.fc-printer:has(input:checked) .fc-pname{color:var(--cream)}
.fc-printer:has(input:checked) .fc-pfam{color:#bcae98}
.fc-printer:focus-within{border-color:var(--clay)}

/* segmented controls (nozzle, hardness) as labels */
.seg label{font-family:var(--sans);font-weight:600;font-size:13px;background:none;padding:7px 14px;cursor:pointer;color:var(--ink2);border-radius:30px;display:inline-flex;align-items:center;position:relative}
.seg label:hover{color:var(--ink)}
.seg label input{position:absolute;opacity:0;pointer-events:none}
.seg label:has(input:checked){background:var(--ink);color:var(--cream)}

/* brand chips */
.fc-brand{position:relative}
.fc-brand input{position:absolute;opacity:0;pointer-events:none}
.fc-brand:has(input:checked){background:var(--clay);color:#fff}
.fc-brand:has(input:checked) .fc-btag{color:#ffd9c9}

/* warnings region (support column; OOB-refreshed) */
#warnings{display:flex;flex-direction:column;gap:11px;margin:16px 0}

/* htmx: subtle fade while a preview request is in flight */
#preview.htmx-request{opacity:.6;transition:opacity .12s}

/* copied state for the copy-link button */
.btn.is-ok{background:var(--green);border-color:var(--green);color:#fff}

/* ===================================================================
   Sticky readouts — these rules live ONLY inline in design/type-specimen.html
   (design/c.css is a subset and omits them). Lifted here verbatim so the
   sticky bar, pinned mini-readout, and mobile pill/pop actually work.
   =================================================================== */

/* top sliding condensed readout */
.sticky-readout{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(247,242,234,.93);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1.5px solid var(--ink);transform:translateY(-101%);transition:transform .32s cubic-bezier(.3,.7,.2,1);cursor:pointer}
.sticky-readout.show{transform:none}
.sticky-readout .wrap{display:flex;align-items:center;gap:14px;height:56px}
.sr-dot{width:8px;height:8px;border-radius:50%;background:var(--clay);animation:pl 1.7s infinite;flex:none}
.sr-label{font-family:var(--sans);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink2)}
.sr-grp{display:flex;align-items:baseline;gap:9px}
.sr-grp.flow{margin-left:6px}
.sr-grp.speed{margin-left:28px;padding-left:28px;border-left:1.5px solid var(--rule)}
.sr-val{font-family:var(--disp);font-weight:700;font-size:25px;color:var(--clay);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.sr-speed{font-family:var(--disp);font-weight:700;font-size:25px;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.sticky-readout.is-clamped .sr-val,.sticky-readout.is-clamped .sr-speed{color:var(--clay-d)}
.sr-up{margin-left:auto;font-size:11px;font-weight:600;color:var(--faint);border:1.5px solid var(--rule2);border-radius:30px;padding:4px 11px}
.sticky-readout:hover .sr-up{color:var(--clay);border-color:var(--clay)}
/* Mobile (<1000px): single column, and the top bar IS the sticky readout (pill retired). */
@media(max-width:999px){
  .sticky-readout .wrap{height:48px;gap:10px;padding:0 16px}
  .sr-grp.flow{margin-left:0}
  .sr-grp.speed{margin-left:14px;padding-left:14px}
  .sr-val,.sr-speed{font-size:18px}
  .sr-label{font-size:9px;letter-spacing:.06em}
  .sr-up{display:none}
  .pill,.pillpop{display:none!important}
}
/* Small phones (<=430px): drop the labels — the units (mm³/s, mm/s) disambiguate — so
   "● 21 mm³/s | 250 mm/s" fits down to ~320px without overflow. */
@media(max-width:430px){
  .sticky-readout .wrap{gap:8px}
  .sticky-readout .sr-label{display:none}
  .sr-grp.speed{margin-left:10px;padding-left:10px}
  .sr-val,.sr-speed{font-size:17px}
}

/* the support column pins on lg+ so the mini-readout stays beside the inputs */
@media(min-width:1000px){.support{position:sticky;top:78px;align-self:start}}

/* pinned mini-readout card */
.mini-readout{display:none}
@media(min-width:1000px){.mini-readout{display:block;border:1.5px solid var(--ink);border-radius:16px;padding:16px 18px;margin-bottom:22px;background:var(--panel)}}
.mini-readout .mr-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.mini-readout .mr-k{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink2);font-weight:600}
.mini-readout .mr-live{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--clay);font-weight:600;display:inline-flex;align-items:center;gap:6px}
.mini-readout .mr-live .d{width:6px;height:6px;border-radius:50%;background:var(--clay);animation:pl 1.7s infinite}
.mini-readout .mr-flow{display:flex;align-items:flex-end;gap:8px;border-bottom:1.5px solid var(--rule);padding-bottom:12px;margin-bottom:12px}
.mini-readout .mr-flow .v{font-family:var(--disp);font-weight:800;font-size:clamp(40px,4.4vw,56px);line-height:.8;color:var(--clay);letter-spacing:-.02em}
.mini-readout.is-clamped .mr-flow .v{color:var(--clay-d)}
.mini-readout .mr-flow .u{font-family:var(--sans);font-size:13px;color:var(--faint);padding-bottom:4px}
.mini-readout .mr-flow .lbl{margin-left:auto;text-align:right;font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);font-weight:600;max-width:11ch;line-height:1.3;padding-bottom:3px}
.mini-readout .mr-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px 18px}
.mini-readout .mr-cell .k{font-size:9.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--faint);font-weight:600}
.mini-readout .mr-cell .v{font-family:var(--disp);font-weight:700;font-size:19px;margin-top:2px;letter-spacing:-.01em}
.mini-readout .mr-cell .v small{font-size:11px;font-weight:500;color:var(--faint)}

/* mobile pill expands into a mini Quick Answer (pillpop omitted from c.css) */
.pill{cursor:pointer;border:0}
.pillpop{position:fixed;left:12px;right:12px;bottom:74px;z-index:56;background:var(--cream);border:2px solid var(--ink);border-radius:20px;padding:16px 18px 18px;box-shadow:0 24px 50px rgba(0,0,0,.3);transform:translateY(12px);opacity:0;pointer-events:none;transition:.22s cubic-bezier(.3,.7,.2,1)}
.pillpop.open{transform:none;opacity:1;pointer-events:auto}
.pillpop .pph{display:flex;align-items:center;justify-content:space-between;border-bottom:1.5px solid var(--rule);padding-bottom:10px;margin-bottom:12px}
.pillpop .pph .t{font-family:var(--disp);font-weight:700;font-size:16px}
.pillpop .pph .x{background:none;border:0;font-size:22px;cursor:pointer;line-height:1;color:var(--faint)}
.pillpop-lead{display:flex;align-items:flex-end;gap:8px;margin-bottom:8px}
.pillpop-lead .v{font-family:var(--disp);font-weight:800;font-size:52px;line-height:.85;color:var(--clay)}
.pillpop-lead.is-clamped .v{color:var(--clay-d)}
.pillpop-lead .u{font-family:var(--sans);font-size:14px;color:var(--faint);padding-bottom:7px}
.pillpop-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px;border-top:1.5px solid var(--rule);padding-top:12px}
.pillpop-grid .k{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);font-weight:600}
.pillpop-grid .v{font-family:var(--disp);font-weight:700;font-size:20px}
@media(min-width:1000px){.pillpop{display:none}}

/* "target N → clamped" line shows only when the effective-speed metric is clamped */
.cmetric:not(.is-clamped) .g-target{display:none}

/* full-settings table group-header rows (not in the c.css subset) */
.fc-fgroup td{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-size:10.5px;font-weight:700;color:var(--clay);padding:18px 10px 7px;border-bottom:1.5px solid var(--ink)}
.broadsheet .accord-t span{font-family:var(--sans);font-weight:400;font-size:15px;color:var(--faint);margin-left:10px}

/* How-it-works modal (lean; the elaborate .hiw-* prototype styles aren't in c.css) */
.modal-scrim{position:fixed;inset:0;background:rgba(34,29,23,.5);opacity:0;pointer-events:none;transition:.2s;z-index:70}
.modal-scrim.show{opacity:1;pointer-events:auto}
.modal{position:fixed;z-index:71;left:50%;top:50%;transform:translate(-50%,-47%) scale(.98);opacity:0;pointer-events:none;transition:.24s cubic-bezier(.3,.7,.2,1);width:min(680px,94vw);max-height:88vh;overflow:auto;background:var(--cream);border:2px solid var(--ink);border-radius:20px}
.modal.show{transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto}
.modal-bar{height:7px;background:var(--clay)}
.modal-in{padding:24px 30px 30px}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;border-bottom:2px solid var(--ink);padding-bottom:14px;margin-bottom:18px}
.modal-t{font-family:var(--disp);font-weight:700;font-size:26px}
.modal-x{flex:none;width:38px;height:38px;border-radius:50%;border:1.5px solid var(--ink);background:none;font-size:20px;cursor:pointer;line-height:1;color:var(--ink)}
.modal-x:hover{background:var(--ink);color:var(--cream)}
.modal-in p{font-size:14.5px;color:var(--ink2);line-height:1.6;margin:0 0 13px;max-width:62ch}
.modal-in p b{color:var(--ink)}
.modal-in code{font-family:ui-monospace,monospace;font-size:13px;background:var(--tint);padding:1px 6px;border-radius:5px}
