:root {
  --bg: #050814;
  --surface: #0a0e14;
  --surface-2: #11151f;
  --line: rgba(255,255,255,.08);
  --line-strong: rgba(255,255,255,.18);
  --text: #f0f6ff;
  --text-2: #cbd5e1;
  --muted: #94a3b8;
  --cyan: #67e8f9;
  --cyan-d: #22d3ee;
  --violet: #a78bfa;
  --violet-d: #8b5cf6;
  --green: #34d399;
  --amber: #fbbf24;
  --red: #f87171;
  --rl: 14px;
  --rs: 8px;
}

* { box-sizing: border-box }
html, body { margin: 0; padding: 0 }
body {
  background: radial-gradient(ellipse at top, #1a1442 0%, var(--bg) 60%);
  color: var(--text);
  font: 15px/1.5 'DM Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  min-height: 100vh;
}
a { color: var(--cyan); text-decoration: none }
a:hover { color: #fff }

.container { max-width: 1180px; margin: 0 auto; padding: 0 18px }
.muted { color: var(--muted) }
.eyebrow { color: var(--violet); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; margin: 0 0 8px }
.hide-mobile { display: none }
@media (min-width: 760px) { .hide-mobile { display: table-cell } }

/* topbar */
.topbar {
  display: flex; gap: 18px; align-items: center; justify-content: space-between;
  padding: 14px 18px; max-width: 1180px; margin: 0 auto;
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; gap: 12px; align-items: center; color: var(--text) }
.brand-mark {
  width: 38px; height: 38px; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--cyan-d), var(--violet));
  color: var(--bg); border-radius: 9px; font-size: 18px; font-weight: 800;
}
.brand-title { font-weight: 700; letter-spacing: .04em }
.brand-sub { display: block; color: var(--muted); font-size: 11px; margin-top: 2px }
.topbar-nav { display: flex; gap: 4px; flex-wrap: wrap; font-size: 13px }
.topbar-nav a {
  color: var(--text-2); padding: 6px 11px; border-radius: 7px;
  border: 1px solid transparent; transition: all .12s;
}
.topbar-nav a:hover { color: var(--cyan); border-color: var(--line-strong) }
.topbar-nav a.active {
  color: var(--cyan); background: rgba(34,211,238,.1);
  border-color: rgba(34,211,238,.3);
}

/* hero */
.hero { padding: 56px 0 32px }
.hero h1 {
  margin: 4px 0 14px; font-size: clamp(28px, 5vw, 44px);
  font-weight: 800; letter-spacing: -.02em;
  background: linear-gradient(180deg, #fff, #67e8f9 90%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero .lead { color: var(--text-2); max-width: 720px; margin: 0 0 20px; font-size: 17px }
.status-row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap }

.chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; padding: 5px 11px; border-radius: 99px;
  background: rgba(255,255,255,.04); border: 1px solid var(--line);
  font-family: 'JetBrains Mono', Consolas, monospace; letter-spacing: .04em;
}
.chip .dot { width: 7px; height: 7px; border-radius: 99px; background: var(--amber) }
.chip.ok .dot { background: var(--green) }
.chip.err .dot { background: var(--red) }
.btn-o {
  display: inline-block; padding: 7px 14px; border-radius: 8px;
  border: 1px solid var(--line-strong); color: var(--text);
  font-size: 13px; transition: all .15s; cursor: pointer;
  background: transparent;
}
.btn-o:hover { border-color: var(--cyan); color: var(--cyan); background: rgba(34,211,238,.05) }

/* tile */
.tile {
  background: linear-gradient(180deg, rgba(20,26,62,.4), rgba(15,20,50,.6));
  border: 1px solid var(--line);
  border-radius: var(--rl);
  padding: 22px;
  margin: 18px 0;
  backdrop-filter: blur(10px);
}
.tile-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px; gap: 10px; flex-wrap: wrap;
}
.tile-head h2 { margin: 0; font-size: 18px; font-weight: 700 }
.tile-head h3.sub { margin: 4px 0 8px; font-size: 13px; font-weight: 600; color: var(--cyan); letter-spacing: .04em }
.badge {
  font: 11px/1 'JetBrains Mono', Consolas, monospace;
  color: var(--muted);
  background: rgba(255,255,255,.04);
  padding: 4px 8px; border-radius: var(--rs);
  border: 1px solid var(--line);
}
.skel { padding: 20px; color: var(--muted); text-align: center; font-style: italic }

.grid { display: grid; gap: 10px }
.grid-7 { grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)) }
.grid-2col { display: grid; gap: 18px; grid-template-columns: 1fr; margin: 18px 0 }
@media (min-width: 880px) { .grid-2col { grid-template-columns: 1fr 1fr } }
.grid-2col > section { margin: 0 }

