/* earthmoonsky — observatory theme v1 */
:root {
  --bg0: #04060c;
  --bg1: #0a0f1c;
  --panel: rgba(15, 21, 37, 0.88);
  --panel-edge: #243150;
  --ink: #e9edf5;
  --dim: #8b96ad;
  --brass: #d4af6e;
  --blue: #7fb4e8;
  --green: #5fce8a;
  --yellow: #e8c469;
  --red: #e06c75;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  background: radial-gradient(ellipse at 50% -20%, #101a30 0%, var(--bg1) 45%, var(--bg0) 100%) fixed;
  color: var(--ink);
  font-family: Inter, "Segoe UI", system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.55;
  min-height: 100vh;
}

/* starfield */
.stars, .stars::after {
  content: "";
  position: fixed; inset: 0;
  background-image:
    radial-gradient(1px 1px at 12% 22%, #fff 50%, transparent 51%),
    radial-gradient(1px 1px at 28% 68%, #cfd9ee 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 41% 15%, #fff 50%, transparent 51%),
    radial-gradient(1px 1px at 55% 45%, #aebadb 50%, transparent 51%),
    radial-gradient(1px 1px at 63% 81%, #fff 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 74% 30%, #e6ecfa 50%, transparent 51%),
    radial-gradient(1px 1px at 86% 60%, #fff 50%, transparent 51%),
    radial-gradient(1px 1px at 93% 12%, #c4d0ea 50%, transparent 51%),
    radial-gradient(1px 1px at 7% 88%, #fff 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 48% 92%, #dde5f5 50%, transparent 51%);
  opacity: 0.45;
  pointer-events: none;
  z-index: 0;
}
.stars::after { transform: scale(1.7) rotate(17deg); opacity: 0.25; }

.masthead, .status-strip, .grid, .site-foot { position: relative; z-index: 1; }

/* masthead */
.masthead {
  text-align: center;
  padding: 42px 20px 10px;
}
.lockup {
  font-size: clamp(20px, 4vw, 30px);
  font-weight: 300;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  text-indent: 0.32em;
}
.lockup b { font-weight: 600; }
.lockup .dot { color: var(--brass); }
.tagline { color: var(--dim); font-weight: 300; margin-top: 8px; font-size: 14px; }
.clocks { margin-top: 14px; display: flex; gap: 18px; justify-content: center; }
.clock {
  font-variant-numeric: tabular-nums;
  font-size: 13px;
  color: var(--blue);
  letter-spacing: 0.08em;
  border: 1px solid rgba(127, 180, 232, 0.25);
  border-radius: 999px;
  padding: 3px 14px;
}

/* status strip */
.status-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(140px, 220px));
  justify-content: center;
  gap: 12px;
  padding: 22px 20px 6px;
}
.chip {
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 10px;
  padding: 10px 14px;
  text-align: center;
}
.chip-label {
  display: block;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--dim);
}
.chip-value {
  display: block;
  font-size: 22px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  margin: 2px 0;
}
.chip-note { display: block; font-size: 11px; color: var(--dim); }
.chip.is-quiet .chip-value { color: var(--green); }
.chip.is-active .chip-value { color: var(--yellow); }
.chip.is-storm .chip-value { color: var(--red); }

/* grid + panels */
.grid {
  max-width: 1180px;
  margin: 0 auto;
  padding: 24px 20px 40px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.panel {
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 14px;
  padding: 20px 22px;
  backdrop-filter: blur(4px);
}
.panel-wide { grid-column: span 1; }

.plate {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--panel-edge);
  padding-bottom: 10px;
  margin-bottom: 12px;
}
.plate h2 {
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--brass);
}
.prov {
  font-size: 11px;
  color: var(--dim);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.prov.is-live::before {
  content: "●";
  color: var(--green);
  margin-right: 5px;
  font-size: 8px;
  vertical-align: 1px;
}
.prov.is-stale::before {
  content: "●";
  color: var(--yellow);
  margin-right: 5px;
  font-size: 8px;
  vertical-align: 1px;
}
.prov.is-err::before {
  content: "●";
  color: var(--red);
  margin-right: 5px;
  font-size: 8px;
  vertical-align: 1px;
}

.explain { color: var(--dim); font-size: 13.5px; margin-bottom: 14px; }

.imgwrap {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  background: #060a14;
  border: 1px solid #1b2440;
}
.imgwrap.square { aspect-ratio: 1 / 1; }
.imgwrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  opacity: 1;
  transition: opacity 0.35s ease;
}
.imgwrap img.is-loading { opacity: 0.25; }
/* Disk-size normalization: SDO and EPIC frames carry black padding around the
   disk, which made the Sun render smaller than the Earth. Zoom the padded
   frames so all disks fill their panels equally. */
.imgwrap img.zoom-sun { transform: scale(1.22); }
.imgwrap img.zoom-epic { transform: scale(1.40); }
.imgveil {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--dim);
  background: rgba(6, 10, 20, 0.55);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}
.imgveil.is-on { opacity: 1; }

.tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.tab {
  background: transparent;
  border: 1px solid var(--panel-edge);
  border-radius: 999px;
  color: var(--dim);
  font: inherit;
  font-size: 12px;
  padding: 5px 12px;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}
.tab small { display: block; font-size: 9.5px; letter-spacing: 0.06em; opacity: 0.75; }
.tab:hover { border-color: var(--blue); color: var(--ink); }
.tab.is-active { border-color: var(--brass); color: var(--brass); }

.caption { font-size: 12.5px; color: var(--dim); margin-top: 10px; }

.facts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 16px;
  margin: 12px 0 4px;
}
.facts > div {
  border-left: 2px solid var(--panel-edge);
  padding-left: 10px;
}
.facts dt {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--dim);
}
.facts dd {
  font-size: 15px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

.about { margin-top: 14px; font-size: 12.5px; color: var(--dim); }
.about summary {
  cursor: pointer;
  color: var(--blue);
  font-size: 12px;
  letter-spacing: 0.04em;
}
.about p { margin-top: 8px; }

/* launch panel */
.launch-body h3 { font-size: 17px; font-weight: 600; margin-bottom: 6px; }
.countdown {
  font-size: clamp(22px, 3vw, 30px);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.06em;
  color: var(--brass);
  margin: 6px 0 10px;
}

/* footer */
.site-foot {
  max-width: 1180px;
  margin: 0 auto;
  padding: 8px 20px 48px;
  text-align: center;
  color: var(--dim);
  font-size: 12px;
}
.site-foot .observer { margin-bottom: 10px; color: var(--ink); font-size: 12.5px; }
.site-foot .dim { color: var(--dim); }
.site-foot .credits { max-width: 760px; margin: 0 auto 10px; }
.site-foot .colophon { letter-spacing: 0.06em; }

/* top navigation — sticky */
.topnav {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px clamp(20px, 4vw, 40px);
  background: rgba(7, 10, 18, 0.82);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(36, 49, 80, 0.55);
}
.nav-home {
  color: var(--ink);
  text-decoration: none;
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 300;
}
.nav-home b { font-weight: 600; }
.nav-links { display: flex; gap: 6px; align-items: center; }
.nav-links a {
  color: var(--dim);
  text-decoration: none;
  font-size: 12.5px;
  padding: 4px 12px;
  border-radius: 999px;
  border: 1px solid transparent;
  white-space: nowrap;
}
.nav-links a:hover { color: var(--ink); border-color: var(--panel-edge); }
.nav-links a.is-here { color: var(--brass); border-color: var(--brass); }

/* room pages */
.room-head { padding-top: 22px; }
.room-title { letter-spacing: 0.26em; color: var(--brass); }
.room {
  max-width: 1180px;
  margin: 0 auto;
  padding: 24px 20px 40px;
  display: flex;
  flex-direction: column;
  gap: 26px;
}
.room > .panel { max-width: 760px; margin: 0 auto; width: 100%; }
.roomsec-title {
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--brass);
  text-align: center;
  margin-bottom: 8px;
}
.roomsec .explain { max-width: 700px; margin: 0 auto 16px; text-align: center; }
.duo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.hero-controls { display: flex; justify-content: center; margin-top: 12px; }
.imgwrap video { width: 100%; height: 100%; object-fit: contain; display: block; }

