:root {
  --navy:#080f1a; --deep:#0a1628; --panel:#0d1f38; --border:#1a3a5c;
  --accent:#1e5fa8; --bright:#2e7dd4; --glow:#4a9eff;
  --text:#c8d8e8; --muted:#5a7a9a; --white:#e8f2ff;
  --red:#c0392b; --green:#27ae60; --orange:#f39c12;
  --mono:'IBM Plex Mono',monospace;
  --sans:'IBM Plex Sans',sans-serif;
  --display:'Bebas Neue',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--navy);color:var(--text);font-family:var(--sans);font-weight:300;line-height:1.6;overflow-x:hidden;min-height:100vh}
body::before{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.03) 2px,rgba(0,0,0,0.03) 4px);pointer-events:none;z-index:9999}

/* ── TOP NAV ── */
.top-nav{position:fixed;top:0;left:0;right:0;z-index:100;height:56px;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(30,95,168,0.2);background:rgba(8,15,26,0.95);backdrop-filter:blur(12px)}
.nav-logo{font-family:var(--display);font-size:1.2rem;letter-spacing:0.2em;color:var(--white);text-decoration:none}
.nav-logo span{color:var(--glow)}
.nav-center{display:flex;gap:0.2rem}
.nav-link{font-family:var(--mono);font-size:0.65rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:0.4rem 0.8rem;border-radius:2px;transition:all 0.2s}
.nav-link:hover{color:var(--glow)}
.nav-link.active{color:var(--white);background:rgba(30,95,168,0.2);border-bottom:2px solid var(--glow)}
.nav-right{display:flex;align-items:center;gap:1rem}
.nav-search{background:var(--panel);border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:0.75rem;padding:0.4rem 0.8rem;outline:none;width:220px;transition:border-color 0.2s}
.nav-search:focus{border-color:var(--accent)}
.nav-search::placeholder{color:var(--muted)}
.nav-user{font-family:var(--mono);font-size:0.65rem;color:var(--muted);letter-spacing:0.1em}
.btn-logout{font-family:var(--mono);font-size:0.65rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.3rem 0.8rem;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all 0.2s}
.btn-logout:hover{border-color:var(--red);color:var(--red)}

/* ── PAGE WRAPPER ── */
.page-wrap{padding:5rem 0 3rem}
.page-inner{max-width:1400px;margin:0 auto;padding:2rem 3rem}
.page-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem}
.page-title{font-family:var(--display);font-size:2.5rem;color:var(--white);letter-spacing:0.05em}
.page-meta{font-family:var(--mono);font-size:0.65rem;color:var(--muted);letter-spacing:0.1em;text-align:right;line-height:1.8}
.live-dot{display:inline-block;width:7px;height:7px;background:var(--green);border-radius:50%;margin-right:0.4rem;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}

/* ── SECTION TAG ── */
.section-tag{font-family:var(--mono);font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--glow);margin-bottom:0.8rem}
.section-tag::before{content:'// ';color:var(--muted)}

/* ── STAT CARDS ── */
.stat-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:2rem}
.stat-card{padding:1.2rem;border:1px solid var(--border);background:var(--panel);position:relative;overflow:hidden}
.stat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent)}
.stat-num{font-family:var(--display);font-size:2.5rem;color:var(--white);line-height:1;margin-bottom:0.2rem}
.stat-lbl{font-family:var(--mono);font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted)}

