:root {
  --bg: #0b1020;
  --surface: #141a2e;
  --surface-2: #1c2440;
  --text: #eef1f8;
  --muted: #9aa3c0;
  --faint: #6b7497;
  --border: rgba(255, 255, 255, 0.10);
  --border-strong: rgba(255, 255, 255, 0.18);
  --accent: #fbbf24;
  --accent-bg: color-mix(in srgb, var(--accent) 15%, transparent);
  --danger: #f87171;
  --radius: 12px;
  --radius-sm: 8px;
  --maxw: 640px;
}
@media (prefers-color-scheme: light) {
  :root {
    --bg: #f5f7fb; --surface: #ffffff; --surface-2: #eef1f8;
    --text: #16203a; --muted: #5a6488; --faint: #8b93ad;
    --border: rgba(20,30,60,.10); --border-strong: rgba(20,30,60,.18);
    --accent: #b45309;
  }
}
* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif; background: var(--bg); color: var(--text); line-height: 1.55; -webkit-font-smoothing: antialiased; }
a { color: var(--accent); text-decoration: none; } a:hover { text-decoration: underline; }
h1 { font-size: 1.75rem; font-weight: 600; letter-spacing: -0.01em; margin: 6px 0 16px; }
h2 { font-size: 1.1rem; font-weight: 600; margin: 0 0 8px; display: flex; align-items: center; gap: 8px; }
h3 { font-size: 1rem; font-weight: 600; margin: 0 0 4px; display: flex; align-items: center; gap: 8px; }
svg { width: 1em; height: 1em; }

.site-header { max-width: var(--maxw); margin: 0 auto; padding: 16px 18px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.brand { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 1.05rem; color: var(--text); }
.brand:hover { text-decoration: none; } .brand-icon { color: var(--accent); font-size: 1.3rem; }
.tz-pill { display: inline-flex; align-items: center; gap: 6px; font-size: .78rem; color: var(--muted); background: var(--surface); border: 1px solid var(--border); padding: 5px 11px; border-radius: 999px; }

#main { max-width: var(--maxw); margin: 0 auto; padding: 4px 18px 40px; }

.hero { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 22px; }
.hero-eyebrow { font-size: .8rem; color: var(--accent); font-weight: 500; }
.countdown { background: var(--surface-2); border-radius: var(--radius-sm); padding: 18px; text-align: center; }
.countdown-time { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; font-size: 2.3rem; font-weight: 600; letter-spacing: 1px; line-height: 1.1; }
.countdown-when { font-size: .86rem; color: var(--muted); margin-top: 4px; }
.hero-actions { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }
.btn { flex: 1; min-width: 150px; display: inline-flex; align-items: center; justify-content: center; gap: 7px; font-size: .9rem; font-weight: 500; font-family: inherit; padding: 11px 14px; border-radius: var(--radius-sm); border: 1px solid var(--border-strong); background: transparent; color: var(--text); cursor: pointer; transition: background .12s; }
.btn:hover { background: var(--surface-2); text-decoration: none; }
.btn:active { transform: scale(.98); }
.btn-primary { color: var(--accent); background: var(--accent-bg); border-color: transparent; }

.block { margin-top: 26px; }
.lead { color: var(--muted); font-size: .9rem; margin: 0 0 14px; }

.loc-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.loc-item { display: flex; align-items: center; justify-content: space-between; gap: 12px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 12px 14px; }
.loc-name { font-size: .92rem; font-weight: 500; }
.loc-sub { font-size: .76rem; color: var(--muted); margin-top: 2px; }
.loc-time { text-align: right; flex-shrink: 0; }
.loc-time .t { font-size: .9rem; font-weight: 500; font-variant-numeric: tabular-nums; }
.loc-time .dur { font-size: .74rem; color: var(--accent); margin-top: 2px; }
.tag { font-size: .68rem; color: var(--accent); border: 1px solid var(--border); border-radius: 999px; padding: 2px 8px; margin-left: 6px; }

.travel-card { margin-top: 26px; background: var(--accent-bg); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; }
.travel-card p { font-size: .85rem; color: var(--muted); margin: 0 0 12px; }
.travel-actions { display: flex; gap: 10px; flex-wrap: wrap; }

.partial p, .safety p { font-size: .9rem; }
.safety h2 svg { color: var(--accent); }
.safety strong { color: var(--text); }

.ad-slot { margin: 26px 0; min-height: 120px; display: flex; align-items: center; justify-content: center; border: 1px dashed var(--border-strong); border-radius: var(--radius-sm); color: var(--faint); font-size: .78rem; background: var(--surface); }

.site-footer { max-width: var(--maxw); margin: 0 auto; padding: 24px 18px 40px; font-size: .76rem; color: var(--faint); text-align: center; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

@media (max-width: 380px) { .hero-actions .btn, .travel-actions .btn { flex-basis: 100%; } }

/* Auto-ads phase: hide reserved manual slots; Google auto-places its own. Remove when we switch to manual units. */
.ad-slot { display: none !important; }
