/* NCC 2025 Staff Tool — JALBAR brand styling. Mobile-first. Class hooks match app.js. */
:root{
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Jost",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --header:#2a2a2a; --header-ink:#faf8f5;
  --bg:#faf8f5; --surface:#ffffff; --surface-2:#f6f5f3;
  --ink:#3a3a3a; --ink-2:#6e6e6e; --ink-3:#9a948c;
  --line:#e7e3dd; --line-2:#d8d2c8;
  --accent:#8a6f4e; --accent-soft:#f1eae0; --gold:#e8d4b5;
  --ok:#4f7a5b; --ok-bg:#eaf1ea; --warn:#9a6f2e; --warn-bg:#f6ecd9;
  --nsw:#8a6f4e; --nsw-bg:#f1eae0;
  --radius:6px; --radius-sm:3px;
  --shadow:0 1px 2px rgba(58,46,30,.05),0 10px 30px rgba(58,46,30,.06);
  --tap:46px; --maxw:900px;
}
@media (prefers-color-scheme:dark){
  :root{
    --header:#1d1b18; --header-ink:#f3ede2;
    --bg:#16140f; --surface:#211e19; --surface-2:#1a1813;
    --ink:#ece6da; --ink-2:#b6ab98; --ink-3:#8a8071;
    --line:#322d25; --line-2:#403a30;
    --accent:#c8a878; --accent-soft:#2a241b; --gold:#e8d4b5;
    --ok:#7fb38c; --ok-bg:#17231a; --warn:#d6a657; --warn-bg:#2a2113;
    --nsw:#c8a878; --nsw-bg:#2a241b;
    --shadow:0 1px 2px rgba(0,0,0,.4),0 10px 30px rgba(0,0,0,.35);
  }
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:300;font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-bottom:env(safe-area-inset-bottom)}
h1,h2,h3{margin:0;font-weight:400;letter-spacing:-.01em}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:8px;top:8px;background:var(--surface);padding:8px 12px;border-radius:3px;z-index:50}

/* Header */
.app-header{position:sticky;top:0;z-index:20;background:var(--header);color:var(--header-ink);
  padding:calc(env(safe-area-inset-top) + 11px) 14px 12px;box-shadow:0 2px 18px rgba(20,16,10,.22)}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;color:var(--header-ink);min-width:0}
.brand-logo{height:26px;width:auto;display:block}
.brand-sep{width:1px;height:26px;background:rgba(250,248,245,.26);flex:none}
.brand-text{display:flex;flex-direction:column;line-height:1.12;min-width:0}
.brand-text strong{font-family:var(--sans);font-weight:500;font-size:14px;letter-spacing:.16em;text-transform:uppercase}
.brand-text small{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;opacity:.72;font-weight:400}
.icon-btn{position:relative;display:grid;place-items:center;min-width:var(--tap);height:var(--tap);border:0;border-radius:var(--radius-sm);
  background:rgba(250,248,245,.12);color:var(--header-ink);font-size:21px;cursor:pointer}
.icon-btn:active{transform:scale(.96)}
.bm-count{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--accent);
  color:#fff;font-size:11px;font-weight:500;display:grid;place-items:center}
.search-wrap{position:relative;max-width:var(--maxw);margin:11px auto 0}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--ink-3);font-size:19px}
#search{width:100%;height:var(--tap);border:0;border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);
  font-family:var(--sans);padding:0 42px;font-size:16px;box-shadow:var(--shadow)}
#search::placeholder{color:var(--ink-3)}
#search:focus{outline:2px solid var(--accent);outline-offset:1px}
.search-clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:36px;height:36px;border:0;border-radius:var(--radius-sm);
  background:transparent;color:var(--ink-3);font-size:18px;cursor:pointer}

/* Layout */
main{max-width:var(--maxw);margin:0 auto;padding:18px 14px 28px}
.section-title{font-family:var(--sans);font-size:11.5px;text-transform:uppercase;letter-spacing:.26em;color:var(--accent);
  margin:6px 2px 12px;font-weight:500}