/* weather day cards */
.day {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: var(--rs);
  padding: 12px 10px;
  text-align: center;
}
.day-name { font-weight: 700; color: var(--cyan); font-size: 13px; letter-spacing: .04em }
.day-temps { font-size: 18px; margin: 6px 0; font-weight: 600 }
.day-temps .lo { color: var(--muted); font-weight: 400; font-size: 14px }
.day-precip { font-size: 11px; color: var(--text-2) }

/* AI synthesis block */
.ai-block {
  margin-top: 14px; padding: 14px 16px;
  background: linear-gradient(135deg, rgba(167,139,250,.08), rgba(34,211,238,.06));
  border: 1px solid rgba(167,139,250,.18);
  border-radius: var(--rs);
  font-size: 14px;
  line-height: 1.6;
}
.ai-block::before {
  content: 'AI · gemma3'; display: block;
  font: 11px/1 'JetBrains Mono', Consolas, monospace;
  color: var(--violet); letter-spacing: .1em;
  margin-bottom: 6px;
}

/* stocks */
.stocks-table { overflow-x: auto }
.stocks-table table {
  width: 100%; border-collapse: collapse; font-size: 14px;
}
.stocks-table th, .stocks-table td {
  padding: 10px 8px; text-align: left;
  border-bottom: 1px solid var(--line);
}
.stocks-table th { font-weight: 600; color: var(--cyan); font-size: 12px; letter-spacing: .05em; text-transform: uppercase }
.stocks-table .pos { color: var(--green) }
.stocks-table .neg { color: var(--red) }
.signal {
  display: inline-block; padding: 2px 8px; border-radius: 99px;
  font-size: 11px; font-weight: 700; letter-spacing: .05em;
}
.signal.buy { background: rgba(52,211,153,.15); color: var(--green) }
.signal.hold { background: rgba(251,191,36,.15); color: var(--amber) }
.signal.sell { background: rgba(248,113,113,.15); color: var(--red) }

/* threat gauge */
.threat-card { display: flex; gap: 18px; align-items: center }
.threat-gauge {
  width: 90px; height: 90px; border-radius: 50%; flex-shrink: 0;
  display: grid; place-items: center;
  font-size: 28px; font-weight: 800;
  background: conic-gradient(var(--green) 0%, var(--amber) 50%, var(--red) 100%);
  color: var(--bg);
  border: 4px solid var(--surface);
  box-shadow: 0 0 30px rgba(255,255,255,.08);
}
.threat-detail { font-size: 14px; line-height: 1.6 }

/* iss */
.iss-coords { font: 24px/1.2 'JetBrains Mono', Consolas, monospace; color: var(--cyan); letter-spacing: .04em }
.iss-meta { margin-top: 8px; font-size: 13px; color: var(--text-2) }

/* feeds */
.feed { list-style: none; padding: 0; margin: 0 }
.feed li {
  padding: 9px 0; border-bottom: 1px solid var(--line);
  font-size: 14px; line-height: 1.5;
}
.feed li:last-child { border-bottom: 0 }
.feed-meta { display: block; color: var(--muted); font-size: 11px; margin-top: 2px }

/* ask */
.ask-form { display: flex; gap: 10px; margin: 12px 0 }
.ask-form input {
  flex: 1; background: rgba(255,255,255,.05);
  border: 1px solid var(--line-strong); border-radius: var(--rs);
  padding: 11px 14px; color: var(--text); font: inherit; outline: 0;
}
.ask-form input:focus { border-color: var(--cyan-d) }
.ask-form button {
  background: linear-gradient(135deg, var(--cyan-d), var(--violet));
  color: var(--bg); border: 0; padding: 11px 22px;
  border-radius: var(--rs); font: inherit; font-weight: 700;
  cursor: pointer; letter-spacing: .04em;
}
.ask-form button:disabled { opacity: .4; cursor: wait }
.ask-out {
  background: rgba(255,255,255,.03); border: 1px solid var(--line);
  border-radius: var(--rs); padding: 14px;
  font-size: 14px; line-height: 1.6;
  white-space: pre-wrap; word-wrap: break-word;
  min-height: 56px; color: var(--text-2);
}
.ask-out:empty::before { content: '↑ Type a question and press Ask. Local AI replies in seconds.'; color: var(--muted); font-style: italic }

.footnote {
  text-align: center; padding: 32px 0 50px;
  color: var(--muted); font-size: 13px;
}

/* hero predictions tile */
.tile-hero {
  background: linear-gradient(135deg, rgba(167,139,250,.12), rgba(34,211,238,.06));
  border: 1px solid rgba(167,139,250,.3);
}
.pred-meta { font: 11px/1.5 'JetBrains Mono', Consolas, monospace; letter-spacing: .03em; margin-bottom: 12px }
.pred-body {
  font: 14px/1.65 'DM Sans', system-ui, sans-serif;
  white-space: pre-wrap; word-wrap: break-word;
  margin: 0; padding: 16px 18px;
  background: rgba(0,0,0,.25); border: 1px solid var(--line);
  border-radius: var(--rs); color: var(--text-2);
  min-height: 240px;
}

