/* ── Axis Compass Design System — CERC Cohort Analytics ── */
:root {
  --ink:#1E1A14;--ink2:#2A2520;--muted:#7A7265;
  --surface:#F8F6F2;--warm:#EDE9E0;--card:#FFFFFF;
  --gold:#C9962A;--gold2:#E8B84B;--gold-faint:#F5EDD6;
  --red:#C62828;--red-faint:#FFF5F5;
  --green:#2E7D32;--green-faint:#F0F8F0;
  --orange:#E65100;--orange-faint:#FFF8F0;
  --brand:#2B579A;--brand-faint:#EEF3FA;
  --purple:#6D4FC2;--purple-faint:#F0EBFF;
  --teal:#1B7A6E;--teal-faint:#E6F4F2;
  --border:#DDD8CE;--border2:#E8E4DE;
  --r:12px;--rs:8px;
  --shadow:0 2px 16px rgba(30,26,20,.07);
  --shadow2:0 4px 28px rgba(30,26,20,.13);
  --font-d:'Fraunces',Georgia,serif;
  --font-b:'DM Sans',system-ui,sans-serif;
  --font-m:'DM Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);background:var(--surface);color:var(--ink);min-height:100vh;line-height:1.6;font-size:15px}
a{color:var(--brand);text-decoration:none}
button,input,select,textarea{font-family:inherit}
.hidden{display:none!important}

/* ── HEADER ─────────────────────────────── */
.hdr{background:#fff;border-bottom:2px solid var(--gold);padding:0 36px;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200;box-shadow:0 1px 8px rgba(30,26,20,.06)}
.hdr-l{display:flex;align-items:center;gap:14px}
.hex{width:40px;height:40px;background:var(--gold);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:18px;color:#fff}
.hdr h1{font-family:var(--font-d);font-size:19px;font-weight:700;letter-spacing:-.3px;color:var(--ink)}
.hdr .sub{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-top:1px}
.badge{background:var(--gold-faint);border:1px solid rgba(201,150,42,.3);border-radius:20px;padding:4px 14px;font-size:10px;color:var(--gold);font-weight:700;letter-spacing:1px;text-transform:uppercase}

/* ── LAYOUT ─────────────────────────────── */
.wrap{max-width:1200px;margin:0 auto;padding:32px 36px}
.stitle{font-family:var(--font-d);font-size:18px;font-weight:600;margin-bottom:18px;display:flex;align-items:center;gap:10px;color:var(--ink)}
.stitle .n{background:var(--gold);color:#fff;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-b);font-size:12px;font-weight:700;flex-shrink:0}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:24px;margin-bottom:22px;box-shadow:var(--shadow)}

/* ── TEMPLATE BAR ────────────────────────── */
.tbar{display:flex;align-items:center;justify-content:space-between;background:var(--brand-faint);border:1px solid rgba(43,87,154,.2);border-radius:var(--rs);padding:12px 18px;margin-bottom:18px}
.tbar p{font-size:13px;color:var(--muted)}
.tbar button,.btn-p,.btn-s{font-family:var(--font-b);cursor:pointer;border:none;border-radius:var(--rs);font-weight:600;transition:all .2s}
.tbar button{background:var(--brand);color:#fff;padding:7px 16px;font-size:12px}
.tbar button:hover{background:#1e3f73}

/* ── FORMAT TABLE ────────────────────────── */
.ftbl{width:100%;border-collapse:collapse;font-size:12px;margin-top:14px}
.ftbl th{background:var(--ink);color:rgba(255,255,255,.85);text-transform:uppercase;letter-spacing:.8px;font-size:10px;font-weight:600;padding:9px 12px;text-align:left}
.ftbl td{padding:7px 12px;border-bottom:1px solid var(--border);color:var(--muted)}
.ftbl .cn{color:var(--gold);font-weight:600}
.ftbl .cc{color:var(--purple);font-weight:500}
.ftbl .cs{color:var(--teal);font-weight:500}

/* ── UPLOAD ─────────────────────────────── */
.uzone{border:2px dashed var(--border);border-radius:var(--r);padding:44px;text-align:center;cursor:pointer;transition:all .3s;position:relative;overflow:hidden;background:var(--card)}
.uzone:hover,.uzone.over{border-color:var(--gold);background:var(--gold-faint)}
.uzone .ico{font-size:44px;margin-bottom:10px;opacity:.7}
.uzone p{color:var(--muted);font-size:13px}
.uzone .cta{color:var(--gold);font-weight:600}
.uzone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}

/* ── OPTIONS ────────────────────────────── */
.orow{display:flex;gap:18px;flex-wrap:wrap;margin-top:18px}
.ogrp{display:flex;flex-direction:column;gap:5px}
.ogrp label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;font-weight:700}
.ogrp select,.ogrp input[type=text]{background:#fff;border:1.5px solid var(--border);border-radius:var(--rs);padding:9px 13px;color:var(--ink);font-family:var(--font-b);font-size:13px;min-width:190px;outline:none;transition:border-color .2s}
.ogrp select:focus,.ogrp input:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-faint)}

/* ── TOGGLES ────────────────────────────── */
.tg-wrap{margin-top:18px;display:flex;gap:22px;flex-wrap:wrap}
.tg-c{display:flex;align-items:center;gap:9px}
.tg{position:relative;width:44px;height:24px;background:var(--warm);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .3s}
.tg.on{background:var(--gold);border-color:var(--gold)}
.tg .k{position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:all .3s;box-shadow:0 1px 4px rgba(30,26,20,.2)}
.tg.on .k{left:23px}
.tg-l{font-size:12px;color:var(--muted)}

/* ── STATS ──────────────────────────────── */
.sgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:22px}
.scard{background:#fff;border:1px solid var(--border);border-radius:var(--rs);padding:16px;text-align:center;box-shadow:var(--shadow)}
.scard .sv{font-family:var(--font-d);font-size:26px;font-weight:700;color:var(--ink)}
.scard .sl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-top:3px}

/* ── DATA PREVIEW ───────────────────────── */
.dprev{max-height:280px;overflow:auto;border-radius:var(--rs);border:1px solid var(--border);background:var(--card)}
.dprev table{width:100%;border-collapse:collapse;font-size:11px;white-space:nowrap}
.dprev th{background:var(--ink);color:rgba(255,255,255,.85);padding:7px 10px;text-align:left;position:sticky;top:0;font-size:10px;text-transform:uppercase;letter-spacing:.4px}
.dprev td{padding:5px 10px;border-bottom:1px solid var(--border);color:var(--ink2)}
.dprev tr:nth-child(even) td{background:var(--surface)}

/* ── BUTTONS ────────────────────────────── */
.btn-p{background:var(--gold);color:#fff;padding:12px 28px;font-size:14px;display:inline-flex;align-items:center;gap:7px;border-radius:var(--rs);font-weight:700}
.btn-p:hover{background:#b8860b;box-shadow:var(--shadow2);transform:translateY(-1px)}
.btn-p:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.btn-s{background:#fff;border:1.5px solid var(--border);color:var(--muted);padding:11px 22px;font-size:13px;font-weight:500;border-radius:var(--rs)}
.btn-s:hover{border-color:var(--ink);color:var(--ink)}

/* ── STATUS ─────────────────────────────── */
.sbar{display:none;align-items:center;gap:10px;padding:12px 18px;background:var(--brand-faint);border:1px solid rgba(43,87,154,.2);border-radius:var(--rs);margin-top:14px}
.sbar.on{display:flex}
.spin{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:sp .8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.stxt{font-size:12px;color:var(--muted)}

/* ── VALIDATION ITEMS ───────────────────── */
.v-list{display:flex;flex-direction:column;gap:5px;margin-top:12px}
.v-item{display:flex;align-items:center;gap:8px;font-size:12px;padding:6px 12px;border-radius:5px}
.v-item.ok{background:var(--green-faint);color:var(--green)}
.v-item.warn{background:var(--orange-faint);color:var(--orange)}
.v-item.err{background:var(--red-faint);color:var(--red)}

/* ── ON-SCREEN REPORT ───────────────────── */
#reportArea{display:none;margin-top:28px}
.rpt{background:#fff;color:var(--ink);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow2);border:1px solid var(--border)}
.rpt-inner{padding:36px 40px}
.rpt h1{font-family:var(--font-d);color:var(--ink);font-size:22px;border-bottom:3px solid var(--gold);padding-bottom:10px;margin-bottom:6px}
.rpt .rsub{color:var(--muted);font-size:12px;margin-bottom:22px}
.rpt h2{font-family:var(--font-d);font-size:16px;color:var(--ink);margin:24px 0 12px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.rpt h3{font-size:14px;font-weight:600;color:var(--ink);margin:16px 0 7px}
.rpt p{font-size:12px;line-height:1.7;margin-bottom:6px;color:var(--ink2)}
.rpt table{width:100%;border-collapse:collapse;margin:10px 0 16px;font-size:11px}
.rpt th{background:var(--ink);color:rgba(255,255,255,.85);padding:8px 10px;text-align:left;font-weight:600;font-size:10px}
.rpt td{padding:7px 10px;border-bottom:1px solid var(--border);color:var(--ink2)}
.rpt tr:nth-child(even) td{background:var(--surface)}
.rpt .bH{color:var(--green);font-weight:700}
.rpt .bM{color:var(--orange);font-weight:700}
.rpt .bL{color:var(--red);font-weight:700}
.rpt .alert{background:var(--red-faint);border-left:4px solid var(--red);padding:10px 14px;border-radius:4px;margin:10px 0;font-size:12px}
.rpt .info{background:var(--brand-faint);border-left:4px solid var(--brand);padding:10px 14px;border-radius:4px;margin:10px 0;font-size:12px}
.rpt .ok{background:var(--green-faint);border-left:4px solid var(--green);padding:10px 14px;border-radius:4px;margin:10px 0;font-size:12px}
.rpt .rdm{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:12px;margin-bottom:8px}
.rpt .rdm .mh{font-weight:700;color:var(--brand);margin-bottom:5px;font-size:12px}
.rpt .rdm .act{font-size:11px;margin:3px 0;padding-left:10px;border-left:2px solid var(--gold);color:var(--ink2)}
.rpt .stu{margin-bottom:32px;border:1px solid var(--border);border-radius:8px;padding:22px;page-break-inside:avoid;background:#fff}
.rpt .stu-hdr{border-bottom:2px solid var(--gold);padding-bottom:10px;margin-bottom:16px}
.rpt .foot{font-size:10px;color:var(--muted);text-align:center;margin-top:28px;padding-top:14px;border-top:1px solid var(--border)}

/* ── EXPORT BAR ─────────────────────────── */
.export-bar{display:flex;align-items:center;gap:10px;padding:12px 18px;background:#fff;border:1px solid var(--border);border-radius:var(--r);margin-bottom:18px;box-shadow:var(--shadow);flex-wrap:wrap}
.export-bar-label{font-size:13px;font-weight:600;color:var(--ink);margin-right:4px}

/* ── HEX CANVAS ─────────────────────────── */
.hex-canvas-wrap{text-align:center;margin:12px 0}
.hex-canvas-wrap canvas{max-width:280px}

/* ── RESPONSIVE ─────────────────────────── */
@media(max-width:768px){.hdr{padding:0 18px}.wrap{padding:18px}.orow{flex-direction:column}.tg-wrap{flex-direction:column}}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--warm)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.fade{animation:fi .4s ease-out}@keyframes fi{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
