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

:root{
  --ground:#0a0f12; --panel:#111a1f; --panel-2:#16232a; --line:#22343d;
  --bone:#e8eef0; --muted:#8aa1aa; --teal:#19c2ad; --teal-deep:#0e7c74;
  --warn:#e6b450; --bad:#e76a6a; --good:#3ad29f;
  --display:'Fraunces',Georgia,serif; --body:'Public Sans',system-ui,sans-serif; --mono:'IBM Plex Mono',monospace;
  --r:12px; --shadow:0 8px 30px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:radial-gradient(1200px 600px at 80% -10%,#13242b 0,var(--ground) 60%);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)}
.hidden{display:none!important}
.mono{font-family:var(--mono);font-size:13px}

/* ---- splash / gates ---- */
.gate{max-width:760px;margin:0 auto;padding:8vh 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(38px,6vw,68px);line-height:1.02;margin:10px 0 6px}
.gate .sub{color:var(--muted);font-size:18px;max-width:54ch}
.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:24px 0;max-height:46vh;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:10px;padding:12px 22px;font-weight:700;font-size:15px}
.btn:hover{background:#22d8c1}
.btn.ghost{background:transparent;color:var(--bone);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--teal)}
.btn.sm{padding:7px 13px;font-size:13px;border-radius:8px}
.btn.danger{background:transparent;border:1px solid var(--bad);color:var(--bad)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* ---- app shell ---- */
.app{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.side{background:#0c1419;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 14px}
.side .logo small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}
.nav a{display:block;color:#b9ccd2;text-decoration:none;padding:9px 12px;border-radius:8px;font-size:14px;margin:2px 0}
.nav a:hover{background:var(--panel-2)}
.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:26px 30px 60px;max-width:1100px}
.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}
.badge{font-family:var(--mono);font-size:11px;padding:4px 10px;border-radius:20px;border:1px solid var(--line);color:var(--muted)}
.badge.carr{border-color:var(--teal-deep);color:var(--teal)}
.badge.shush{border-color:var(--warn);color:var(--warn)}
.badge.dot::before{content:"●";margin-right:6px}

/* ---- cards ---- */
.grid{display:grid;gap:16px}
.grid.c2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid.c3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card{background:linear-gradient(180deg,var(--panel),#0e171c);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--shadow)}
.card h3{margin:0 0 10px;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal)}
.card .big{font-family:var(--display);font-size:34px;font-weight:600}
.card .k{color:var(--muted);font-size:13px}
.kv{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed var(--line);font-size:14px}
.kv:last-child{border:0}
.kv b{color:#fff}

/* ---- forms ---- */
label{display:block;font-size:13px;color:var(--muted);margin:12px 0 5px}
input,textarea,select{width:100%;background:#0b1418;border:1px solid var(--line);color:var(--bone);border-radius:8px;padding:9px 11px;font-family:var(--body);font-size:14px}
textarea{min-height:64px;resize:vertical}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--teal)}
.scale{display:flex;align-items:center;gap:12px}
.scale input[type=range]{accent-color:var(--teal)}
.scale .val{font-family:var(--mono);min-width:38px;text-align:right;color:var(--teal)}
.checks label{display:inline-flex;align-items:center;gap:7px;color:var(--bone);margin:6px 14px 0 0;width:auto}
.checks input{width:auto}
.sectioncard{margin-bottom:14px}
.sectioncard h3{font-family:var(--display);text-transform:none;letter-spacing:0;color:var(--bone);font-size:18px}
.fieldnote{font-size:12px;color:var(--muted);margin:-4px 0 8px}

/* ---- vectors / maps ---- */
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th,table.tbl td{border-bottom:1px solid var(--line);padding:9px 8px;text-align:left;vertical-align:top}
table.tbl th{color:var(--muted);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.bar{height:7px;background:#0b1418;border-radius:5px;overflow:hidden;min-width:90px}
.bar>i{display:block;height:100%;background:linear-gradient(90deg,var(--teal-deep),var(--teal))}
.tag{font-family:var(--mono);font-size:11px;padding:2px 8px;border-radius:6px;border:1px solid var(--line);color:var(--muted)}
.status{font-weight:700;padding:3px 10px;border-radius:8px;font-size:12px}
.status.green{background:rgba(58,210,159,.15);color:var(--good)}
.status.yellow{background:rgba(230,180,80,.15);color:var(--warn)}
.status.red{background:rgba(231,106,106,.15);color:var(--bad)}
.shushtxt{color:var(--warn);font-style:italic}
.blocked{color:var(--bad)}
.allowed{color:var(--good)}
.notice{background:var(--panel-2);border-left:3px solid var(--teal);padding:11px 14px;border-radius:8px;font-size:13px;color:#cfdde2;margin:10px 0}
.notice.warn{border-color:var(--warn)}
.notice.bad{border-color:var(--bad)}
.empty{color:var(--muted);padding:30px;text-align:center;border:1px dashed var(--line);border-radius:var(--r)}
.toast{position:fixed;right:20px;bottom:20px;background:var(--teal-deep);color:#eafffb;padding:12px 16px;border-radius:10px;box-shadow:var(--shadow);z-index:50}
.src{font-family:var(--mono);font-size:11px;color:var(--muted)}
.src.k{color:var(--good)} .src.f{color:var(--warn)}