/* ── SEARCH BAR ── */
.search-bar{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem;padding:1rem;background:var(--panel);border:1px solid var(--border)}
.search-bar-input{flex:1;background:transparent;border:none;color:var(--text);font-family:var(--mono);font-size:0.9rem;outline:none}
.search-bar-input::placeholder{color:var(--muted)}
.search-bar-label{font-family:var(--mono);font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.search-clear{font-family:var(--mono);font-size:0.65rem;color:var(--muted);background:none;border:none;cursor:pointer;padding:0.2rem 0.5rem}
.search-clear:hover{color:var(--text)}

/* ── TABS ── */
.tab-bar{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:1.5rem;flex-wrap:wrap}
.tab-btn{font-family:var(--mono);font-size:0.65rem;letter-spacing:0.15em;text-transform:uppercase;padding:0.8rem 1.2rem;background:transparent;color:var(--muted);border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all 0.2s;white-space:nowrap}
.tab-btn.active{color:var(--glow);border-bottom-color:var(--glow)}
.tab-btn:hover{color:var(--text)}
.tab-pane{display:none}
.tab-pane.active{display:block}

/* ── FILTER BAR ── */
.filter-bar{display:flex;gap:0.5rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}
.filter-lbl{font-family:var(--mono);font-size:0.6rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.filter-btn{font-family:var(--mono);font-size:0.6rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.3rem 0.7rem;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all 0.2s}
.filter-btn.active{border-color:var(--glow);color:var(--glow);background:rgba(74,158,255,0.08)}
.filter-btn:hover{border-color:var(--accent);color:var(--text)}

/* ── TABLES ── */
.data-table{width:100%;border-collapse:collapse;font-size:0.85rem}
.data-table th{font-family:var(--mono);font-size:0.58rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);text-align:left;padding:0.7rem 1rem;border-bottom:1px solid var(--border);background:var(--deep);white-space:nowrap}
.data-table td{padding:0.8rem 1rem;border-bottom:1px solid rgba(26,58,92,0.4);color:var(--text);vertical-align:top;line-height:1.5}
.data-table tr:hover td{background:rgba(13,31,56,0.5)}
.data-table td.mono{font-family:var(--mono);font-size:0.75rem;color:var(--muted)}
.data-table td.glow{font-family:var(--mono);font-size:0.8rem;color:var(--glow)}
.empty-row td{font-family:var(--mono);font-size:0.7rem;color:var(--muted);text-align:center;padding:3rem;letter-spacing:0.1em}

/* ── BADGES ── */
.badge{font-family:var(--mono);font-size:0.58rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.2rem 0.5rem;border:1px solid;display:inline-block;white-space:nowrap}
.badge-person{color:var(--glow);border-color:rgba(74,158,255,0.3);background:rgba(74,158,255,0.05)}
.badge-organization{color:var(--orange);border-color:rgba(243,156,18,0.3);background:rgba(243,156,18,0.05)}
.badge-location{color:var(--green);border-color:rgba(39,174,96,0.3);background:rgba(39,174,96,0.05)}
.badge-other{color:var(--muted);border-color:var(--border)}
.badge-open{color:var(--glow);border-color:rgba(74,158,255,0.3);background:rgba(74,158,255,0.05)}
.badge-progress{color:var(--orange);border-color:rgba(243,156,18,0.3);background:rgba(243,156,18,0.05)}
.badge-confirmed{color:var(--green);border-color:rgba(39,174,96,0.3);background:rgba(39,174,96,0.05)}
.badge-closed{color:var(--muted);border-color:var(--border)}

/* ── CARDS ── */
.card{padding:1.5rem;border:1px solid var(--border);background:var(--panel);margin-bottom:1rem;transition:border-color 0.2s}
.card:hover{border-color:var(--accent)}
.card-title{font-family:var(--mono);font-size:0.8rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--white);margin-bottom:0.5rem}
.card-body{font-size:0.9rem;color:var(--muted);line-height:1.7}
.card-meta{font-family:var(--mono);font-size:0.6rem;color:var(--border);margin-top:0.8rem;letter-spacing:0.08em}
.card-accent{border-left:3px solid var(--accent)}
.card-accent:hover{border-left-color:var(--glow)}

