:root{
  --bg:#F6F5F1; --surface:#FFFFFF; --ink:#1C2522; --muted:#5C6B66; --faint:#616C66;
  --line:#E4E2DA; --line-strong:#CFCdC4;
  --accent:#0F6E56; --accent-soft:#E1F1EB; --accent-ink:#0A4E3E;
  --amber:#9A6A12; --amber-soft:#F7EEDB; --danger:#9A2D2D; --danger-soft:#F8E9E9;
  --radius:14px; --radius-sm:10px;
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;
  --mono:"SF Mono",ui-monospace,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--accent-ink)}
h1,h2,h3{font-family:var(--serif);font-weight:600;letter-spacing:-.01em}
.app{max-width:1280px;margin:0 auto;padding:0 24px 64px}

/* Header */
header.top{display:flex;align-items:center;justify-content:space-between;padding:22px 0 18px;border-bottom:1px solid var(--line);margin-bottom:26px}
.brand{display:flex;align-items:center;gap:14px}
.brand .mark{width:40px;height:40px;border-radius:11px;background:var(--accent);display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:20px;flex:none}
.brand h1{font-size:20px;margin:0;line-height:1.1}
.brand .wordmark{font-family:var(--sans);font-weight:600;letter-spacing:-.4px}
.brand .mark svg{display:block;width:40px;height:40px}
.brand .wordmark .os-tag{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.06em;color:var(--muted);background:#EFEEE8;border-radius:5px;padding:1px 5px;margin-left:7px;vertical-align:middle;position:relative;top:-2px}
.brand .sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.top .actions{display:flex;gap:10px;align-items:center}

/* Buttons */
.btn{font-family:var(--sans);font-size:14px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);padding:9px 15px;border-radius:10px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:7px}
.btn:hover{border-color:var(--accent);color:var(--accent-ink)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-ink);color:#fff}
.btn.ghost{border-color:transparent;background:transparent;color:var(--muted)}
.btn.ghost:hover{background:#EFEEE8;color:var(--ink)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.sm{padding:5px 10px;font-size:12.5px;border-radius:8px}

/* Layout */
.grid{display:grid;grid-template-columns:minmax(360px,420px) 1fr;gap:26px;align-items:start}
@media(max-width:920px){.grid{grid-template-columns:1fr}}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;margin-bottom:18px}
.card h2{font-size:16.5px;margin:0 0 4px}
.card .desc{color:var(--muted);font-size:13px;margin:0 0 16px}
.section-eyebrow{font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--accent-ink);font-weight:600;font-family:var(--sans)}

/* Mode toggle */
.modes{display:flex;gap:6px;background:#EFEEE8;border-radius:11px;padding:4px;margin-bottom:18px}
.modes button{flex:1;border:none;background:transparent;padding:9px;border-radius:8px;font-size:13.5px;cursor:pointer;color:var(--muted);font-family:var(--sans)}
.modes button.on{background:var(--surface);color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.05);font-weight:500}

/* Form */
.fld{margin-bottom:13px}
.fld label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:5px;font-weight:500}
.fld input,.fld select,.fld textarea{width:100%;font-family:var(--sans);font-size:14px;padding:9px 11px;border:1px solid var(--line-strong);border-radius:9px;background:var(--surface);color:var(--ink)}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
textarea{resize:vertical;min-height:120px;line-height:1.5}
.fldgroup{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}

/* Activity flags */
.flag{display:flex;gap:11px;align-items:flex-start;padding:10px 12px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;cursor:pointer;transition:.12s}
.flag:hover{border-color:var(--line-strong)}
.flag.on{border-color:var(--accent);background:var(--accent-soft)}
.flag input{margin-top:3px;accent-color:var(--accent)}
.flag .l{font-size:13.5px;font-weight:500}
.flag .h{font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.4}

