:root{
  --bg:#e7e9e3;
  --panel:#fbfbf7;
  --panel-2:#f2f4ef;
  --line:#c6cbc1;
  --ink:#242522;
  --muted:#646b62;
  --asphalt:#171817;
  --blue:#176f86;
  --orange:#c86f3d;
  --green:#138a67;
  --amber:#f3c544;
  --violet:#7152a6;
  --red:#c94434;
  --white:#ffffff;
  --shadow:0 18px 50px rgba(28,31,28,.16);
  font-family:"Aptos","Segoe UI",system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{min-height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  display:flex;
  flex-direction:column;
  min-height:100vh;
  letter-spacing:0;
}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
button:focus-visible,a:focus-visible{
  outline:3px solid rgba(23,111,134,.35);
  outline-offset:2px;
}
header,.app-header{
  padding:14px 18px 14px 22px;
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
  flex:0 0 auto;
  background:rgba(251,251,247,.98);
}
.brand{display:flex;align-items:center;gap:13px;min-width:260px}
.brand-mark{
  width:42px;height:42px;border-radius:7px;display:grid;place-items:center;
  background:
    linear-gradient(90deg,transparent 0 39%,rgba(255,255,255,.55) 39% 45%,transparent 45% 55%,rgba(255,255,255,.55) 55% 61%,transparent 61%),
    linear-gradient(135deg,var(--asphalt),#30352f);
  color:var(--amber);
  border:1px solid #0d0f0d;
  font-family:"Bahnschrift","Arial Narrow",sans-serif;
  font-weight:800;
}
header h1{
  font-family:"Bahnschrift","Arial Narrow","Segoe UI",sans-serif;
  font-size:clamp(20px,2.4vw,30px);
  line-height:1.02;
  margin:0;
  font-weight:750;
}
header .sub{color:var(--muted);font-size:13px;line-height:1.35}
nav{display:flex;gap:6px;align-items:center}
nav a{
  color:var(--muted);
  text-decoration:none;
  font-size:13px;
  padding:8px 12px;
  border-radius:7px;
  border:1px solid transparent;
  background:transparent;
}
nav a:hover{color:var(--ink);background:#eef1eb}
nav a.active{
  color:var(--white);
  background:var(--asphalt);
  border-color:var(--asphalt);
}
.stats{
  margin-left:auto;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:stretch;
}
.stat{
  min-width:108px;
  padding:8px 10px;
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:7px;
}
.stat b{
  font-family:"Bahnschrift","Arial Narrow",sans-serif;
  font-size:18px;
  color:var(--blue);
  display:block;
  line-height:1.05;
}
.stat span{
  font-size:11px;
  color:var(--muted);
  text-transform:uppercase;
  display:block;
  margin-top:4px;
}
main{flex:1 1 auto;min-height:0;overflow:auto}

/* map page */
#map{height:100%;width:100%;background:#d9ddd5}
.legend{
  background:rgba(251,251,247,.96);
  padding:10px 12px;
  border-radius:8px;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  font-size:12px;
  line-height:1.7;
  color:var(--ink);
}
.legend i{width:14px;height:14px;display:inline-block;margin-right:6px;border-radius:3px;vertical-align:-2px}
.leaflet-control-layers{
  background:rgba(251,251,247,.96)!important;
  color:var(--ink);
  border:1px solid var(--line)!important;
  border-radius:8px;
  box-shadow:var(--shadow);
}
.leaflet-control-layers label{font-size:12px;margin:2px 0}
.leaflet-control-layers-list{padding:2px 4px}
.leaflet-control-layers-separator{border-top:1px solid var(--line)}

/* forecasts + analytics pages */
.page{
  padding:24px;
  max-width:1280px;
  margin:0 auto;
  width:100%;
}
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(360px,1fr));
  gap:18px;
}
.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:8px;
  padding:16px;
  box-shadow:0 1px 0 rgba(255,255,255,.7);
}
.card h2{
  font-size:13px;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 4px;
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:8px;
}
.card h2 .tag{
  font-size:11px;
  color:var(--green);
  text-transform:none;
}
.card .desc,.desc{
  font-size:12px;
  color:var(--muted);
  margin:0 0 10px;
  line-height:1.5;
}
.badges{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 2px}
.badge{
  background:#eef1eb;
  border:1px solid var(--line);
  border-radius:6px;
  padding:6px 9px;
  font-size:11px;
  color:var(--muted);
}
.badge b{color:var(--ink);font-size:13px}
.badge.win b{color:var(--green)}
.note{font-size:11px;color:#8f5f00;margin-top:8px;line-height:1.5}
.foot{
  font-size:11px;
  color:var(--muted);
  margin-top:18px;
  line-height:1.6;
}
h3.subh{
  font-family:"Bahnschrift","Arial Narrow",sans-serif;
  font-size:17px;
  color:var(--ink);
  margin:0 0 4px;
  font-weight:700;
}
.toggle{
  display:flex;
  gap:6px;
  margin:4px 0 12px;
  max-width:440px;
}
.toggle button{
  flex:1;
  background:var(--white);
  color:var(--muted);
  border:1px solid var(--line);
  border-radius:7px;
  padding:8px 9px;
  font-size:12px;
}
.toggle button.active{
  color:var(--white);
  border-color:var(--asphalt);
  background:var(--asphalt);
}
a{color:var(--blue)}
canvas{max-width:100%}

/* analytics page */
.analytics-shell{display:grid;gap:18px}
.analytics-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,420px);
  gap:18px;
  align-items:stretch;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:8px;
  padding:18px;
  box-shadow:var(--shadow);
}
.eyebrow{
  margin:0 0 8px;
  color:var(--blue);
  font-size:12px;
  text-transform:uppercase;
  font-weight:800;
}
.analytics-hero h2{
  margin:0 0 10px;
  font-family:"Bahnschrift","Arial Narrow","Segoe UI",sans-serif;
  font-size:clamp(28px,4vw,48px);
  line-height:1;
  font-weight:750;
  max-width:820px;
}
.analytics-hero .desc{
  font-size:14px;
  max-width:760px;
  margin-bottom:0;
}
.control-panel{
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:8px;
  padding:14px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.control-label{
  display:block;
  color:var(--muted);
  text-transform:uppercase;
  font-size:11px;
  margin-bottom:8px;
}
.analytics-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.wide-card{grid-column:span 2}
.card-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:8px;
}
.chip{
  white-space:nowrap;
  color:var(--muted);
  background:#eef1eb;
  border:1px solid var(--line);
  border-radius:999px;
  padding:5px 8px;
  font-size:11px;
}
.method-note{
  background:rgba(251,251,247,.82);
  border:1px solid var(--line);
  border-radius:8px;
  padding:12px 14px;
}

