
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:#020617;color:#e5e7eb}
a{text-decoration:none;color:inherit}
.app{display:grid;grid-template-rows:auto 28px 1fr auto;min-height:100vh}
/* Ribbon + Ticker */
.ribbon{display:flex;align-items:center;gap:10px;background:linear-gradient(90deg,#0B1533,#1f2937);border-bottom:1px solid #1f2937;padding:6px 12px;position:sticky;top:0;z-index:50}
.ribbon .badge{border:1px solid #C6A45A;color:#C6A45A;border-radius:999px;padding:2px 8px;font-size:11px}
.ribbon img{height:18px}
.ribbon .mini{font-size:12px;color:#9ca3af}
.ribbon .right{margin-left:auto;display:flex;gap:8px;align-items:center}
.ticker{height:28px;background:rgba(220,38,38,.12);border-bottom:1px solid rgba(220,38,38,.35);display:flex;align-items:center;overflow:hidden;padding:0 12px;font-size:12px}
.ticker .label{font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-right:12px;color:#fecaca}
.ticker .track{white-space:nowrap;animation:ticker-scroll 24s linear infinite}
.ticker:hover .track{animation-play-state:paused}
@keyframes ticker-scroll{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}
/* Topbar */
.topbar{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#020617;border-bottom:1px solid #111827;position:sticky;top:28px;z-index:40}
.brand{display:flex;align-items:center;gap:8px;font-weight:600}
.brand img{height:24px}
.nav{display:flex;gap:6px;margin-left:12px}
.btn{border-radius:8px;border:1px solid #374151;background:#111827;color:#e5e7eb;font-size:13px;padding:6px 10px;cursor:pointer}
.btn:hover{background:#020617}
.btn.gold{background:#eab308;border-color:#eab308;color:#111827;font-weight:600}
.btn-compact{padding:2px 8px;font-size:11px}
.btn-danger{border-color:#b91c1c;color:#fecaca}
.select{border-radius:8px;border:1px solid #374151;background:#020617;color:#e5e7eb;padding:6px 10px;font-size:13px}
.input{border-radius:8px;border:1px solid #374151;background:#020617;color:#e5e7eb;padding:6px 10px;font-size:13px}
/* Layout */
.main{display:grid;grid-template-columns:260px 1fr;min-height:0}
.sidebar{background:#020617;border-right:1px solid #111827;padding:10px 8px;font-size:13px;position:sticky;top:112px;height:calc(100vh - 112px);overflow:auto}
.section-title{font-size:11px;color:#9ca3af;text-transform:uppercase;margin:4px 4px}
.side-link{display:block;padding:6px 8px;border-radius:6px;color:#e5e7eb}
.side-link:hover,.side-link.active{background:#111827}
.content{padding:12px;overflow:auto}
.panel{background:#020617;border-radius:10px;border:1px solid #1f2937;padding:10px;margin-bottom:12px;box-shadow:0 10px 24px rgba(15,23,42,.7)}
.panel h3{margin:0 0 6px}
.small{font-size:12px;color:#9ca3af}
/* KPI + widgets */
.kpis{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:8px;margin-top:8px}
.tile{border-radius:10px;border:1px solid #1f2937;padding:6px 8px;background:#020617}
.tile h4{margin:0 0 2px;font-size:11px;text-transform:uppercase;color:#9ca3af}
.tile .val{font-size:18px}
.time-toggle{margin-top:6px;display:flex;gap:4px;flex-wrap:wrap}
.time-btn{border-radius:999px;border:1px solid #374151;background:transparent;color:#9ca3af;font-size:11px;padding:2px 8px;cursor:pointer}
.time-btn.active{background:#eab308;border-color:#eab308;color:#111827}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.progress{height:8px;border-radius:999px;background:#020617;border:1px solid #374151;overflow:hidden}
.progress>div{height:100%;background:#16a34a}
.heatmap{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-top:6px}
.cell{border-radius:6px;padding:6px 4px;text-align:center;font-size:12px;border:1px solid #374151;cursor:pointer}
.cell.bad{background:#450a0a}.cell.warn{background:#451a03}.cell.good{background:#022c22}
.table{width:100%;border-collapse:collapse;font-size:13px;margin-top:4px}
.table th,.table td{border-bottom:1px solid #1f2937;padding:4px 4px;text-align:left}
.table th{font-size:11px;color:#9ca3af;text-transform:uppercase}
.badge{border-radius:6px;border:1px solid #4b5563;font-size:11px;padding:1px 6px}
.badge.high{border-color:#dc2626;color:#fecaca}
.badge.med{border-color:#eab308;color:#fef9c3}
/* Safety chips */
.safety-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.chip{border-radius:999px;border:1px solid #374151;padding:4px 10px;font-size:12px;display:flex;align-items:center;gap:6px}
.chip-weather{background:rgba(37,99,235,.15)}
.chip-occupancy-safe{background:rgba(22,163,74,.15)}
.chip-occupancy-warn{background:rgba(234,179,8,.15)}
.chip-occupancy-critical{background:rgba(220,38,38,.15)}
/* GM Notes + modal */
.gm-notes{position:fixed;top:112px;right:0;bottom:0;width:280px;background:#020617;border-left:1px solid #1f2937;padding:8px;z-index:25;display:flex;flex-direction:column}
.gm-notes textarea{flex:1;border-radius:8px;border:1px solid #374151;background:#020617;color:#e5e7eb;font-size:13px;padding:6px;resize:none}
.gm-notes-footer{margin-top:4px;font-size:11px;color:#9ca3af}
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(15,23,42,.7);z-index:30}
.modal .window{background:#020617;border-radius:10px;border:1px solid #1f2937;padding:10px;width:90%;max-width:520px}
.actions{display:flex;justify-content:flex-end;gap:6px;margin-top:8px}
/* Emergency styling */
body.emergency-mode .topbar{background:#7f1d1d;border-bottom-color:#b91c1c}
body.emergency-mode .panel{border-color:rgba(248,113,113,.8);box-shadow:0 0 0 1px rgba(248,113,113,.4),0 18px 40px rgba(127,29,29,.7)}
body.emergency-mode .ticker{background:rgba(239,68,68,.2);border-bottom-color:rgba(239,68,68,.75)}
body.emergency-mode #occupancy-chip{border-color:rgba(248,113,113,.9)}
body.emergency-mode .non-critical{display:none!important}
.emergency-badge{border-radius:999px;border:1px solid rgba(148,163,184,.7);font-size:11px;padding:2px 8px;margin-left:8px}
.emergency-badge.active{border-color:rgba(248,113,113,.9);color:#fecaca;background:rgba(185,28,28,.5)}
.emergency-badge.clear{border-color:rgba(34,197,94,.9);color:#bbf7d0;background:rgba(22,163,74,.35)}
/* Movies scroller */
.marquee{overflow:hidden;position:relative;border-top:1px solid #111827;border-bottom:1px solid #111827;background:#0b1020}
.marquee-track{display:flex;gap:12px;padding:8px 12px;white-space:nowrap;animation:marquee-x 32s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.movie{display:flex;align-items:center;gap:8px;border:1px solid #1f2937;border-radius:8px;padding:6px 10px;font-size:12px;background:#0b1224}
.movie .tag{border:1px solid #374151;border-radius:6px;padding:1px 6px;font-size:10px;color:#cbd5e1}
@keyframes marquee-x{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
/* Footer */
.footer{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;border-top:1px solid #111827;background:#020617}
.footer .sponsor{display:flex;align-items:center;gap:8px;font-size:12px}
.footer .sponsor strong{color:#C6A45A}
/* Responsive */
@media(max-width:980px){.main{grid-template-columns:1fr}.sidebar{display:none}.kpis{grid-template-columns:repeat(2,minmax(120px,1fr))}}