/* feed-2col — multi-column news list on wide screens */
.feed-2col {
  column-count: 1;
  column-gap: 24px;
}
@media (min-width: 880px) { .feed-2col { column-count: 2 } }
.feed-2col li { break-inside: avoid; }

/* threat summary rows */
.threat-summary {
  display: flex; flex-direction: column; gap: 6px;
}
.threat-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 12px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  border-radius: var(--rs);
  font-size: 13px;
}
.threat-row strong { color: var(--cyan); font: 600 14px/1 'JetBrains Mono', Consolas, monospace }

/* clickable table rows + stat tables */
.stocks-table tr.clickable-row { cursor: pointer; transition: background .12s; }
.stocks-table tr.clickable-row:hover { background: rgba(34,211,238,.05) }
.stat-table { width: 100%; border-collapse: collapse; font-size: 13px }
.stat-table th { text-align: left; padding: 7px 10px 7px 0; color: var(--muted); font-weight: 500; font-size: 12px; letter-spacing: .03em; text-transform: uppercase; width: 40% }
.stat-table td { padding: 7px 0; color: var(--text) }
.stat-table tr { border-bottom: 1px solid var(--line) }
.stat-table tr:last-child { border-bottom: 0 }
svg.spark { color: var(--cyan) }
svg.spark.pos { color: var(--green) }
svg.spark.neg { color: var(--red) }