/* ── FORMS ── */
.form-group{display:flex;flex-direction:column;gap:0.4rem;margin-bottom:1rem}
.form-label{font-family:var(--mono);font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted)}
.form-input,.form-textarea,.form-select{background:var(--panel);border:1px solid var(--border);color:var(--text);font-family:var(--sans);font-size:0.9rem;padding:0.7rem 1rem;outline:none;transition:border-color 0.2s;width:100%;-webkit-appearance:none}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--accent)}
.form-textarea{min-height:120px;resize:vertical;font-family:var(--sans)}
.form-select option{background:var(--panel)}
.form-note{font-family:var(--mono);font-size:0.6rem;color:var(--muted);letter-spacing:0.05em}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* ── BUTTONS ── */
.btn{font-family:var(--mono);font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.7rem 1.5rem;border:none;cursor:pointer;transition:all 0.2s;display:inline-block;text-decoration:none}
.btn-primary{background:var(--accent);color:var(--white)}
.btn-primary:hover{background:var(--bright)}
.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{border-color:var(--accent);color:var(--glow)}
.btn-green{background:var(--green);color:var(--white)}
.btn-green:hover{background:#219a52}
.btn-danger{background:transparent;color:var(--red);border:1px solid rgba(192,57,43,0.3)}
.btn-danger:hover{background:rgba(192,57,43,0.1)}
.btn-sm{padding:0.4rem 0.8rem;font-size:0.65rem}

/* ── ALERTS ── */
.alert{font-family:var(--mono);font-size:0.75rem;padding:0.8rem 1rem;border:1px solid;letter-spacing:0.05em;margin-bottom:1rem}
.alert-success{color:var(--green);border-color:rgba(39,174,96,0.3);background:rgba(39,174,96,0.05)}
.alert-error{color:var(--red);border-color:rgba(192,57,43,0.3);background:rgba(192,57,43,0.05)}
.alert-info{color:var(--glow);border-color:rgba(74,158,255,0.3);background:rgba(74,158,255,0.05)}

/* ── LOGIN GATE ── */
.gate-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}
.gate-box{max-width:400px;width:100%;text-align:center;padding:3rem 2rem}
.gate-icon{font-size:2.5rem;margin-bottom:1.5rem;display:block}
.gate-title{font-family:var(--display);font-size:2.5rem;color:var(--white);letter-spacing:0.1em;margin-bottom:0.3rem}
.gate-sub{font-family:var(--mono);font-size:0.65rem;color:var(--muted);letter-spacing:0.2em;text-transform:uppercase;margin-bottom:2rem}
.gate-input-row{display:flex;margin-bottom:0.8rem}
.gate-input{flex:1;background:var(--panel);border:1px solid var(--border);border-right:none;color:var(--text);font-family:var(--mono);font-size:0.9rem;padding:0.8rem 1rem;outline:none;transition:border-color 0.2s}
.gate-input:focus{border-color:var(--accent)}
.gate-btn{font-family:var(--mono);font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.8rem 1.5rem;background:var(--accent);color:var(--white);border:none;cursor:pointer;transition:background 0.2s;white-space:nowrap}
.gate-btn:hover{background:var(--bright)}
.gate-error{font-family:var(--mono);font-size:0.7rem;color:var(--red);letter-spacing:0.1em;display:none;margin-top:0.5rem}
.gate-links{display:flex;justify-content:center;gap:1.5rem;margin-top:2rem}
.gate-link{font-family:var(--mono);font-size:0.65rem;letter-spacing:0.1em;color:var(--muted);text-decoration:none;text-transform:uppercase;transition:color 0.2s}
.gate-link:hover{color:var(--glow)}

/* ── MISC ── */
.divider{border:none;border-top:1px solid var(--border);margin:2rem 0}
.text-mono{font-family:var(--mono);font-size:0.8rem}
.text-muted{color:var(--muted)}
.text-glow{color:var(--glow)}
.text-green{color:var(--green)}
.text-red{color:var(--red)}
.flex{display:flex} .flex-gap{gap:1rem} .flex-wrap{flex-wrap:wrap} .items-center{align-items:center} .justify-between{justify-content:space-between}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem}
.mb-1{margin-bottom:0.5rem} .mb-2{margin-bottom:1rem} .mb-3{margin-bottom:1.5rem} .mb-4{margin-bottom:2rem}
.mt-1{margin-top:0.5rem} .mt-2{margin-top:1rem}

@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.fade-in{opacity:0;transform:translateY(16px);transition:opacity 0.5s ease,transform 0.5s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

@media(max-width:900px){
  .page-inner{padding:1.5rem}
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3,.form-row{grid-template-columns:1fr}
  .top-nav .nav-center{display:none}
  .nav-search{width:140px}
}
