/* Gruvbox palette */
:root{
  --gb-bg0: #282828;
  --gb-bg1: #3c3836;
  --gb-bg2: #504945;
  --gb-fg:  #ebdbb2;
  --gb-fg-dim:#d5c4a1;
  --gb-red:#fb4934;
  --gb-green:#b8bb26;
  --gb-yellow:#fabd2f;
  --gb-blue:#83a598;
  --gb-purple:#d3869b;
  --gb-aqua:#8ec07c;
  --gb-orange:#fe8019;
  --shadow: 0 8px 24px rgba(0,0,0,0.35);
}

*{ box-sizing:border-box }
html,body{ height:100%; margin:0; background:var(--gb-bg0); color:var(--gb-fg);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  font-weight: 600; /* bold-forward default look using system stack */
}
#map{ position:fixed; inset:0; }

/* Scene badge (Presenter) */
.scene-badge{
  position: fixed; top: 10px; left:50%; transform: translateX(-50%);
  background: rgba(40,40,40,0.92);
  border:1px solid rgba(255,255,255,0.08);
  color: var(--gb-fg); font-weight:900; letter-spacing:.2px;
  padding: 6px 10px; border-radius: 10px; box-shadow: var(--shadow);
  z-index: 10;
}

/* Attack alert (only during zoomed focus) */
.attack-alert{
  position: fixed; top: 50px; left: 50%; transform: translateX(-50%);
  background: rgba(40,40,40,0.92);
  border: 1px solid rgba(251,73,52,0.45);
  color: var(--gb-red);
  font-weight: 900; letter-spacing: .6px;
  padding: 8px 14px; border-radius: 12px; box-shadow: 0 0 30px rgba(251,73,52,0.25);
  display:flex; align-items:center; gap:10px;
  z-index: 11;
}
.attack-alert .loc{ color: var(--gb-green); }
.attack-alert .dot{ width:10px; height:10px; border-radius:999px; background: var(--gb-red); box-shadow: 0 0 12px var(--gb-red); }
@keyframes blink { 0%, 60% { opacity:1 } 70% { opacity:.45 } 80% { opacity:1 } 90% { opacity:.5 } 100% { opacity:1 } }
.blink{ animation: blink 0.8s infinite; }

/* HUD (left top) */
.hud{
  position: fixed; top:16px; left:16px; width:380px;
  background: rgba(40,40,40,0.9);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  padding: 12px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(4px);
}
.hud-title{ font-weight:900; letter-spacing:.3px; font-size:16px; margin-bottom:2px; }
.hud-sub{ font-size:12px; color: var(--gb-fg-dim); }
.hud-controls{ display:flex; flex-wrap:wrap; gap:8px; margin:10px 0 8px; }
.btn{
  appearance:none; border:1px solid var(--gb-bg2); background: var(--gb-bg1);
  color: var(--gb-fg); padding:8px 10px; border-radius:8px; cursor:pointer;
  transition: transform .06s ease, background .2s ease, border-color .2s ease;
  font-weight:700;
}
.btn:hover{ transform:translateY(-1px); border-color: var(--gb-yellow); }
.btn-ghost{ background: transparent; }

.stats{ display:grid; grid-template-columns: repeat(2, 1fr); gap:8px; margin-top:4px; }
.stat{ background: var(--gb-bg1); border:1px solid var(--gb-bg2); border-radius:10px; padding:8px 10px; }
.stat .label{ font-size:11px; color:var(--gb-fg-dim); margin-bottom:4px; }
.stat .value{ font-weight:800; font-size:18px; }
.stat .value.green{ color: var(--gb-aqua); }
.stat .value.yellow{ color: var(--gb-yellow); }
.stat .value.red{ color: var(--gb-red); }

/* INSIGHTS COLUMN (left bottom) */
.insights{
  position: fixed; left:16px; bottom:16px; width:380px;
  display: grid; gap: 10px;
}
.panel{
  background: rgba(40,40,40,0.9);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px; padding: 12px; box-shadow: var(--shadow);
  backdrop-filter: blur(4px);
}
.panel-title{ font-weight:800; font-size:14px; margin-bottom:8px; }
.kpis{ display:grid; grid-template-columns: repeat(3, 1fr); gap:8px; margin-bottom:8px; }
.kpi{ background: var(--gb-bg1); border:1px solid var(--gb-bg2); border-radius:10px; padding:8px 10px; }
.kpi-label{ font-size:11px; color:var(--gb-fg-dim); margin-bottom:4px; }
.kpi-value{ font-weight:800; font-size:18px; }

.list.two-col{ display:grid; grid-template-columns: 1fr 1fr; gap:10px; }
.list-title{ font-size:12px; color:var(--gb-fg-dim); margin-bottom:4px; }
.list-body .row{ margin:6px 0 10px; }
.row-head{ display:flex; justify-content:space-between; font-size:12px; }
.row .label{ color:var(--gb-fg); }
.row .num{ color:var(--gb-fg-dim); }
.bar{ height:8px; background: var(--gb-bg1); border:1px solid var(--gb-bg2); border-radius:999px; overflow:hidden; }
.bar-fill{ height:100%; width:40%; background: linear-gradient(90deg, var(--gb-yellow), var(--gb-orange), var(--gb-red)); box-shadow: 0 0 10px rgba(254,128,25,.3) inset; }

