:root{
  --red:#AF001F; --red-dark:#8C0019; --black:#0E0C0C; --ink:#1A1717;
  --white:#FFFFFF; --paper:#FAFAF8; --line:#E6E2DC; --mute:#6E6862;
  --ok:#1E7A3C; --warn:#B96A00;
  --radius:6px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:'Barlow',system-ui,sans-serif;background:var(--white);color:var(--ink);
  font-size:16px;line-height:1.45}
h1,h2,h3,.disp{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.02em;text-transform:uppercase}
.mono{font-family:'JetBrains Mono',monospace}
a{color:var(--red);text-decoration:none}
a:hover{text-decoration:underline}

/* Header band */
.band{background:var(--black);color:var(--white);position:relative}
.band::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--red)}
.band-inner{max-width:1180px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.band .brand{display:inline-flex;align-items:center}
.band .brand:hover{text-decoration:none}
.brand-logo{height:50px;display:block}
.subbar{border-top:1px solid #2c2825}
.subbar-inner{max-width:1180px;margin:0 auto;padding:7px 20px}
.crumb{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#CFC9C4}
.crumb b{color:var(--white);font-weight:600}
.band .who{font-size:13px;color:#CFC9C4;white-space:nowrap}
.band .who b{color:var(--white)}
.band .who .who-email{margin-left:8px;color:#9b948c}
.band a{color:#CFC9C4}
.band a:hover{color:var(--white);text-decoration:none}

/* Grouped dropdown nav */
.nav{margin-left:18px;flex:1;display:flex;align-items:center;gap:2px}
.hamburger{display:none}
.navgroup{position:relative}
.navtop{display:inline-block;font-family:'Anton',sans-serif;font-size:14px;letter-spacing:.08em;
  text-transform:uppercase;color:#CFC9C4;padding:7px 12px;border-radius:5px}
.navgroup:hover .navtop,.navgroup:focus-within .navtop{color:#fff;background:rgba(255,255,255,.10)}
/* Flush with the trigger (no dead gap to cross) + a close delay so a brief
   diagonal move toward the items doesn't dismiss the menu. */
.navmenu{position:absolute;left:0;top:100%;min-width:200px;background:var(--ink);
  border:1px solid #34302c;border-radius:8px;padding:6px;z-index:60;
  box-shadow:0 10px 28px rgba(0,0,0,.35);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .14s ease, transform .14s ease, visibility .14s;transition-delay:.2s}
.navgroup:hover .navmenu,.navgroup:focus-within .navmenu{
  opacity:1;visibility:visible;transform:translateY(0);transition-delay:0s}
.navmenu a{display:block;padding:10px 14px;color:#D8D3CD;font-family:'Barlow',sans-serif;font-size:14px;
  letter-spacing:0;text-transform:none;border-radius:5px}
.navmenu a:hover{background:var(--red);color:#fff;text-decoration:none}
.nav-user{margin-left:auto;display:flex;align-items:center;gap:14px;white-space:nowrap}

/* Mobile: collapse the nav into a hamburger panel */
@media (max-width:900px){
  .hamburger{display:inline-flex;align-items:center;margin-left:auto;font-size:24px;line-height:1;
    cursor:pointer;color:#fff;padding:4px 12px;border-radius:6px}
  .hamburger:hover{background:rgba(255,255,255,.10)}
  .nav{display:none;position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;
    gap:0;margin:0;background:var(--ink);border-top:1px solid #2c2825;padding:8px;z-index:80;
    box-shadow:0 14px 30px rgba(0,0,0,.45)}
  .navtoggle:checked ~ .nav{display:flex}
  .navgroup{width:100%}
  .navtop{display:block;width:100%;color:#fff}
  .navmenu{position:static;min-width:0;background:transparent;border:0;box-shadow:none;padding:0 0 6px 16px;
    opacity:1;visibility:visible;transform:none;transition:none}
  .nav-user{margin-left:0;flex-direction:column;align-items:flex-start;gap:10px;padding:12px;
    border-top:1px solid #2c2825;margin-top:6px}
  .who{white-space:normal}
}

/* Dev role-preview bar */
.devbar{position:fixed;left:0;right:0;bottom:0;z-index:90;display:flex;align-items:center;gap:8px;
  flex-wrap:wrap;background:#1A1717;color:#CFC9C4;border-top:2px solid var(--red);padding:6px 14px;font-size:12px}
.devbar-label{font-weight:700;letter-spacing:.1em;color:var(--red)}
.devbar a{color:#CFC9C4;padding:3px 9px;border-radius:4px;border:1px solid #3a3531}
.devbar a:hover{background:var(--red);color:#fff;text-decoration:none;border-color:var(--red)}
.devbar a.on{background:#fff;color:#111;border-color:#fff}
.devbar-note{margin-left:auto;color:var(--warn)}

/* Cards & chips */
/* The [hidden] attribute must win over component display rules (e.g. .btn, .fc-card). */
[hidden]{display:none !important}

.card{background:var(--white);border:2px solid var(--black);border-radius:var(--radius);padding:20px;margin-bottom:18px}
.chip{display:inline-block;font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:3px 9px 2px;border:1.5px solid currentColor;border-radius:4px}
.chip.red{color:var(--white);background:var(--red);border-color:var(--red)}
.chip.ok{color:var(--white);background:var(--ok);border-color:var(--ok)}
.chip.warn{color:var(--white);background:var(--warn);border-color:var(--warn)}
.chip.ghost{color:var(--mute);border-color:var(--line);background:var(--paper)}
.chip.blk{color:var(--white);background:var(--black);border-color:var(--black)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
  font-family:'Anton',sans-serif;letter-spacing:.06em;text-transform:uppercase;font-size:17px;
  border:2px solid var(--black);background:var(--black);color:var(--white);padding:12px 26px;border-radius:5px;
  transition:transform .06s ease, background .12s;text-decoration:none}
.btn:hover{background:var(--red);border-color:var(--red);text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn.red{background:var(--red);border-color:var(--red)}
.btn.red:hover{background:var(--red-dark)}
.btn.ghost{background:var(--white);color:var(--black)}
.btn.ghost:hover{background:var(--black);color:var(--white)}
.btn.sm{font-size:13px;padding:7px 14px}
.btn:focus-visible,a:focus-visible,.opt:focus-visible{outline:3px solid var(--red);outline-offset:2px}

.eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red)}

.wrap{max-width:1180px;margin:0 auto;padding:26px 20px 60px}
.foot{font-size:12px;color:var(--mute);text-align:center;padding:18px 0 30px}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* Forms */
.form{display:flex;flex-direction:column;gap:14px;padding:24px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.field input[type=text],.field input[type=email],.field input[type=password],
.field input[type=tel],.field select,.field textarea{
  font:inherit;font-size:16px;padding:10px 12px;border:2px solid var(--line);background:var(--white);border-radius:5px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--black)}
.field .help{font-size:13px;color:var(--mute)}
.form-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.checklist{display:flex;flex-direction:column;gap:6px}
.checklist label{display:flex;gap:8px;align-items:center;font-size:15px}

.alert{padding:12px 14px;border-left:4px solid var(--red);background:#FBEBEE;font-size:14px}
.alert.ok{border-left-color:var(--ok);background:#E8F4EC}
.alert.warn{border-left-color:var(--warn);background:#FBEFE0}

/* Tables */
.tbl{width:100%;border-collapse:collapse;background:var(--white)}
.tbl th,.tbl td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
.tbl th{font-family:'Anton',sans-serif;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);background:var(--paper)}
.tbl tr:hover td{background:var(--paper)}
.row-actions{display:flex;gap:8px;flex-wrap:wrap}

.page-title{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.page-title h1{font-size:clamp(22px,4vw,32px)}
.page-title .spacer{flex:1}

.split{display:grid;gap:18px}
@media(min-width:720px){.split{grid-template-columns:1fr 1fr}}

/* Rules Library */
.card .disp{font-size:16px;margin:0 0 12px}
.opt{border:2px solid var(--line);background:var(--paper);padding:12px 14px;border-radius:var(--radius)}
.rendered{font-size:15px;line-height:1.55}
.rendered h1,.rendered h2,.rendered h3{font-family:'Barlow',sans-serif;text-transform:none;letter-spacing:0;margin:.6em 0 .3em}
.rendered h1{font-size:20px}.rendered h2{font-size:18px}.rendered h3{font-size:16px}
.rendered p{margin:.4em 0}
.rendered ul,.rendered ol{margin:.4em 0 .4em 1.4em}
.rendered blockquote{margin:.5em 0;padding:.2em 0 .2em 14px;border-left:4px solid var(--red);color:var(--mute)}
.rendered code{font-family:'JetBrains Mono',monospace;font-size:13px;background:var(--paper);padding:1px 5px}
/* Flashcard study — one card at a time */
.fc-study{max-width:720px;margin:0 auto}
.fc-meta{display:flex;justify-content:space-between;align-items:baseline;margin:0 0 10px;color:var(--mute);font-size:13px}
.fc-card{min-height:300px;display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;cursor:pointer}
.fc-card .eyebrow{margin-bottom:6px}
.fc-card .rendered{font-size:18px}
.fc-card .fc-back{width:100%}
.fc-card .fc-back .rendered{font-size:16px}
.fc-card .fc-back .fc-answers{list-style:none;padding:0;margin:8px 0;font-size:18px}
.fc-hint{margin-top:16px;color:var(--mute)}
.fc-controls{display:flex;gap:10px;justify-content:center;align-items:center;margin-top:14px;flex-wrap:wrap}
.btn.got{background:var(--ok);border-color:var(--ok);color:#fff}
.fc-bar{height:8px;border:1px solid var(--line);border-radius:5px;background:var(--paper);overflow:hidden;margin-top:18px}
.fc-bar>i{display:block;height:100%;width:0;background:var(--red);transition:width .25s}
.fc-done{text-align:center;margin-top:18px}

/* Settings sub-tabs */
.subtabs{display:flex;gap:4px;flex-wrap:wrap;border-bottom:2px solid var(--line);margin:0 0 18px}
.subtabs a{padding:8px 14px;font-family:'Anton',sans-serif;font-size:13px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--mute);border-bottom:3px solid transparent;margin-bottom:-2px}
.subtabs a:hover{color:var(--ink);text-decoration:none}
.subtabs a.on{color:var(--red);border-bottom-color:var(--red)}

/* Markdown toolbar */
.mdbar{display:flex;align-items:center;gap:3px;flex-wrap:wrap;margin:0 0 6px;padding:5px;
  background:var(--paper);border:1px solid var(--line);border-radius:5px}
.mdbtn{min-width:30px;height:28px;padding:0 7px;font-family:'Barlow',sans-serif;font-size:13px;
  background:var(--white);border:1px solid var(--line);border-radius:4px;cursor:pointer;color:var(--ink)}
.mdbtn:hover{background:var(--red);color:#fff;border-color:var(--red)}
.mdsep{width:1px;height:18px;background:var(--line);margin:0 3px}

/* Modal (used by the visual table builder) */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:200;display:none;
  align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.modal{background:var(--white);border:2px solid var(--black);border-radius:var(--radius);
  padding:20px;max-width:780px;width:100%;box-shadow:0 20px 50px rgba(0,0,0,.4)}
.tb-grid{border-collapse:collapse;margin-top:4px}
.tb-grid th,.tb-grid td{border:1px solid var(--line);padding:2px}
.tb-grid input,.tb-grid select{width:100%;min-width:96px;border:0;padding:5px;font-size:13px;background:transparent}
.tb-grid thead input{font-weight:700}
.tb-grid input:focus{outline:2px solid var(--red)}

.rendered .table-wrap{overflow-x:auto;margin:.5em 0}
.rendered table{border-collapse:collapse;margin:0}
.rendered th,.rendered td{border:1px solid var(--line);padding:6px 10px;text-align:left;white-space:nowrap}
.rendered thead th{background:var(--paper)}
.rendered img{max-width:100%;height:auto}
.video-embed{position:relative;width:100%;max-width:640px;aspect-ratio:16/9;margin:.6em auto}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:6px}

/* Progress bar */
.bar{height:10px;background:var(--paper);border:2px solid var(--line);overflow:hidden}
.bar>span{display:block;height:100%;background:var(--red)}
.bar.done>span{background:var(--ok)}
.muted{color:var(--mute);font-size:13px}

/* Nav pending-review indicators (e.g. headshot approvals) */
.navdot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--red);margin-left:5px;vertical-align:middle;box-shadow:0 0 0 2px rgba(175,0,31,.25)}
.navbadge{display:inline-block;min-width:18px;padding:0 5px;border-radius:9px;background:var(--red);color:#fff;font-size:11px;font-weight:700;text-align:center;line-height:18px}
.navmenu a:hover .navbadge{background:#fff;color:var(--red)}

/* Home dashboard */
.dash{display:grid;gap:18px}
@media(min-width:860px){.dash{grid-template-columns:2fr 1fr;align-items:start}}
.dash-main{display:grid;gap:18px}
.dash-rail{display:grid;gap:18px}
.card.pinned{border-color:var(--red)}
.checkrow{display:flex;flex-wrap:wrap;gap:6px 14px;align-items:center;margin:6px 0}
.check{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-weight:600}
.check input{margin:0}