/* the wall */
.wall {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.wallcard {
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  padding: 10px;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: var(--ink);
  transition: border-color 0.15s, transform 0.15s;
}
.wallcard:hover { border-color: var(--blue); transform: translateY(-2px); }
.wallcard.is-here { border-color: var(--brass); }
.wallimgwrap {
  display: block;
  border-radius: 8px;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background: #060a14;
}
.wallimgwrap img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.18); display: block; }
.wallmeta { display: block; margin-top: 8px; }
.wallmeta b { display: block; font-size: 13px; font-weight: 600; }
.wallmeta i { display: block; font-style: normal; font-size: 11px; color: var(--dim); }

/* flux chart */
.chartwrap { border: 1px solid #1b2440; border-radius: 10px; background: #060a14; padding: 6px; }
#flux-chart { width: 100%; height: auto; display: block; }
#flux-chart .grid { stroke: #223052; stroke-width: 1; }
#flux-chart .grid.v { stroke-dasharray: 2 4; }
#flux-chart .gl { fill: var(--dim); font-size: 11px; font-family: Inter, sans-serif; }
#flux-chart .gl.t { text-anchor: middle; }
#flux-chart .fluxline { fill: none; stroke: var(--brass); stroke-width: 1.4; }

/* flare log */
.flarelog { list-style: none; margin-top: 4px; }
.flarelog li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 2px;
  border-bottom: 1px solid rgba(36, 49, 80, 0.6);
  font-variant-numeric: tabular-nums;
}
.fcls {
  min-width: 52px;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  border-radius: 6px;
  padding: 2px 6px;
}
.fcls.fb { background: rgba(95,206,138,0.13); color: var(--green); }
.fcls.fc { background: rgba(232,196,105,0.13); color: var(--yellow); }
.fcls.fm { background: rgba(224,148,90,0.15); color: #e0945a; }
.fcls.fx { background: rgba(224,108,117,0.16); color: var(--red); }
.fwhen { flex: 1; font-size: 13px; }
.fdur { font-size: 12px; color: var(--dim); }
.fnone { color: var(--dim); font-size: 13px; padding: 8px 0; }

/* observer picker */
.obs-actions { display: inline-flex; gap: 8px; margin-left: 10px; }
.obs-btn {
  background: transparent;
  border: 1px solid var(--panel-edge);
  border-radius: 999px;
  color: var(--blue);
  font: inherit;
  font-size: 11.5px;
  padding: 2px 10px;
  cursor: pointer;
}
.obs-btn:hover { border-color: var(--blue); }
dialog.obs-dialog {
  background: var(--panel);
  color: var(--ink);
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  padding: 20px 22px;
  max-width: 340px;
  max-height: 90vh;
  overflow: auto;
}
.obs-dialog .obs-results {
  list-style: none;
  margin: 6px 0 2px;
  padding: 0;
  max-height: 184px;
  overflow-y: auto;
  border: 1px solid var(--panel-edge);
  border-radius: 8px;
}
.obs-dialog .obs-results button {
  width: 100%;
  display: block;
  text-align: left;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(36, 49, 80, 0.5);
  color: var(--ink);
  font: inherit;
  padding: 7px 10px;
  cursor: pointer;
}
.obs-dialog .obs-results li:last-child button { border-bottom: none; }
.obs-dialog .obs-results button:hover { background: rgba(127, 180, 232, 0.10); }
.obs-dialog .obs-results button b { font-weight: 600; font-size: 13px; }
.obs-dialog .obs-results button span { display: block; font-size: 11px; color: var(--dim); }
.obs-dialog .obs-noresult { padding: 8px 10px; font-size: 12px; color: var(--dim); }
.obs-dialog .obs-divider { display: flex; align-items: center; gap: 10px; margin: 14px 0 2px; color: var(--dim); font-size: 11px; }
.obs-dialog .obs-divider::before, .obs-dialog .obs-divider::after { content: ""; flex: 1; height: 1px; background: var(--panel-edge); }
dialog.obs-dialog::backdrop { background: rgba(4, 6, 12, 0.7); }
.obs-dialog h3 { font-size: 14px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--brass); margin-bottom: 12px; }
.obs-dialog label { display: block; font-size: 12px; color: var(--dim); margin: 8px 0 3px; }
.obs-dialog input {
  width: 100%;
  background: #0a101e;
  border: 1px solid var(--panel-edge);
  border-radius: 6px;
  color: var(--ink);
  font: inherit;
  padding: 6px 9px;
}
.obs-dialog .obs-row { display: flex; gap: 10px; }
.obs-dialog .obs-row > div { flex: 1; }
.obs-dialog menu { display: flex; justify-content: flex-end; gap: 10px; margin-top: 16px; padding: 0; }
.obs-dialog button { font: inherit; font-size: 13px; padding: 6px 16px; border-radius: 8px; cursor: pointer; }
.obs-dialog .obs-save { background: var(--brass); border: none; color: #161208; font-weight: 600; }
.obs-dialog .obs-cancel { background: transparent; border: 1px solid var(--panel-edge); color: var(--dim); }

/* orbit room */
.panel-map { max-width: 980px !important; }
.mapwrap { border: 1px solid #1b2440; border-radius: 10px; background: #101a30; overflow: hidden; }
#orbit-map, #earth-map { width: 100%; height: auto; display: block; }
#map-base, #emap-base { opacity: 0.9; }
#orbit-map line, #earth-map line { stroke: rgba(160, 180, 220, 0.22); stroke-width: 0.6; }
#orbit-map line.eq, #earth-map line.eq { stroke: rgba(160, 180, 220, 0.38); stroke-width: 1; }
#orbit-map .night, #earth-map .night { fill: rgba(2, 4, 10, 0.6); stroke: #5a6f9e; stroke-width: 1; }
#orbit-map text { paint-order: stroke; stroke: rgba(3, 6, 12, 0.9); stroke-width: 2.5px; font-weight: 600; }
#orbit-map .track { stroke-width: 1.5; opacity: 0.9; }

/* earth room event markers */
.ev-fire { fill: #e0945a; opacity: 0.85; }
.ev-storm { fill: #7fb4e8; opacity: 0.9; }
.ev-volcano { fill: #e06c75; opacity: 0.9; }
.ev-quake { fill: none; stroke: var(--brass); stroke-width: 1.2; opacity: 0.85; }
.maplegend {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  justify-content: center;
  margin-top: 10px;
  font-size: 12px;
  color: var(--dim);
}
.maplegend .lg { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: 5px; vertical-align: -1px; }
.lg-fire { background: #e0945a; }
.lg-storm { background: #7fb4e8; }
.lg-volcano { background: #e06c75; }
.lg-quake { background: transparent; border: 1.5px solid var(--brass); }
.eventlist { list-style: none; }
.eventlist li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 7px 2px;
  border-bottom: 1px solid rgba(36, 49, 80, 0.6);
}
.evtag {
  min-width: 86px;
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  border-radius: 6px;
  padding: 2px 8px;
}
.ev-quake-t { background: rgba(212, 175, 110, 0.13); color: var(--brass); }
.ev-storm-t { background: rgba(127, 180, 232, 0.13); color: var(--blue); }
.ev-volcano-t { background: rgba(224, 108, 117, 0.14); color: var(--red); }
.evname { flex: 1; font-size: 13.5px; }
.evnote { font-size: 12px; color: var(--dim); font-variant-numeric: tabular-nums; }

/* space weather room */
#aurora-canvas { width: 100%; height: auto; display: block; }
#kp-chart, #speed-chart, #dens-chart { width: 100%; height: auto; display: block; }
#kp-chart .grid, #speed-chart .grid, #dens-chart .grid { stroke: #223052; stroke-width: 1; }
#kp-chart .gl, #speed-chart .gl, #dens-chart .gl { fill: var(--dim); font-size: 11px; font-family: Inter, sans-serif; }
#kp-chart .gl.r { text-anchor: end; }
#kp-chart .nowline { stroke: var(--blue); stroke-width: 1; stroke-dasharray: 3 3; }
#speed-chart .fluxline, #dens-chart .fluxline { fill: none; stroke: var(--brass); stroke-width: 1.4; }
.alertlist { list-style: none; }
.alertlist li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 2px;
  border-bottom: 1px solid rgba(36, 49, 80, 0.6);
}
.altag {
  min-width: 80px;
  text-align: center;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  border-radius: 6px;
  padding: 3px 8px;
}
.al-warn { background: rgba(224, 108, 117, 0.14); color: var(--red); }
.al-watch { background: rgba(232, 196, 105, 0.13); color: var(--yellow); }
.al-sum { background: rgba(127, 180, 232, 0.12); color: var(--blue); }

/* tonight page */
.verdict {
  font-size: clamp(17px, 2.4vw, 21px);
  line-height: 1.6;
  color: var(--ink);
  font-weight: 300;
}
.planetlist {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 14px;
  max-width: 1000px;
  margin: 0 auto;
}
.planetcard {
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  padding: 14px 16px;
  opacity: 0.55;
}
.planetcard.is-up { opacity: 1; border-color: rgba(212, 175, 110, 0.5); }
.planetcard b { display: block; font-size: 15px; margin-bottom: 3px; }
.planetcard .pline { display: block; font-size: 13px; color: var(--blue); margin-bottom: 5px; font-variant-numeric: tabular-nums; }
.planetcard small { display: block; font-size: 12px; color: var(--dim); line-height: 1.5; }
.tracknote { color: var(--brass); }
#orbit-map .track { fill: none; stroke-width: 1.2; opacity: 0.75; }
#orbit-map text { font-family: Inter, sans-serif; font-size: 10px; }
#orbit-map .selsat { stroke: #fff; stroke-width: 1; }
#orbit-map .obsdot { fill: none; stroke: #e9edf5; stroke-width: 1.4; }
#orbit-map .obstxt { fill: #8b96ad; font-size: 9px; }

.fleet {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.fleetcard {
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  padding: 14px 16px;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: var(--dim);
  font-size: 12.5px;
  line-height: 1.5;
  transition: border-color 0.15s, transform 0.15s;
}
.fleetcard:hover { border-color: var(--blue); transform: translateY(-2px); }
.fleetcard.is-here { border-color: var(--brass); }
.fleetcard b { display: inline-block; color: var(--ink); font-size: 14.5px; margin-bottom: 2px; }
.fleetdot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; margin-right: 8px; vertical-align: 1px; }
.fleetcard .fleetstat { display: block; font-style: normal; color: var(--blue); font-size: 12px; font-variant-numeric: tabular-nums; margin-bottom: 6px; }

.passlist { list-style: none; }
.passlist li {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  padding: 9px 2px;
  border-bottom: 1px solid rgba(36, 49, 80, 0.6);
  font-variant-numeric: tabular-nums;
}
.pwhen { min-width: 110px; font-weight: 600; }
.pel { min-width: 70px; color: var(--blue); }
.pdur { min-width: 56px; color: var(--dim); font-size: 13px; }
.pverdict { flex: 1; text-align: right; font-size: 12.5px; }
.pv-yes { color: var(--green); font-weight: 600; }
.pv-day { color: var(--dim); }
.pv-shadow { color: var(--dim); }

/* moon room */
.loopbar { display: flex; align-items: center; gap: 14px; margin-top: 12px; justify-content: center; }
.loopdate { font-variant-numeric: tabular-nums; color: var(--brass); font-size: 14px; min-width: 130px; }
.mooncal-head {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  text-align: center;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--dim);
  margin-bottom: 8px;
}
.mooncal { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.calday {
  border: 1px solid var(--panel-edge);
  border-radius: 8px;
  padding: 6px 4px;
  text-align: center;
  background: rgba(10, 15, 28, 0.6);
}
.calday b { display: block; font-size: 11px; color: var(--dim); font-weight: 500; }
.calday em { display: block; font-style: normal; font-size: 20px; line-height: 1.3; }
.calday small { display: block; font-size: 10px; color: var(--dim); font-variant-numeric: tabular-nums; }
.calday i { display: block; font-style: normal; font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--brass); margin-top: 2px; }
.calday.is-today { border-color: var(--brass); background: rgba(212, 175, 110, 0.08); }
.calday.is-today b { color: var(--brass); font-weight: 700; }
.calblank { }

.almanac {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  max-width: 1000px;
  margin: 0 auto;
}
.almcard {
  background: var(--panel);
  border: 1px solid var(--panel-edge);
  border-radius: 12px;
  padding: 14px 16px;
  text-align: center;
}
.almcard .almicon { display: block; font-size: 26px; margin-bottom: 6px; }
.almcard b { display: block; font-size: 13.5px; margin-bottom: 4px; }
.almcard .almwhen { display: block; font-size: 12.5px; color: var(--blue); font-variant-numeric: tabular-nums; }
.almcard small { display: block; font-size: 11.5px; color: var(--dim); margin-top: 4px; }

/* tonight 2.0 — the cinematic sky-track hero */
.hero-sec { margin-bottom: 6px; }
.skytrack { max-width: 1000px; margin: 0 auto; }
.skytrack svg { width: 100%; height: auto; display: block; border: 1px solid var(--panel-edge); border-radius: 14px; }

.moonview { display: flex; align-items: center; gap: 24px; margin: 8px 0 2px; }
.moondisc { flex: 0 0 auto; width: 112px; }
.moonsvg { width: 112px; height: 112px; display: block; }
.moonview .facts { flex: 1; margin: 0; }

.skydome { margin: 2px auto 16px; max-width: 760px; }
.skydome svg { width: 100%; height: auto; display: block; overflow: visible; }
.skydome .dome-base { stroke: #2c3a5c; stroke-width: 1.2; }
.skydome .dome-ring { stroke: #1b2440; stroke-width: 1; stroke-dasharray: 3 5; }
.skydome .dome-cmp { fill: var(--dim); font: 500 15px Inter, sans-serif; }
.skydome .dome-lbl { font: 500 16px Inter, sans-serif; }

.pas-arc { flex: 0 0 auto; }
.passarc { width: 120px; height: 42px; display: block; }

/* responsive */
@media (max-width: 860px) {
  .nav-links {
    width: 100%;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 2px;
  }
  .nav-links::-webkit-scrollbar { display: none; }
  .almanac { grid-template-columns: repeat(2, 1fr); }
  .calday em { font-size: 15px; }
  .fleet { grid-template-columns: 1fr; }
  .pverdict { text-align: left; flex-basis: 100%; }
  .grid { grid-template-columns: 1fr; }
  .status-strip { grid-template-columns: repeat(2, 1fr); }
  .facts { grid-template-columns: 1fr 1fr; }
  .duo { grid-template-columns: 1fr; }
  .wall { grid-template-columns: repeat(2, 1fr); }
  .moonview { gap: 16px; }
  .moondisc, .moonsvg { width: 92px; height: 92px; }
  .moondisc { height: auto; }
  .pas-arc { display: none; }
}