@media (max-width:900px){
  header,.app-header{padding:12px}
  .stats{margin-left:0;width:100%}
  .stat{flex:1 1 130px}
  .analytics-hero{grid-template-columns:1fr}
  .analytics-grid{grid-template-columns:1fr}
  .wide-card{grid-column:auto}
}
@media (max-width:560px){
  .page{padding:12px}
  .grid{grid-template-columns:1fr}
  .toggle{flex-direction:column}
  .brand{min-width:0}
  .brand-mark{width:38px;height:38px}
}

/* full app revamp */
.forecast-shell{display:grid;gap:18px}
.forecast-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,380px);
  gap:18px;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:8px;
  padding:18px;
  box-shadow:var(--shadow);
}
.forecast-hero h2{
  margin:0 0 10px;
  font-family:"Bahnschrift","Arial Narrow","Segoe UI",sans-serif;
  font-size:clamp(28px,4vw,48px);
  line-height:1;
  font-weight:750;
}
.compact-desc{font-size:12px;margin-top:8px}
.forecast-grid{grid-template-columns:1fr}
.map-page{height:100vh;overflow:hidden}
.map-main{position:relative;overflow:hidden}
.map-main #map{position:absolute;inset:0;height:100%;width:100%}
.map-banner{
  position:absolute;
  left:18px;
  top:18px;
  z-index:410;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  max-width:min(720px,calc(100% - 36px));
}
.map-banner .chip{
  background:rgba(251,251,247,.94);
  box-shadow:var(--shadow);
}
@media (max-width:900px){
  .forecast-hero{grid-template-columns:1fr}
  .map-banner{left:12px;top:12px}
}

/* map-first forecast polish */
.forecast-hero-split{
  grid-template-columns:minmax(0,1fr) minmax(300px,420px);
  align-items:stretch;
}
.forecast-copy{
  min-height:240px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.forecast-copy h2{
  max-width:880px;
}
.forecast-rail{
  display:grid;
  gap:10px;
}
.rail-card{
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:8px;
  padding:14px;
}
.rail-note{
  display:grid;
  gap:7px;
  align-content:start;
  color:var(--muted);
  font-size:12px;
  line-height:1.45;
}
.rail-note b{
  color:var(--ink);
  font-family:"Bahnschrift","Arial Narrow",sans-serif;
  font-size:18px;
}
.forecast-stack{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}
.forecast-card{
  position:relative;
  overflow:hidden;
}
.forecast-card::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:5px;
  background:var(--blue);
}
.primary-forecast::before{background:var(--red)}
.forecast-pair{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.forecast-card canvas{
  margin-top:4px;
}
@media (max-width:980px){
  .forecast-hero-split{grid-template-columns:1fr}
  .forecast-copy{min-height:0}
  .forecast-pair{grid-template-columns:1fr}
}

