/* styles.css — Carr NeuroClinic Polarity Engine Master Platform
   Black ground / bone text / clinical teal accent. Dark professional clinical UI. */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Public+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --ground:#080c0f; --panel:#101a1f; --panel-2:#16252c; --panel-3:#1c2f37; --line:#26404a;
  --bone:#e8eef0; --bone-dim:#aebec5; --muted:#7a929b;
  --teal:#19c2ad; --teal-deep:#0e7c74; --teal-glow:rgba(25,194,173,.18);
  --warn:#e6b450; --bad:#e76a6a; --good:#3ad29f; --shush:#e07a2c;
  --display:'Fraunces',Georgia,serif; --body:'Public Sans',system-ui,sans-serif; --mono:'IBM Plex Mono',monospace;
  --r:10px; --shadow:0 8px 30px rgba(0,0,0,.55);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:
    radial-gradient(1400px 700px at 75% -15%,#13242b 0,var(--ground) 55%),
    var(--ground);
  color:var(--bone);font-family:var(--body);font-size:15px;line-height:1.5;
}
button{font-family:var(--body);cursor:pointer}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
.hidden{display:none!important}
.mono{font-family:var(--mono);font-size:13px}
.src{font-family:var(--mono);font-size:11px;color:var(--muted)}
.src.k{color:var(--good)} .src.f{color:var(--warn)}
.blocked{color:var(--bad);font-weight:700}
.allowed{color:var(--good);font-weight:700}

