* { margin: 0; padding: 0; box-sizing: border-box; }
body { display: flex; flex-direction: column; height: 100vh;
       font-family: 'Courier New', monospace; background: #080810; color: #00ff88;
       overflow: hidden; }

/* ── HEADER ─────────────────────────────────────────────────── */
#toc-header { display: flex; align-items: center; gap: 16px; padding: 6px 12px;
              background: #0a0a18; border-bottom: 1px solid #00ff8822;
              flex-shrink: 0; flex-wrap: wrap; }
#toc-title  { font-size: 14px; letter-spacing: 3px; color: #00ff88; white-space: nowrap; }
#toc-sub    { color: #335533; font-size: 11px; }
#toc-stats  { display: flex; gap: 10px; flex: 1; }
#toc-right  { display: flex; align-items: center; gap: 10px; margin-left: auto; }
#toc-clock  { font-size: 11px; color: #446644; letter-spacing: 1px; }

.stat-box   { background: #0d0d1a; border: 1px solid #00ff8818; padding: 4px 12px;
              text-align: center; min-width: 70px; }
.alert-box  { border-color: #ff880033; }
.stat-num   { font-size: 20px; line-height: 1.1; color: #00ff88; }
.stat-lbl   { font-size: 8px; color: #446644; letter-spacing: 2px; margin-top: 1px; }
.alert-box .stat-num { color: #ff8800; }

/* ── BODY ────────────────────────────────────────────────────── */
#toc-body   { display: flex; flex: 1; overflow: hidden; }
#map        { flex: 1; }

/* ── RIGHT PANEL ─────────────────────────────────────────────── */
#right-panel { width: 280px; background: #0a0a18; border-left: 1px solid #00ff8820;
               display: flex; flex-direction: column; overflow: hidden; }

.panel-tabs  { display: flex; border-bottom: 1px solid #00ff8820; flex-shrink: 0; }
.tab-btn     { flex: 1; background: none; border: none; color: #446644; font-family: inherit;
               font-size: 9px; letter-spacing: 1px; padding: 6px 2px; cursor: pointer; }
.tab-btn.active { color: #00ff88; border-bottom: 1px solid #00ff88; }
.tab-btn:hover  { color: #88ffaa; }

.tab-pane    { display: none; flex: 1; overflow-y: auto; flex-direction: column;
               padding: 8px; gap: 4px; }
.tab-pane.active { display: flex; }

.pane-header { font-size: 9px; letter-spacing: 2px; color: #446644;
               padding-bottom: 4px; border-bottom: 1px solid #1a1a2a; margin-bottom: 4px; }
.pane-note   { font-size: 8px; color: #334433; margin-bottom: 6px; }
.empty-state { font-size: 10px; color: #334433; text-align: center; padding: 20px 0; line-height: 1.8; }
hr.dim       { border: none; border-top: 1px solid #1a1a2a; margin: 6px 0; }

/* ── ROWS ────────────────────────────────────────────────────── */
.vessel-row  { font-size: 10px; padding: 3px 0; border-bottom: 1px solid #111120;
               cursor: pointer; white-space: nowrap; overflow: hidden; }
.vessel-row:hover { color: #fff; }
.vessel-row .sog { color: #446644; }

.event-row   { font-size: 9px; padding: 2px 0; border-bottom: 1px solid #111120; }
.event-enter { color: #00ff88; }
.event-leave { color: #ff8800; }

.canary-row  { font-size: 9px; padding: 3px 4px; border-bottom: 1px solid #111120; line-height: 1.5; }
.canary-ext  { background: #1a0800; border-left: 2px solid #ff8800; padding-left: 6px; }
.canary-name { color: #ff8800; }
.canary-int  .canary-name { color: #334433; }
.canary-meta { color: #335533; font-size: 8px; }

.qr-row      { font-size: 9px; padding: 3px 4px; border-bottom: 1px solid #111120; line-height: 1.5; }
.qr-ext      { background: #001a0a; border-left: 2px solid #00ff88; padding-left: 6px; }
.qr-meta     { color: #335533; font-size: 8px; }
.qr-isp      { color: #00cc66; }

.transit-row { font-size: 9px; padding: 3px 4px; border-bottom: 1px solid #111120; line-height: 1.5; }
.transit-in  { color: #00ff88; }
.transit-out { color: #ff8800; }

/* ── GEOFENCE / DRAW ─────────────────────────────────────────── */
#btn-save-fence { background: #00ff88; color: #000; border: none; padding: 5px 10px;
                  cursor: pointer; font-family: inherit; font-size: 10px;
                  margin-top: 4px; width: 100%; }
#btn-save-fence:hover { background: #00cc66; }

/* ── IG CARD ─────────────────────────────────────────────────── */
#ig-card  { margin-top: auto; padding-top: 10px; text-align: center;
            border-top: 1px solid #111120; }
#ig-qr    { width: 80px; height: 80px; opacity: 0.6; display: block; margin: 0 auto 4px; }
#ig-label { font-size: 8px; color: #334433; letter-spacing: 1px; }

/* ── AI BRIEF ────────────────────────────────────────────────── */
#btn-brief  { background: none; border: 1px solid #00ff8844; color: #00ff88;
              font-family: inherit; font-size: 9px; letter-spacing: 2px;
              padding: 3px 8px; cursor: pointer; }
#btn-brief:hover { background: #00ff8811; }
#brief-overlay { position: fixed; inset: 0; background: #000a; z-index: 1000;
                 display: flex; align-items: center; justify-content: center; }
#brief-box  { background: #0a0a18; border: 1px solid #00ff8844; padding: 20px;
              max-width: 560px; width: 90%; max-height: 80vh; overflow-y: auto; }
#brief-header { font-size: 10px; letter-spacing: 3px; color: #00ff88;
                margin-bottom: 14px; display: flex; justify-content: space-between; }
#brief-close { cursor: pointer; color: #446644; }
#brief-close:hover { color: #00ff88; }
#brief-content { font-size: 11px; color: #88cc88; line-height: 1.7; white-space: pre-wrap; }

/* ── STATUS DOTS ─────────────────────────────────────────────── */
.dot-red   { color: #ff4444; font-size: 14px; }
.dot-green { color: #00ff88; font-size: 14px; }