/* tools page */
.tools-grid {
  display: grid; gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.tool {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  border-radius: var(--rs);
  padding: 14px 16px;
}
.tool h3 { margin: 0 0 4px; font-size: 14px; font-weight: 700; color: var(--cyan) }
.tool p { font-size: 12.5px; margin: 0 0 10px; line-height: 1.45 }
.tool input[type="text"], .tool input[type="password"], .tool select {
  width: 100%; background: rgba(255,255,255,.04);
  border: 1px solid var(--line-strong); border-radius: 6px;
  padding: 7px 10px; color: var(--text); font: 13px/1.4 'JetBrains Mono', Consolas, monospace;
  margin-bottom: 8px; outline: 0;
}
.tool input:focus, .tool select:focus { border-color: var(--cyan-d) }
.tool button.btn-o { font-size: 12px; padding: 6px 14px; margin-top: 2px }
.tool .tool-out {
  margin-top: 10px;
  font-size: 13px;
  background: rgba(0,0,0,.25);
  border-radius: 6px;
  padding: 10px 12px;
  max-height: 320px;
  overflow: auto;
  word-wrap: break-word;
  color: var(--text);
  min-height: 0;
}
.tool .tool-out .pos { color: var(--green) }
.tool .tool-out .neg { color: var(--red) }
.tool .tool-out a { word-break: break-word }
.tool .tool-out code {
  background: rgba(255,255,255,.06);
  padding: 1px 5px;
  border-radius: 3px;
  font: 12px/1.4 'JetBrains Mono', Consolas, monospace;
}
.tool .tool-out:empty { display: none }

/* category cards (dashboard home) */
.cat-grid {
  display: grid; gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  margin: 18px 0;
}
.cat-card {
  display: block;
  background: linear-gradient(180deg, rgba(20,26,62,.4), rgba(15,20,50,.6));
  border: 1px solid var(--line);
  border-radius: var(--rl);
  padding: 18px;
  text-decoration: none;
  color: var(--text);
  transition: all .15s;
  position: relative;
  overflow: hidden;
}
.cat-card:hover {
  border-color: var(--cyan);
  background: linear-gradient(180deg, rgba(34,211,238,.08), rgba(167,139,250,.05));
  transform: translateY(-2px);
}
.cat-card::after {
  content: '→'; position: absolute; right: 16px; top: 16px;
  color: var(--muted); transition: all .15s;
}
.cat-card:hover::after { color: var(--cyan); transform: translateX(4px) }
.cat-card-icon {
  width: 36px; height: 36px; border-radius: 9px;
  background: linear-gradient(135deg, var(--cyan-d), var(--violet));
  color: var(--bg); display: grid; place-items: center;
  font-size: 18px; font-weight: 800;
  margin-bottom: 12px;
}
.cat-card-title {
  font-size: 17px; font-weight: 700; margin: 0 0 4px;
}
.cat-card-sub {
  font-size: 12px; color: var(--muted); margin: 0 0 12px;
  letter-spacing: .03em;
}
.cat-card-pred {
  font-size: 13px; line-height: 1.5; color: var(--text-2);
  border-top: 1px dashed var(--line); padding-top: 10px;
  min-height: 60px;
}
.cat-card-pred .skel-line {
  height: 9px; background: rgba(255,255,255,.06); border-radius: 3px;
  margin: 6px 0;
}
.cat-card-pred .skel-line:nth-child(1) { width: 90% }
.cat-card-pred .skel-line:nth-child(2) { width: 75% }
.cat-card-pred .skel-line:nth-child(3) { width: 60% }

/* global counts strip */
.counts-strip {
  display: grid; gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  margin: 20px 0;
}
.count-cell {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: var(--rs);
  padding: 14px 16px;
}
.count-cell strong {
  display: block; font: 700 22px/1 'JetBrains Mono', Consolas, monospace;
  color: var(--cyan); margin-bottom: 4px;
}
.count-cell span { font-size: 11px; color: var(--muted); letter-spacing: .05em; text-transform: uppercase }

.page-head { padding: 30px 0 14px }
.page-head h1 {
  margin: 0 0 8px; font-size: clamp(22px, 4vw, 32px);
  font-weight: 800; letter-spacing: -.01em;
}
.page-head p { color: var(--text-2); margin: 0; max-width: 720px }

/* unified app-wide world-state strip — lands on every page below the topbar */
.worldstate {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px; max-width: 1180px; margin: 0 auto; padding: 10px 18px 0;
}
@media (max-width: 760px) {
  .worldstate { grid-template-columns: repeat(2, minmax(0, 1fr)) }
}
.ws-item {
  display: flex; flex-direction: column; gap: 3px;
  padding: 9px 14px;
  background: linear-gradient(180deg, rgba(34,211,238,.05), rgba(168,85,247,.06));
  border: 1px solid var(--line); border-radius: 10px;
  color: var(--text); transition: all .15s; min-height: 64px;
}
.ws-item:hover { border-color: rgba(34,211,238,.5); color: var(--cyan); transform: translateY(-1px) }
.ws-item .ws-lbl { font-size: 10.5px; color: var(--muted); letter-spacing: .12em; text-transform: uppercase }
.ws-item .ws-val { font: 800 21px/1.05 'JetBrains Mono', Consolas, monospace; color: #fff }
.ws-item .ws-val-sm { font: 600 13px/1.25 'DM Sans', sans-serif; color: var(--text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis }
.ws-pill {
  display: inline-block; align-self: flex-start;
  padding: 1px 8px; border-radius: 99px; font-size: 10px; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  background: rgba(255,255,255,.06); border: 1px solid var(--line); color: var(--text-2);
}
.ws-pill.ws-stable   { background: rgba(52,211,153,.10); border-color: rgba(52,211,153,.45); color: #6ee7b7 }
.ws-pill.ws-elevated { background: rgba(251,191,36,.10); border-color: rgba(251,191,36,.45); color: #fcd34d }
.ws-pill.ws-severe   { background: rgba(248,113,113,.12); border-color: rgba(248,113,113,.5); color: #fda4af }
.ws-pill.ws-critical { background: rgba(220,38,38,.18); border-color: rgba(220,38,38,.6); color: #fecaca }

/* per-region grid (regions.html) */
.region-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 10px; margin: 16px 0 }
.region-card {
  display: flex; flex-direction: column; gap: 6px;
  padding: 12px 14px; border: 1px solid var(--line); border-radius: 10px;
  background: rgba(15,21,33,.5); color: var(--text); transition: all .15s;
}
.region-card:hover { border-color: rgba(34,211,238,.5); color: var(--cyan); transform: translateY(-1px) }
.region-card .rc-name { font-weight: 700; font-size: 14.5px; color: #fff }
.region-card .rc-meta { font-size: 11.5px; color: var(--muted); letter-spacing: .04em }
.region-card .rc-tier { font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase }
.region-card .rc-tier.tier-low  { color: #6ee7b7 }
.region-card .rc-tier.tier-mid  { color: #fcd34d }
.region-card .rc-tier.tier-high { color: #fda4af }
.region-card .rc-tier.tier-crit { color: #fecaca }

.region-search {
  width: 100%; padding: 10px 14px; border-radius: 10px;
  background: rgba(15,21,33,.6); border: 1px solid var(--line);
  color: var(--text); font: 14px 'DM Sans', sans-serif;
}
.region-search:focus { outline: none; border-color: rgba(34,211,238,.5) }
.region-tabs { display: flex; gap: 6px; margin: 10px 0 4px; flex-wrap: wrap }
.region-tabs button {
  padding: 6px 12px; background: rgba(15,21,33,.5); border: 1px solid var(--line);
  color: var(--text-2); border-radius: 7px; font-size: 13px; cursor: pointer; transition: all .12s;
}
.region-tabs button.active { color: var(--cyan); background: rgba(34,211,238,.1); border-color: rgba(34,211,238,.3) }