/* ---- splash / gates ---- */
.gate{max-width:780px;margin:0 auto;padding:7vh 24px}
.brandmark{font-family:var(--display);font-size:13px;letter-spacing:.34em;text-transform:uppercase;color:var(--teal)}
.gate h1{font-family:var(--display);font-weight:600;font-size:clamp(42px,7vw,76px);line-height:1.02;margin:10px 0 6px}
.gate .sub{color:var(--bone-dim);font-size:18px;max-width:60ch}
.gate .ver{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:18px}
.legalbox{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px;margin:22px 0;max-height:50vh;overflow:auto}
.legalbox h3{margin:.2em 0;color:var(--teal)}
.legalbox ul{margin:.4em 0 1em;padding-left:1.1em}
.legalbox li{margin:.25em 0;color:#cfdde2}
.btn{background:var(--teal);color:#04201d;border:0;border-radius:9px;padding:12px 22px;font-weight:700;font-size:15px}
.btn:hover{background:#22d8c1;transform:translateY(-1px)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.ghost{background:transparent;color:var(--bone);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--teal);background:rgba(25,194,173,.06)}
.btn.sm{padding:7px 13px;font-size:13px;border-radius:7px}
.btn.danger{background:transparent;border:1px solid var(--bad);color:var(--bad)}
.btn.shush{background:var(--shush);color:#221107;border:0}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* ---- app shell ---- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:#0a1418;border-right:1px solid var(--line);padding:18px 12px;position:sticky;top:0;height:100vh;overflow:auto}
.side .logo{font-family:var(--display);font-size:20px;font-weight:600;padding:6px 10px 4px;line-height:1.1}
.side .logo small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-top:4px}
.lane-strip{font-family:var(--mono);font-size:10px;color:var(--bone-dim);padding:4px 10px 12px;letter-spacing:.05em}
.lane-strip .lane-pill{display:inline-block;padding:2px 8px;border-radius:8px;background:var(--panel-2);border:1px solid var(--line);color:var(--teal)}
.lane-strip .lane-pill.shush{color:var(--shush);border-color:var(--shush)}
.lane-strip .lane-pill.benthouse{color:#cfa;border-color:#aac}
.nav a{display:block;color:#b9ccd2;text-decoration:none;padding:8px 12px;border-radius:7px;font-size:13.5px;margin:1px 0}
.nav a:hover{background:var(--panel-2);text-decoration:none}
.nav a.active{background:var(--teal-deep);color:#eafffb;font-weight:600}
.nav .sep{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#5d7178;padding:14px 12px 4px}
.main{padding:24px 30px 60px;max-width:1280px}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.topbar h2{font-family:var(--display);font-weight:600;font-size:28px;margin:0;line-height:1.1}
.badge{font-family:var(--mono);font-size:11px;padding:4px 10px;border-radius:18px;border:1px solid var(--line);color:var(--bone-dim)}
.badge.carr{border-color:var(--teal-deep);color:var(--teal)}
.badge.shush{border-color:var(--shush);color:var(--shush)}
.badge.good{border-color:var(--good);color:var(--good)}
.badge.warn{border-color:var(--warn);color:var(--warn)}
.badge.bad{border-color:var(--bad);color:var(--bad)}
.badge.dot::before{content:"●";margin-right:6px}

/* ---- cards / grids ---- */
.grid{display:grid;gap:14px}
.grid.c2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.grid.c3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.grid.c4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.card{background:linear-gradient(180deg,var(--panel),#0c161b);border:1px solid var(--line);border-radius:var(--r);padding:16px;box-shadow:var(--shadow)}
.card h3{margin:0 0 10px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);font-weight:700}
.card h4{margin:14px 0 6px;font-size:13px;color:var(--bone);font-weight:600}
.card .big{font-family:var(--display);font-size:32px;font-weight:600;line-height:1.1}
.card .k{color:var(--bone-dim);font-size:13px}
.kv{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dashed var(--line);font-size:13.5px}
.kv:last-child{border:0}
.kv b{color:#fff;font-weight:600}
.kv span:first-child{color:var(--bone-dim)}

/* ---- forms ---- */
label{display:block;font-size:13px;color:var(--bone-dim);margin:12px 0 5px;font-weight:500}
input,textarea,select{width:100%;background:#0a1418;border:1px solid var(--line);color:var(--bone);
  border-radius:7px;padding:9px 11px;font-family:var(--body);font-size:14px;transition:border-color .15s}
textarea{min-height:64px;resize:vertical;line-height:1.5}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 2px var(--teal-glow)}
.scale{display:flex;align-items:center;gap:12px}
.scale input[type=range]{accent-color:var(--teal);flex:1}
.scale .val{font-family:var(--mono);min-width:42px;text-align:right;color:var(--teal);font-weight:600}
.checks label{display:inline-flex;align-items:center;gap:7px;color:var(--bone);margin:6px 14px 0 0;width:auto;font-weight:400}
.checks input{width:auto}
.fieldnote{font-size:12px;color:var(--muted);margin:-4px 0 8px}

/* ---- tables ---- */
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th,table.tbl td{border-bottom:1px solid var(--line);padding:8px 8px;text-align:left;vertical-align:top}
table.tbl th{color:var(--bone-dim);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase}
table.tbl tr:hover td{background:rgba(25,194,173,.04)}
.bar{height:6px;background:#0b1418;border-radius:4px;overflow:hidden;min-width:80px}
.bar>i{display:block;height:100%;background:linear-gradient(90deg,var(--teal-deep),var(--teal))}
.tag{font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:5px;border:1px solid var(--line);color:var(--bone-dim)}

/* ---- status / pills ---- */
.status{font-weight:700;padding:3px 10px;border-radius:7px;font-size:11px;letter-spacing:.05em;text-transform:uppercase}
.status.green,.status.YES{background:rgba(58,210,159,.15);color:var(--good)}
.status.yellow,.status.WAIT{background:rgba(230,180,80,.15);color:var(--warn)}
.status.red,.status.NO{background:rgba(231,106,106,.15);color:var(--bad)}

/* ---- notices ---- */
.notice{background:var(--panel-2);border-left:3px solid var(--teal);padding:11px 14px;border-radius:7px;font-size:13px;color:#cfdde2;margin:10px 0}
.notice.warn{border-color:var(--warn)}
.notice.bad{border-color:var(--bad)}
.notice.shush{border-color:var(--shush)}

/* ---- empty / toast ---- */
.empty{color:var(--muted);padding:30px;text-align:center;border:1px dashed var(--line);border-radius:var(--r);font-size:14px}
.toast{position:fixed;right:20px;bottom:20px;background:var(--teal-deep);color:#eafffb;padding:12px 16px;border-radius:9px;box-shadow:var(--shadow);z-index:50;font-weight:600}

/* ---- pillar/vector blocks (P.L.A.Y. + F.P.A.) ---- */
.pillar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:14px 0}
.pillar{background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:14px;text-align:center}
.pillar b{display:block;font-size:11px;color:var(--teal);letter-spacing:.08em;text-transform:uppercase;font-weight:700}
.pillar .n{font-family:var(--display);font-size:36px;font-weight:600;color:var(--bone);margin:4px 0}
.pillar small{color:var(--bone-dim);font-size:11px}

/* ---- decoder / critics / bleed blocks ---- */
.decoder-block,.critics-banner,.bleed-ok,.bleed-warn,.bleed-fail,.ceiling-banner{
  border-radius:8px;padding:10px 14px;margin:10px 0;font-size:13px
}
.decoder-block{background:rgba(25,194,173,.06);border:1px solid var(--teal-deep)}
.decoder-block details{margin:6px 0}
.decoder-block summary{cursor:pointer;color:var(--teal);font-weight:600}
.critics-banner.ok{background:rgba(58,210,159,.10);border-left:3px solid var(--good)}
.critics-banner.warn{background:rgba(231,106,106,.10);border-left:3px solid var(--bad)}
.bleed-ok{background:rgba(58,210,159,.08);color:var(--good);border-left:3px solid var(--good)}
.bleed-warn{background:rgba(230,180,80,.10);color:var(--warn);border-left:3px solid var(--warn)}
.bleed-fail{background:rgba(231,106,106,.12);color:var(--bad);border-left:3px solid var(--bad);font-weight:600}
.ceiling-banner{background:var(--panel);border:1px solid var(--line);color:var(--bone-dim);font-family:var(--mono);font-size:11px}
.ceiling-banner code{background:var(--panel-3);padding:1px 6px;border-radius:4px;color:var(--teal)}

/* ---- lineage strip ---- */
.lineage-strip{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-family:var(--mono);font-size:11px;color:var(--muted);padding:8px 0}
.lin-node{background:var(--panel-2);border:1px solid var(--line);padding:3px 8px;border-radius:5px;color:var(--bone-dim)}
.lin-arrow{color:var(--teal)}
.lineage-block{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:14px;margin:14px 0}
.lineage-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--teal);text-transform:uppercase;margin-bottom:6px}
.lineage-rootq{font-style:italic;margin-top:10px;color:var(--bone-dim);font-size:13px;padding:8px 12px;border-left:2px solid var(--teal);background:rgba(25,194,173,.04)}
.lineage-auth{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:8px}

/* ---- shush watermark ---- */
.shush-active{position:relative}
.shush-active::after{
  content:"SHUSH · PRIVATE";position:fixed;top:42%;left:0;right:0;text-align:center;
  font-family:var(--display);font-size:72px;font-weight:600;
  color:rgba(224,122,44,.04);transform:rotate(-22deg);pointer-events:none;letter-spacing:.2em;z-index:1
}

/* lil bro chat */
.lilbro-panel{background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:14px;margin:10px 0}
.lilbro-msg{padding:8px 12px;border-radius:7px;margin:6px 0;font-size:13.5px;white-space:pre-wrap}
.lilbro-msg.user{background:var(--panel-2);border-left:3px solid var(--bone-dim)}
.lilbro-msg.bro{background:rgba(25,194,173,.06);border-left:3px solid var(--teal)}
.lilbro-msg .label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:4px}