/* Nav */
.nav{display:flex;align-items:center;gap:8px;margin-bottom:24px}
.navtab{font-family:var(--sans);font-size:14px;border:1px solid var(--line-strong);background:var(--surface);color:var(--muted);padding:9px 16px;border-radius:10px;cursor:pointer}
.navtab.on{background:var(--accent);border-color:var(--accent);color:#fff}
.navtab:not(.on):hover{border-color:var(--accent);color:var(--accent-ink)}
.nav-hint{font-size:12px;color:var(--faint);margin-left:4px}

/* Console */
.console-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
@media(max-width:920px){.console-grid{grid-template-columns:1fr}}
.console-grid .card{margin-bottom:0}
.twin-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.gauge{flex:none;width:92px;height:92px;border-radius:50%;display:grid;place-items:center;text-align:center;border:4px solid var(--accent)}
.gauge.high{border-color:var(--accent)}.gauge.medium{border-color:#BA7517}.gauge.low{border-color:#C26}.gauge.critical{border-color:var(--danger)}
.gauge .gn{font-family:var(--serif);font-size:30px;line-height:1}
.gauge .gl{font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.twin-stats{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
.tstat{flex:1;min-width:74px;background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:8px 10px;text-align:center}
.tstat .v{font-family:var(--serif);font-size:19px;line-height:1}
.tstat .k{font-size:10.5px;color:var(--muted);margin-top:3px}
.roles{display:flex;flex-wrap:wrap;gap:5px;margin:6px 0 4px}
.role{font-size:10.5px;background:var(--accent-soft);color:var(--accent-ink);border-radius:20px;padding:3px 9px;cursor:default}
.rbadge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;flex:none;letter-spacing:.02em}
.rbadge.crit{background:var(--danger);color:#fff}.rbadge.high{background:var(--amber-soft);color:var(--amber)}.rbadge.med{background:#E9EFF6;color:#2c5577}.rbadge.low{background:#EFEEE8;color:var(--muted)}
.finding{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--line)}
.finding:last-child{border-bottom:none}
.finding .ft{font-size:13px;font-weight:500;line-height:1.4}
.finding .ff{font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.45}
.finding .capa{margin-left:auto;flex:none;align-self:center}
.rtable{border-collapse:collapse;width:100%;font-size:12.5px}
.rtable th,.rtable td{border:1px solid var(--line);padding:6px 8px;text-align:left;vertical-align:top}
.rtable th{background:#F3F2EC;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.insp{padding:10px 0;border-bottom:1px solid var(--line)}.insp:last-child{border-bottom:none}
.insp-h{display:flex;justify-content:space-between;align-items:center}
.readypct{font-family:var(--serif);font-size:15px}.readypct.high{color:var(--accent-ink)}.readypct.med{color:var(--amber)}.readypct.low{color:var(--danger)}
.codes{display:flex;flex-wrap:wrap;gap:4px;margin:7px 0}
.cc{font-family:var(--mono);font-size:10.5px;padding:2px 6px;border-radius:5px}
.cc.ok{background:var(--accent-soft);color:var(--accent-ink)}.cc.no{background:var(--danger-soft);color:var(--danger)}
.sim-select{width:100%;font-size:13.5px;padding:8px 10px;border:1px solid var(--line-strong);border-radius:9px;margin-top:4px}
.sim-out{margin-top:4px}
.feed{padding:9px 0;border-bottom:1px solid var(--line);opacity:.62}
.feed.rel{opacity:1}
.feed-h{display:flex;justify-content:space-between;font-size:11px}.feed-h .src{color:var(--accent-ink);font-weight:600}.feed-h .dt{color:var(--faint)}
.feed .ft{font-size:13px;font-weight:500;margin-top:2px}.feed .ff{font-size:11.5px;color:var(--muted);margin-top:2px}
.analyze textarea{width:100%;font-family:var(--sans);font-size:13px;padding:8px 10px;border:1px solid var(--line-strong);border-radius:9px;margin-bottom:6px}

/* Catalog */
#catalog{max-height:340px;overflow:auto;border:1px solid var(--line);border-radius:10px;padding:4px}
.cat{border-bottom:1px solid var(--line)}
.cat:last-child{border-bottom:none}
.cat-h{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 10px;cursor:pointer;user-select:none}
.cat-h:hover{background:#FAFAF8}
.cat-h .nm{font-size:13px;font-weight:500}
.cat-h .meta{font-size:11px;color:var(--faint);display:flex;gap:7px;align-items:center}
.cat-h .cnt{background:var(--accent-soft);color:var(--accent-ink);border-radius:20px;padding:1px 7px;font-weight:600}
.cat-items{display:none;flex-wrap:wrap;gap:6px;padding:2px 10px 12px}
.cat.open .cat-items{display:flex}
.chip{font-size:12px;padding:5px 10px;border:1px solid var(--line-strong);border-radius:20px;cursor:pointer;background:var(--surface);transition:.1s;line-height:1.2}
.chip:hover{border-color:var(--accent)}
.chip.on{background:var(--accent);border-color:var(--accent);color:#fff}
.chip .fl{opacity:.7;font-size:10px;margin-left:4px}

/* Results */
.summary{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.metric{flex:1;min-width:120px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px}
.metric .v{font-family:var(--serif);font-size:22px;line-height:1}
.metric .k{font-size:11.5px;color:var(--muted);margin-top:5px}
.metric.accent{background:var(--accent-soft);border-color:#BFE0D3}
.metric.accent .v{color:var(--accent-ink)}

.doclist{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}
.docitem{border:1px solid var(--line);border-radius:9px;padding:9px 11px;cursor:pointer;background:var(--surface);transition:.12s;text-align:left}
.docitem:hover{border-color:var(--accent);background:#FAFAF8}
.docitem.active{border-color:var(--accent);background:var(--accent-soft)}
.docitem .c{font-family:var(--mono);font-size:11px;color:var(--accent-ink);font-weight:600}
.docitem .t{font-size:12.5px;margin-top:3px;line-height:1.35;color:var(--ink)}
.fam-head{grid-column:1/-1;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);font-weight:600;margin:10px 0 2px}
.fam-head:first-child{margin-top:0}

/* badges */
.badge{display:inline-block;font-size:10.5px;padding:2px 7px;border-radius:20px;font-weight:600;letter-spacing:.02em}
.badge.ai{background:var(--accent-soft);color:var(--accent-ink)}
.badge.tmpl{background:#EFEEE8;color:var(--muted)}

/* preview */
.preview{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);min-height:420px}
.preview .phead{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--line);gap:10px;flex-wrap:wrap}
.preview .phead .code{font-family:var(--mono);font-size:12px;color:var(--accent-ink);font-weight:600}
.preview .phead .ttl{font-size:14px;font-weight:500}
.preview .pbody{padding:8px 30px 34px;max-height:64vh;overflow:auto}
.doc-md{font-size:14px;line-height:1.62;color:#26302C}
.doc-md h1{font-size:21px;margin:22px 0 6px}
.doc-md h2{font-size:17px;margin:22px 0 6px}
.doc-md h3{font-size:15px;margin:18px 0 4px;font-family:var(--sans);font-weight:600}
.doc-md table{border-collapse:collapse;width:100%;margin:12px 0;font-size:13px}
.doc-md th,.doc-md td{border:1px solid var(--line-strong);padding:6px 9px;text-align:left;vertical-align:top}
.doc-md th{background:#F3F2EC}
.doc-md code{font-family:var(--mono);font-size:12.5px;background:#F1F0EA;padding:1px 5px;border-radius:5px}
.doc-md ul,.doc-md ol{padding-left:20px}
.doc-md hr{border:none;border-top:1px solid var(--line);margin:18px 0}
.doc-md blockquote{margin:12px 0;padding:8px 14px;border-left:3px solid var(--accent);background:var(--accent-soft);border-radius:0 8px 8px 0}

.empty{display:grid;place-items:center;min-height:420px;text-align:center;color:var(--faint);padding:40px}
.empty .big{font-size:15px;color:var(--muted);margin-bottom:6px}

/* note / callout */
.note{font-size:12px;color:var(--muted);background:#F1F0EA;border-radius:9px;padding:10px 13px;margin-top:8px;line-height:1.5}
.note.amber{background:var(--amber-soft);color:var(--amber)}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(20,28,25,.42);display:none;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal-bg.show{display:flex}
.modal{background:var(--surface);border-radius:16px;max-width:520px;width:100%;padding:26px 28px;max-height:88vh;overflow:auto}
.modal h2{font-size:18px;margin:0 0 4px}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--accent-soft);border-top-color:var(--accent);border-radius:50%;animation:sp .7s linear infinite;vertical-align:-2px}
@keyframes sp{to{transform:rotate(360deg)}}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:10px 18px;border-radius:10px;font-size:13.5px;z-index:60;opacity:0;transition:.25s;pointer-events:none}
.toast.show{opacity:1}
footer.foot{margin-top:30px;padding-top:18px;border-top:1px solid var(--line);font-size:12px;color:var(--faint);line-height:1.6}

/* --- pre-deployment hardening: accessibility + responsive --- */
html{color-scheme:light}
.nav{flex-wrap:wrap}
@media(max-width:560px){.nav-hint{display:none}}
.btn:focus-visible,.navtab:focus-visible,.chip:focus-visible,.docitem:focus-visible,
.modes button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible,
.cat-h:focus-visible,.flag:focus-within{outline:2px solid var(--accent-ink);outline-offset:2px}
@media(max-width:920px){.rtable{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.console-grid .card{min-width:0}}
@media (prefers-reduced-motion: reduce){
  .spin{animation:none;border-top-color:var(--accent);opacity:.6}
  *{transition:none !important}
}