/* GEO panel: Top Countries with multi-color donut chips (2 items) */
.countries-grid{ display:grid; grid-template-columns: repeat(2, 1fr); gap:10px; }
.country-chip{ display:flex; align-items:center; gap:10px; background: var(--gb-bg1); border:1px solid var(--gb-bg2); border-radius:12px; padding: 8px 10px; }
.donut{ --pct: 0; --col: var(--gb-yellow);
  position: relative; width: 44px; height: 44px; border-radius:999px;
  background: conic-gradient(var(--col) calc(var(--pct)*1%), rgba(255,255,255,0.06) 0);
  -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 0);
          mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 0);
  box-shadow: 0 0 10px rgba(254,128,25,.15) inset;
}
.donut .count{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:12px; color:var(--gb-fg); }
.country-meta .name{ font-weight:800; font-size:13px; }
.country-meta .sub{ font-size:12px; color:var(--gb-fg-dim); }

/* Live Feed (right) */
.feed{
  position: fixed; top:16px; right:16px; bottom:16px; width:440px; overflow:auto;
  background: rgba(40,40,40,0.88);
  border:1px solid rgba(255,255,255,0.06);
  border-radius: 12px; box-shadow: var(--shadow); padding: 10px;
}
.event{ border:1px solid var(--gb-bg2); border-radius:10px; padding:10px 10px; margin-bottom:10px;
  background: linear-gradient(180deg, rgba(60,56,54,0.9), rgba(60,56,54,0.7)); }
.event .head{ display:flex; align-items:center; justify-content: space-between; font-size:12px; color: var(--gb-fg-dim); margin-bottom:6px; }
.event .sev{ font-weight:800; padding:2px 6px; border-radius:6px; border:1px solid var(--gb-bg2); }
.event .sev.low{ color: var(--gb-aqua); }
.event .sev.med{ color: var(--gb-yellow); }
.event .sev.high{ color: var(--gb-orange); }
.event .sev.crit{ color: var(--gb-red); }
.event .main{ font-size: 13px; line-height:1.35; margin-bottom:4px; }
.event .key{ color: var(--gb-fg-dim); font-size: 12px; }
.badge{ display:inline-block; padding:2px 6px; font-size:11px; border-radius:6px; margin-right:6px; border:1px solid var(--gb-bg2); color: var(--gb-fg-dim); }
.badge.port{ color: var(--gb-blue); }
.badge.service{ color: var(--gb-yellow); }
.badge.cve{ color: var(--gb-orange); }
.badge.status-ok{ color: var(--gb-aqua); }
.badge.status-partial{ color: var(--gb-yellow); }
.badge.status-fail{ color: var(--gb-blue); }
.badge.status-crit{ color: var(--gb-red); }

/* Glowing dots */
.dot{
  --glow: var(--gb-yellow);
  width: 10px; height: 10px; border-radius: 999px;
  background: var(--glow);
  box-shadow: 0 0 8px var(--glow), 0 0 18px var(--glow), 0 0 28px rgba(254,128,25,.45);
}

/* Focus pulse around zoomed dot */
.focus-ring{
  width: 22px; height: 22px; border-radius: 999px;
  border: 2px solid rgba(251,73,52,0.85);
  box-shadow: 0 0 8px rgba(251,73,52,0.65), 0 0 18px rgba(251,73,52,0.35);
}
@keyframes pulseRing {
  0% { transform: scale(1); opacity: 0.9; }
  70% { transform: scale(2.2); opacity: 0.2; }
  100% { transform: scale(2.6); opacity: 0; }
}
.focus-ring::after{
  content:"";
  position:absolute; inset:-2px; border-radius:999px;
  border:2px solid rgba(251,73,52,0.6);
  animation: pulseRing 1.4s ease-out infinite;
}

/* Presenter mode: hide UI, show badge */
.present .feed, .present .hud, .present .insights{ display:none; }
.present #scene-badge{ display:block !important; }

/* Mapbox control spacing */
.mapboxgl-ctrl-top-right { margin: 8px; }

/* Responsive tweaks */
@media (max-width: 1180px){ .feed{ width: 50vw; } }
@media (max-width: 960px){
  .feed{ display:none; }
  .hud{ width: calc(100% - 32px); }
  .insights{ width: calc(100% - 32px); left:16px; right:16px; bottom:16px; }
  .list.two-col{ grid-template-columns: 1fr; }
  .countries-grid{ grid-template-columns: 1fr; }
}

.label i {
  width: 14px;
  height: 14px;
  stroke-width: 2.2;
  margin-right: 6px;
  vertical-align: middle;
}

.stat {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--gb-bg1);
  border: 1px solid var(--gb-bg2);
  border-radius: 10px;
  padding: 10px 16px;   /* wider horizontal padding */
}

.stat i {
  width: 18px;
  height: 18px;
  stroke-width: 2.2;
  margin-right: 8px;   /* more space between icon and label */
}

.stat .label {
  font-weight: 600;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 8px;            /* more padding between icon and text */
  margin-right: 12px;  /* ensures value doesn’t stick to edge */
}

.stat .value {
  font-weight: 800;
  font-size: 18px;
  min-width: 36px;     /* keeps spacing consistent */
  text-align: right;
}