.breadcrumb{display:flex;align-items:center;gap:6px;flex-wrap:wrap;color:var(--ink-3);font-size:12.5px;margin-bottom:14px;
  text-transform:uppercase;letter-spacing:.08em}
.breadcrumb a{color:var(--ink-2)}
.breadcrumb i{font-size:14px;opacity:.7}

/* Category grid */
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cat-card{display:flex;flex-direction:column;gap:9px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:15px;box-shadow:var(--shadow);cursor:pointer;min-height:118px;text-align:left;color:inherit}
.cat-card:active{transform:translateY(1px)}
.cat-ic{width:42px;height:42px;border-radius:var(--radius-sm);display:grid;place-items:center;font-size:22px;
  background:var(--accent-soft);color:var(--accent)}
.cat-card h3{font-family:var(--serif);font-size:20px;font-weight:500}
.cat-card p{margin:0;color:var(--ink-2);font-size:13px;line-height:1.4}
.cat-card .count{margin-top:auto;font-size:10.5px;color:var(--ink-3);font-weight:400;text-transform:uppercase;letter-spacing:.1em}

/* Rows */
.rows{display:flex;flex-direction:column;gap:10px}
.row{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px;box-shadow:var(--shadow);cursor:pointer;color:inherit;text-align:left;width:100%}
.row:active{transform:translateY(1px)}
.row .row-ic{width:40px;height:40px;border-radius:var(--radius-sm);display:grid;place-items:center;background:var(--accent-soft);
  color:var(--accent);font-size:19px;flex:none}
.row-main{flex:1;min-width:0}
.row-main h3{font-family:var(--sans);font-weight:500;font-size:15.5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;letter-spacing:0}
.row-main p{margin:3px 0 0;color:var(--ink-2);font-size:13px;font-weight:300;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .chev{color:var(--ink-3);font-size:20px;flex:none}
.row.planned{opacity:.6;cursor:default}
.row.planned:active{transform:none}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--sans);font-size:10px;font-weight:500;padding:3px 9px;border-radius:999px;
  letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;line-height:1.5}
.badge i{font-size:13px}
.badge.ok{background:var(--ok-bg);color:var(--ok)}
.badge.draft{background:var(--warn-bg);color:var(--warn)}
.badge.nsw{background:var(--nsw-bg);color:var(--nsw)}
.badge.cls{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}
.badge.soon{background:var(--surface-2);color:var(--ink-3);border:1px solid var(--line)}

/* Card view */
.card-head{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin-bottom:14px}
.card-head h1{font-family:var(--serif);font-weight:500;font-size:30px;margin-bottom:4px;line-height:1.08}
.card-head .summary{color:var(--ink-2);font-size:14.5px;font-weight:300;margin:10px 0 0;line-height:1.5}
.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.card-actions{display:flex;gap:8px;margin-top:16px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:44px;padding:0 16px;border-radius:var(--radius-sm);
  border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font-family:var(--sans);font-size:11px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;cursor:pointer}
