/* ============================================================
   Unhinged warm — accessibility & neurodivergent layer (shared)
   Pairs with unhinged-warm-a11y.js. Uses the page's CSS vars.
   ============================================================ */

/* --- skip to content --- */
.skip-link{position:absolute;left:-9999px;top:.5rem;z-index:1000;background:var(--ink);color:var(--bg);
  padding:.6rem 1rem;border-radius:8px;font-family:"Martian Mono",monospace;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.skip-link:focus{left:.5rem}

/* --- visible keyboard focus --- */
a:focus-visible,button:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--clay);outline-offset:3px;border-radius:2px}
:focus:not(:focus-visible){outline:none}

/* --- reduced motion (OS preference OR in-page toggle) --- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}
html[data-nd-motion="reduced"] *,html[data-nd-motion="reduced"] *::before,html[data-nd-motion="reduced"] *::after{
  animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}

/* --- warm DARK theme (manual "Dark" toggle, OR "System" following OS) --- */
html[data-theme="dark"]{
  --bg:#1c1813; --card:#262019; --ink:#f1ebdd; --muted:#c2b69e; --faint:#a89c84;
  --line:#3a3329; --line-2:#4c4537; --clay:#e58a4e; --sage:#92bda3;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.35);
}
@media (prefers-color-scheme: dark){
  html:not([data-theme="light"]){
    --bg:#1c1813; --card:#262019; --ink:#f1ebdd; --muted:#c2b69e; --faint:#a89c84;
    --line:#3a3329; --line-2:#4c4537; --clay:#e58a4e; --sage:#92bda3;
    --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.35);
  }
}
html[data-theme="dark"] .dateline,
html[data-theme="dark"] .build-band{background:#221d16}
html[data-theme="dark"] .topbar{background:color-mix(in srgb,#1c1813 90%,transparent)}
html[data-theme="dark"] .box.keep{background:#1f2620;border-color:#34433a;border-left-color:var(--sage)}
@media (prefers-color-scheme: dark){
  html:not([data-theme="light"]) .dateline,
  html:not([data-theme="light"]) .build-band{background:#221d16}
  html:not([data-theme="light"]) .topbar{background:color-mix(in srgb,#1c1813 90%,transparent)}
  html:not([data-theme="light"]) .box.keep{background:#1f2620;border-color:#34433a}
}

/* --- ND: readable font --- */
html[data-nd-font="readable"] body,
html[data-nd-font="readable"] .serif,
html[data-nd-font="readable"] h1,html[data-nd-font="readable"] h2,
html[data-nd-font="readable"] h3,html[data-nd-font="readable"] h4,
html[data-nd-font="readable"] .filing-head h1,
html[data-nd-font="readable"] .dek{
  font-family:"Atkinson Hyperlegible",Verdana,"Segoe UI",sans-serif!important;font-style:normal!important}

/* --- ND: relaxed spacing (survives WCAG 1.4.12 overrides) --- */
html[data-nd-spacing="relaxed"] p,
html[data-nd-spacing="relaxed"] li{line-height:2!important;letter-spacing:.06em;word-spacing:.16em}

/* --- ND: high contrast --- */
html[data-nd-contrast="high"]{--muted:var(--ink);--faint:var(--ink);--line:var(--ink);--line-2:var(--ink)}
html[data-nd-contrast="high"] a{text-decoration:underline}

/* --- ND: underline all links --- */
html[data-nd-links="underline"] a{text-decoration:underline!important;text-underline-offset:2px}

/* --- nav links: non-color affordance always (WCAG 1.4.1) --- */
nav.main a{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:4px;
  text-decoration-color:color-mix(in srgb,currentColor 30%,transparent)}
nav.main a:hover,nav.main a.cur{text-decoration-color:currentColor}

/* --- mobile menu --- */
.nav-toggle{display:none;width:42px;height:42px;border:1px solid var(--line-2);border-radius:8px;
  background:transparent;color:var(--ink);cursor:pointer;font-size:18px;line-height:1;align-items:center;justify-content:center}
@media(max-width:780px){
  /* JS present: collapse nav behind the toggle */
  html.js .topbar{position:relative}
  html.js .nav-toggle{display:inline-flex}
  html.js nav.main{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg);
    border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:0;
    padding:.6rem clamp(1.25rem,4vw,2.5rem) 1rem}
  html.js nav.main.open{display:flex}
  html.js nav.main a{padding:.6rem 0;min-height:44px;display:flex;align-items:center;width:100%}
  /* No JS: toggle stays hidden and nav stays in normal flow, so navigation is never lost. */
}

/* --- accessibility panel --- */
.a11y-fab{position:fixed;right:1rem;bottom:1rem;z-index:900;font-family:"Martian Mono",monospace;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;background:var(--ink);color:var(--bg);
  border:none;border-radius:999px;padding:.7rem 1.05rem;cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.18)}
.a11y-fab:hover{filter:brightness(1.08)}
.a11y-panel{position:fixed;right:1rem;bottom:3.9rem;z-index:901;width:286px;max-width:calc(100vw - 2rem);
  background:var(--card);color:var(--ink);border:1px solid var(--line-2);border-radius:14px;
  box-shadow:0 14px 44px rgba(0,0,0,.22);padding:1.1rem 1.2rem 1.2rem;display:none}
.a11y-panel.open{display:block}
.a11y-panel .a11y-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.2rem}
.a11y-panel h2{font-family:"Fraunces",serif;font-weight:600;font-size:1.15rem;margin:0}
.a11y-close{background:transparent;border:none;color:var(--muted);font-size:1.6rem;line-height:1;cursor:pointer;padding:0 .15rem;border-radius:6px}
.a11y-close:hover{color:var(--ink)}
.a11y-panel .sub{color:var(--muted);font-size:.82rem;margin:0 0 .9rem}
.a11y-panel .grp{margin:.65rem 0}
.a11y-panel .lbl{font-family:"Martian Mono",monospace;font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.4rem}
.a11y-panel .seg{display:flex;gap:.3rem}
.a11y-panel .seg button{flex:1;font:inherit;font-size:.82rem;padding:.4rem;border:1px solid var(--line-2);
  background:transparent;color:var(--ink);border-radius:8px;cursor:pointer}
.a11y-panel .row{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.34rem 0;font-size:.93rem}
.a11y-panel .row button{font:inherit;font-size:.78rem;min-width:3.2rem;border:1px solid var(--line-2);
  background:transparent;color:var(--ink);border-radius:8px;padding:.32rem .7rem;cursor:pointer}
.a11y-panel .seg button[aria-pressed="true"],
.a11y-panel .row button[aria-pressed="true"]{background:var(--clay);color:#fff;border-color:var(--clay)}

/* --- print: when a board-sheet button is used, print ONLY that sheet --- */
/* (a normal Cmd/Ctrl+P with no .printing-sheet class prints the page as usual) */
@media print{
  body.printing-sheet *{display:none !important}
  body.printing-sheet *:has(.box.sheet){display:block !important}
  body.printing-sheet .box.sheet,
  body.printing-sheet .box.sheet *{display:revert !important;color:#111 !important;background:transparent !important}
  body.printing-sheet .box.sheet{border:1px solid #999;box-shadow:none;margin:0;padding:1.2rem 1.4rem;max-width:100%}
  body.printing-sheet .box.sheet .btn{display:none !important}
  body.printing-sheet .box.sheet .sheet-top .pr{display:none !important}
  body.printing-sheet .box.sheet .sheet-top{display:block !important}
}