.btn i{font-size:18px}
.btn.primary{background:var(--header);border-color:var(--header);color:#faf8f5}
.btn:active{transform:translateY(1px)}

.rule{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 15px;margin-bottom:10px;box-shadow:var(--shadow)}
.rule-top{display:flex;align-items:baseline;gap:14px}
.rule-val{font-family:var(--sans);font-size:22px;font-weight:500;color:var(--accent);letter-spacing:-.01em;flex:none;font-variant-numeric:tabular-nums}
.rule-val .u{font-size:13px;font-weight:400;color:var(--ink-3);margin-left:2px}
.rule-text{font-size:15px;font-weight:300;flex:1;line-height:1.45}
.rule-noval .rule-text{font-weight:400}
.rule-note{color:var(--ink-2);font-size:13px;font-weight:300;margin-top:7px;padding-left:2px;border-left:2px solid var(--line-2);padding-left:9px}
.rule-foot{display:flex;align-items:center;gap:8px;margin-top:11px;flex-wrap:wrap}
.clause{display:inline-flex;align-items:center;gap:5px;font-family:var(--sans);font-size:11.5px;font-weight:500;color:var(--accent);
  background:var(--accent-soft);border-radius:var(--radius-sm);padding:4px 9px;font-variant-numeric:tabular-nums;letter-spacing:.02em}
.clause i{font-size:13px}

.related h2,.source-line{font-family:var(--sans);font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.2em;font-weight:500;margin:20px 2px 9px}
.source-line{text-transform:none;letter-spacing:0;font-weight:300;color:var(--ink-2);margin-top:20px;font-size:13px}
.source-line a{font-weight:500}

.verify-strip{display:flex;gap:10px;align-items:flex-start;background:var(--warn-bg);color:var(--warn);
  border:1px solid color-mix(in srgb,var(--warn) 30%,transparent);border-radius:var(--radius);padding:12px 14px;margin-bottom:14px;font-size:13.5px;font-weight:300}
.verify-strip i{font-size:18px;flex:none;margin-top:1px}

/* Empty */
.empty{text-align:center;color:var(--ink-2);padding:40px 16px}
.empty i{font-size:36px;color:var(--ink-3);display:block;margin-bottom:12px}
.empty h3{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:6px;color:var(--ink)}
.empty p{font-weight:300}

/* Footer */
.app-footer{max-width:var(--maxw);margin:0 auto;padding:20px 16px 34px;color:var(--ink-3);font-size:12px;font-weight:300;border-top:1px solid var(--line)}
.app-footer p{margin:0 0 8px}
.disclaimer{color:var(--ink-2);font-size:12.5px;line-height:1.55}
.attribution{font-size:11.5px}
.brandline{font-size:11px;letter-spacing:.04em;color:var(--ink-2)}
.brandline em{color:var(--accent);font-style:italic;font-family:var(--serif);font-size:13px}
.version{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;opacity:.85}

/* Ask the code (AI) */
.ask-cta{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:var(--header);color:var(--header-ink);
  border:0;border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);cursor:pointer;margin-bottom:14px}
.ask-cta:active{transform:translateY(1px)}
.ask-cta .ic{width:40px;height:40px;border-radius:var(--radius-sm);display:grid;place-items:center;background:rgba(232,212,181,.16);color:var(--gold);font-size:21px;flex:none}
.ask-cta .lab{flex:1;min-width:0}
.ask-cta .lab b{font-family:var(--sans);font-weight:500;font-size:14px;display:block;letter-spacing:.02em}
.ask-cta .lab span{font-size:12.5px;color:var(--gold);opacity:.8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;font-weight:300}
.ask-cta .arw{color:var(--gold);font-size:18px;flex:none}
.ask-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:17px 18px;box-shadow:var(--shadow);margin-bottom:14px}
.ask-q{font-family:var(--serif);font-size:20px;color:var(--ink);margin-bottom:11px;font-weight:500;line-height:1.2}
.ask-answer{font-size:15px;line-height:1.62;color:var(--ink)}
.ask-answer p{margin:0 0 10px}.ask-answer p:last-child{margin-bottom:0}
.ask-loading{display:flex;align-items:center;gap:10px;color:var(--ink-2);font-size:14px}
.spin{width:16px;height:16px;border:2px solid var(--line-2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex:none}
@keyframes spin{to{transform:rotate(360deg)}}
.ask-foot{margin-top:13px;padding-top:12px;border-top:1px solid var(--line);font-size:11.5px;color:var(--ink-3);display:flex;align-items:flex-start;gap:7px;line-height:1.5}
.ask-foot i{font-size:14px;flex:none;margin-top:1px}
.ask-note{font-size:13px;color:var(--ink-2);background:var(--accent-soft);border-radius:var(--radius-sm);padding:11px 13px;line-height:1.55}
.ask-note code{font-family:var(--font-mono,monospace);font-size:12px;background:var(--surface-2);padding:1px 5px;border-radius:3px}

@media (min-width:680px){.cat-grid{grid-template-columns:repeat(3,1fr)}.card-head h1{font-size:34px}}
@media (min-width:920px){.cat-grid{grid-template-columns:repeat(4,1fr)}}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}
