/* CoasterVault — dark thrill-park aesthetic layered on Tailwind CDN */

:root {
  --cv-bg: #0B1120;
  --cv-bg-2: #111827;
  --cv-panel: #1E293B;
  --cv-panel-2: #0F172A;
  --cv-border: #334155;
  --cv-text: #E2E8F0;
  --cv-muted: #94A3B8;
  --cv-yellow: #FACC15;
  --cv-yellow-2: #FBBF24;
  --cv-steel: #38BDF8;
  --cv-steel-2: #0EA5E9;
  --cv-coral: #F43F5E;
  --cv-coral-2: #FB7185;
  --cv-grid: rgba(56,189,248,.07);
}

html { scroll-behavior: smooth; background: var(--cv-bg); }
body {
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, sans-serif;
  background: var(--cv-bg);
  color: var(--cv-text);
}

.font-display {
  font-family: 'Anton', 'Bebas Neue', Impact, sans-serif;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}
.font-bebas { font-family: 'Bebas Neue', Impact, sans-serif; letter-spacing: 0.04em; }
.font-mono-num { font-variant-numeric: tabular-nums; }

/* ===== Header / Footer ===== */
.cv-topbar {
  background: linear-gradient(180deg, rgba(11,17,32,.97) 0%, rgba(11,17,32,.78) 100%);
  border-bottom: 1px solid var(--cv-border);
  backdrop-filter: blur(8px);
}
.cv-topbar a { color: var(--cv-text); }
.cv-topbar a:hover { color: var(--cv-yellow); }
.cv-logo {
  display: inline-flex; align-items: center; gap: .65rem;
  font-family: 'Anton', sans-serif; letter-spacing: .04em;
  font-size: 1.55rem; color: #fff;
}
.cv-logo .mark {
  display: inline-grid; place-items: center;
  width: 2.25rem; height: 2.25rem;
  background: var(--cv-yellow); color: #0B1120;
  font-family: 'Anton', sans-serif; font-size: 1.15rem;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 12% 100%);
  border: 2px solid var(--cv-yellow);
}
.cv-nav-link {
  position: relative; padding: .55rem .15rem;
  font-size: .82rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: var(--cv-text);
}
.cv-nav-link:hover { color: var(--cv-yellow); }
.cv-nav-link.active::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px; height: 3px;
  background: var(--cv-yellow);
}
.cv-cta-pill {
  display: inline-flex; align-items: center; gap: .4rem;
  background: var(--cv-yellow); color: #0B1120;
  font-family: 'Anton', sans-serif; letter-spacing: .08em;
  text-transform: uppercase; font-size: .82rem;
  padding: .55rem 1rem; border-radius: 2px;
  transition: all .12s ease;
}
.cv-cta-pill:hover { background: #fff; color: #0B1120; transform: translateY(-1px); }

/* ===== Hero ===== */
.cv-hero {
  position: relative; isolation: isolate;
  background:
    radial-gradient(60rem 40rem at 80% -10%, rgba(56,189,248,.12), transparent 60%),
    radial-gradient(40rem 30rem at 10% 110%, rgba(250,204,21,.08), transparent 60%),
    linear-gradient(180deg, #0B1120 0%, #0B1120 100%);
  overflow: hidden;
}
.cv-hero-grid {
  position: absolute; inset: 0; z-index: -1;
  background-image:
    linear-gradient(var(--cv-grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--cv-grid) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: linear-gradient(180deg, transparent 0, #000 30%, #000 70%, transparent 100%);
}
.cv-hero-coaster-svg {
  position: absolute; right: -2rem; bottom: -2rem; width: 60%; max-width: 720px; opacity: .35; z-index: -1;
  pointer-events: none;
}
.cv-eyebrow {
  display: inline-block; color: var(--cv-yellow);
  font-family: 'Anton', sans-serif; letter-spacing: .25em;
  font-size: .8rem; padding-left: 14px; position: relative;
}
.cv-eyebrow::before {
  content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 8px; height: 8px; background: var(--cv-yellow);
}
.cv-display {
  font-family: 'Anton', sans-serif; line-height: .85; letter-spacing: -.005em;
  font-weight: 400; text-transform: uppercase; color: #fff;
}
.cv-display .accent { color: var(--cv-yellow); }
.cv-display .steel { color: var(--cv-steel); }
.cv-skew {
  display: inline-block; transform: skewY(-2deg); transform-origin: left;
}

/* ===== Stat callouts ===== */
.cv-stat-row { display: grid; grid-template-columns: repeat(2,1fr); gap: 0; }
@media (min-width: 640px) { .cv-stat-row { grid-template-columns: repeat(4,1fr); } }
.cv-stat {
  position: relative; padding: 1.1rem 1.25rem 1.1rem 1.5rem;
  border-left: 4px solid var(--cv-yellow); background: rgba(255,255,255,.03);
  border-top: 1px solid rgba(255,255,255,.06); border-bottom: 1px solid rgba(255,255,255,.06);
}
.cv-stat + .cv-stat { border-left-color: var(--cv-steel); }
.cv-stat:nth-child(3n) { border-left-color: var(--cv-coral); }
.cv-stat:nth-child(4n) { border-left-color: var(--cv-yellow-2); }
.cv-stat .label {
  display: block; font-family: 'Anton', sans-serif;
  font-size: .72rem; letter-spacing: .22em; color: var(--cv-muted);
}
.cv-stat .value {
  display: block; font-family: 'Anton', sans-serif;
  font-size: 2.4rem; line-height: 1; color: #fff; margin-top: .25rem;
  font-variant-numeric: tabular-nums;
}
.cv-stat .unit { font-size: .9rem; color: var(--cv-muted); margin-left: .35rem; letter-spacing: .15em; }

.cv-mega-stat {
  display: flex; align-items: baseline; gap: .55rem;
  font-family: 'Anton', sans-serif; line-height: .85;
}
.cv-mega-stat .num { font-size: clamp(4rem, 10vw, 8rem); color: var(--cv-yellow); }
.cv-mega-stat .unit { font-size: 1.4rem; letter-spacing: .25em; color: var(--cv-muted); text-transform: uppercase; }

/* ===== Cards / Panels ===== */
.cv-card {
  background: var(--cv-panel);
  border: 1px solid var(--cv-border);
  border-radius: 6px;
  transition: border-color .15s, transform .15s, box-shadow .15s;
  display: block;
}
.cv-card:hover {
  border-color: var(--cv-yellow);
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -12px rgba(250,204,21,.25);
}
.cv-card-dark { background: var(--cv-panel-2); border: 1px solid var(--cv-border); border-radius: 6px; }
.cv-panel { background: var(--cv-panel); border: 1px solid var(--cv-border); border-radius: 6px; }
.cv-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--cv-border), transparent);
}
.cv-section-title {
  font-family: 'Anton', sans-serif; letter-spacing: .03em;
  font-size: clamp(2rem, 4vw, 3rem); color: #fff; line-height: 1;
  text-transform: uppercase;
}
.cv-section-title .accent { color: var(--cv-yellow); }
.cv-section-kicker {
  color: var(--cv-yellow); letter-spacing: .25em;
  font-family: 'Anton', sans-serif; font-size: .75rem; text-transform: uppercase;
}
.cv-rule {
  height: 4px; width: 64px; background: var(--cv-yellow);
  margin: .55rem 0 1.4rem;
}

/* ===== Tables ===== */
.cv-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.cv-table th {
  text-align: left; font-family: 'Anton', sans-serif; font-weight: 400;
  text-transform: uppercase; letter-spacing: .14em; font-size: .72rem;
  color: var(--cv-yellow); padding: .85rem .9rem;
  border-bottom: 1px solid var(--cv-border); background: var(--cv-panel-2);
}
.cv-table td {
  padding: .9rem; border-bottom: 1px solid var(--cv-border);
  color: var(--cv-text); vertical-align: middle;
}
.cv-table tbody tr:hover td { background: rgba(56,189,248,.05); }
.cv-table a { color: #fff; }
.cv-table a:hover { color: var(--cv-yellow); }
.cv-table .num { font-variant-numeric: tabular-nums; }

/* ===== Rank ===== */
.cv-rank-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 2.4rem; height: 2.4rem;
  background: var(--cv-yellow); color: #0B1120;
  font-family: 'Anton', sans-serif; font-size: 1.2rem;
  border-radius: 2px; flex-shrink: 0;
}
.cv-rank-num.top1 { background: var(--cv-yellow); }
.cv-rank-num.top2 { background: var(--cv-steel); color: #0B1120; }
.cv-rank-num.top3 { background: var(--cv-coral); color: #fff; }
.cv-rank-num.med { background: var(--cv-panel); color: var(--cv-yellow); border: 1px solid var(--cv-border); }

.cv-row {
  display: flex; align-items: center; gap: .9rem;
  padding: .75rem .85rem; border: 1px solid var(--cv-border); border-radius: 4px;
  background: var(--cv-panel); margin-bottom: .5rem;
  transition: border-color .15s, background .15s;
}
.cv-row:hover { border-color: var(--cv-yellow); background: var(--cv-panel-2); }
.cv-row .name { color: #fff; font-weight: 600; }
.cv-row .name:hover { color: var(--cv-yellow); }
.cv-row .meta { color: var(--cv-muted); font-size: .8rem; }
.cv-row .stat { font-family: 'Anton', sans-serif; font-size: 1.5rem; color: var(--cv-yellow); }
.cv-row .stat-unit { font-size: .65rem; letter-spacing: .15em; color: var(--cv-muted); display: block; text-transform: uppercase; }

/* ===== Badges ===== */
.cv-badge {
  display: inline-block; padding: .15rem .55rem;
  font-size: .65rem; font-weight: 600; letter-spacing: .15em;
  text-transform: uppercase; border-radius: 2px;
  background: var(--cv-panel); border: 1px solid var(--cv-border); color: var(--cv-text);
}
.cv-badge-steel { background: rgba(56,189,248,.15); border-color: var(--cv-steel); color: var(--cv-steel); }
.cv-badge-wood { background: rgba(251,191,36,.15); border-color: var(--cv-yellow-2); color: var(--cv-yellow-2); }
.cv-badge-hybrid { background: rgba(244,63,94,.15); border-color: var(--cv-coral); color: var(--cv-coral-2); }
.cv-badge-launched { background: rgba(168,85,247,.15); border-color: #a855f7; color: #c084fc; }

/* ===== Prose ===== */
.cv-prose { color: var(--cv-text); font-size: 1.02rem; }
.cv-prose h2 {
  font-family: 'Anton', sans-serif; letter-spacing: .02em; text-transform: uppercase;
  font-size: 1.85rem; margin-top: 2.4rem; margin-bottom: .8rem; color: #fff;
  border-bottom: 1px solid var(--cv-border); padding-bottom: .5rem;
}
.cv-prose h3 {
  font-family: 'Anton', sans-serif; letter-spacing: .03em; text-transform: uppercase;
  font-size: 1.35rem; margin-top: 1.6rem; margin-bottom: .55rem; color: var(--cv-yellow);
}
.cv-prose p { line-height: 1.78; margin-bottom: 1.1rem; color: #cbd5e1; }
.cv-prose strong { color: #fff; }
.cv-prose a, .cv-inline-link {
  color: var(--cv-steel); text-decoration: underline;
  text-decoration-color: rgba(56,189,248,.4); text-underline-offset: 3px;
}
.cv-prose a:hover, .cv-inline-link:hover { color: var(--cv-yellow); text-decoration-color: var(--cv-yellow); }
.cv-prose ul { list-style: disc; padding-left: 1.5rem; margin-bottom: 1.1rem; color: #cbd5e1; }
.cv-prose ol { list-style: decimal; padding-left: 1.5rem; margin-bottom: 1.1rem; color: #cbd5e1; }
.cv-prose li { margin-bottom: .35rem; }
.cv-prose blockquote {
  border-left: 4px solid var(--cv-yellow);
  padding: .25rem 0 .25rem 1.1rem; margin: 1.5rem 0; color: #fff; font-style: italic;
}

/* ===== PBN sidebar widget ===== */
.cv-pbn-sidebar {
  background: var(--cv-panel-2); border: 1px solid var(--cv-border); border-radius: 6px;
  padding: 1.25rem 1.25rem 1rem; position: relative;
  border-top: 4px solid var(--cv-yellow);
}
.cv-pbn-eyebrow {
  display: block; font-family: 'Anton', sans-serif; letter-spacing: .22em;
  font-size: .7rem; color: var(--cv-yellow); text-transform: uppercase;
}
.cv-pbn-title {
  font-family: 'Anton', sans-serif; font-size: 1.4rem; color: #fff;
  text-transform: uppercase; letter-spacing: .02em; margin-top: .15rem;
}
.cv-pbn-blurb { color: var(--cv-muted); font-size: .82rem; line-height: 1.55; margin-top: .4rem; }
.cv-pbn-list { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; gap: .55rem; }
.cv-pbn-item {
  display: block; padding: .65rem .75rem;
  background: var(--cv-panel); border: 1px solid var(--cv-border); border-radius: 3px;
  transition: border-color .15s, background .15s;
}
.cv-pbn-item:hover { border-color: var(--cv-yellow); background: rgba(250,204,21,.06); }
.cv-pbn-kicker {
  display: block; font-family: 'Anton', sans-serif; letter-spacing: .18em;
  font-size: .65rem; color: var(--cv-yellow); text-transform: uppercase;
}
.cv-pbn-label { display: block; color: #fff; font-weight: 500; font-size: .9rem; margin-top: .15rem; }

/* ===== Breadcrumbs ===== */
.cv-crumbs {
  background: var(--cv-bg-2); border-bottom: 1px solid var(--cv-border);
  font-size: .78rem; color: var(--cv-muted); letter-spacing: .03em;
}
.cv-crumbs a { color: var(--cv-muted); }
.cv-crumbs a:hover { color: var(--cv-yellow); }
.cv-crumbs .sep { color: var(--cv-border); margin: 0 .35rem; }
.cv-crumbs .here { color: var(--cv-text); }

/* ===== Footer ===== */
.cv-footer {
  background: linear-gradient(180deg, var(--cv-bg) 0%, #050810 100%);
  border-top: 1px solid var(--cv-border);
  color: var(--cv-muted);
}
.cv-footer h3 {
  font-family: 'Anton', sans-serif; letter-spacing: .04em; color: var(--cv-yellow);
  text-transform: uppercase; font-size: 1rem; margin-bottom: .8rem;
}
.cv-footer a { color: var(--cv-text); }
.cv-footer a:hover { color: var(--cv-yellow); }
.cv-footer .links { display: grid; gap: .4rem; font-size: .9rem; }
.cv-footer-pbn { padding: 1.25rem; background: var(--cv-panel-2); border: 1px solid var(--cv-border); border-radius: 6px; border-top: 4px solid var(--cv-yellow); }

/* ===== Diagonal accent strip ===== */
.cv-stripe {
  height: 6px; background: repeating-linear-gradient(
    -45deg, var(--cv-yellow) 0 14px, #0B1120 14px 28px
  );
}
.cv-stripe-thin {
  height: 2px; background: repeating-linear-gradient(
    -45deg, var(--cv-yellow) 0 6px, transparent 6px 12px
  );
}

/* ===== Filter bar ===== */
.cv-filter-bar {
  background: var(--cv-panel-2); border: 1px solid var(--cv-border); border-radius: 6px;
  padding: .75rem;
}
.cv-input, .cv-select {
  background: var(--cv-bg); color: var(--cv-text);
  border: 1px solid var(--cv-border); border-radius: 3px;
  padding: .55rem .7rem; font-size: .87rem;
}
.cv-input:focus, .cv-select:focus { outline: none; border-color: var(--cv-yellow); }
.cv-btn-yellow {
  background: var(--cv-yellow); color: #0B1120;
  font-family: 'Anton', sans-serif; letter-spacing: .08em; text-transform: uppercase;
  padding: .55rem 1rem; border-radius: 2px; font-size: .85rem;
}
.cv-btn-yellow:hover { background: #fff; }

/* ===== AdSense placeholder ===== */
.cv-ad-slot { display: none; } /* placeholder comments live in markup, not visible */

/* ===== Misc ===== */
.cv-pill {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .35rem .7rem; background: var(--cv-panel); border: 1px solid var(--cv-border);
  border-radius: 999px; font-size: .78rem; color: var(--cv-text);
}
.cv-pill .dot { width: 8px; height: 8px; background: var(--cv-yellow); border-radius: 50%; }
.cv-link { color: var(--cv-yellow); font-family: 'Anton', sans-serif; letter-spacing: .1em; text-transform: uppercase; font-size: .85rem; }
.cv-link:hover { color: #fff; }

/* Pagination */
.cv-page-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 2.4rem; height: 2.4rem; padding: 0 .7rem;
  background: var(--cv-panel); border: 1px solid var(--cv-border); color: var(--cv-text);
  font-family: 'Anton', sans-serif; letter-spacing: .05em;
}
.cv-page-btn:hover { border-color: var(--cv-yellow); color: var(--cv-yellow); }
.cv-page-btn.active { background: var(--cv-yellow); color: #0B1120; border-color: var(--cv-yellow); }

/* ===== Dark-theme overrides for legacy Tailwind classes used by un-redesigned routes ===== */
body.cv-dark .bg-white { background: var(--cv-panel) !important; color: var(--cv-text) !important; }
body.cv-dark .bg-stone-50, body.cv-dark .bg-stone-100 { background: var(--cv-bg-2) !important; color: var(--cv-text) !important; }
body.cv-dark .text-slate-900, body.cv-dark .text-\[\#0B1437\] { color: #fff !important; }
body.cv-dark .text-slate-700 { color: var(--cv-text) !important; }
body.cv-dark .text-slate-600 { color: #cbd5e1 !important; }
body.cv-dark .text-slate-500, body.cv-dark .text-slate-400 { color: var(--cv-muted) !important; }
body.cv-dark .text-slate-300 { color: #cbd5e1 !important; }
body.cv-dark .text-\[\#FF4D5A\] { color: var(--cv-yellow) !important; }
body.cv-dark .text-\[\#FFB627\] { color: var(--cv-yellow) !important; }
body.cv-dark .bg-\[\#FF4D5A\], body.cv-dark .hover\:bg-\[\#ff6770\]:hover { background: var(--cv-yellow) !important; color: #0B1120 !important; }
body.cv-dark .bg-\[\#0B1437\] { background: var(--cv-bg-2) !important; }
body.cv-dark .border-slate-200, body.cv-dark .border-slate-300, body.cv-dark .border-slate-100 { border-color: var(--cv-border) !important; }
body.cv-dark .hover\:bg-stone-100:hover, body.cv-dark .hover\:bg-stone-50:hover { background: rgba(56,189,248,.08) !important; }
body.cv-dark .font-bebas { font-family: 'Anton', 'Bebas Neue', Impact, sans-serif !important; letter-spacing: .02em !important; text-transform: uppercase; }
body.cv-dark input.cv-input, body.cv-dark select.cv-select, body.cv-dark .border.border-slate-300 { background: var(--cv-bg) !important; color: var(--cv-text) !important; }
body.cv-dark input::placeholder { color: var(--cv-muted) !important; }
body.cv-dark .cv-badge.cv-badge-steel { background: rgba(56,189,248,.15) !important; color: var(--cv-steel) !important; border-color: var(--cv-steel) !important; }
body.cv-dark .cv-badge.cv-badge-wood { background: rgba(251,191,36,.15) !important; color: var(--cv-yellow-2) !important; border-color: var(--cv-yellow-2) !important; }
body.cv-dark .cv-badge.cv-badge-hybrid { background: rgba(244,63,94,.15) !important; color: var(--cv-coral-2) !important; border-color: var(--cv-coral) !important; }
body.cv-dark .bg-rose-100 { background: rgba(244,63,94,.15) !important; }
body.cv-dark .text-rose-300, body.cv-dark .text-rose-800 { color: var(--cv-coral-2) !important; }
body.cv-dark .bg-amber-100 { background: rgba(251,191,36,.15) !important; }
body.cv-dark .text-amber-900 { color: var(--cv-yellow-2) !important; }
body.cv-dark .bg-slate-200 { background: var(--cv-panel) !important; color: var(--cv-text) !important; }
body.cv-dark .text-slate-800 { color: var(--cv-text) !important; }
body.cv-dark .cv-stat-block { background: var(--cv-panel) !important; border-color: var(--cv-border) !important; }
body.cv-dark .cv-stat-block .label { color: var(--cv-muted) !important; }
body.cv-dark .cv-stat-block .value { color: #fff !important; font-family: 'Anton', sans-serif !important; }
body.cv-dark .bg-white\/5 { background: rgba(255,255,255,.05) !important; }
body.cv-dark .bg-white\/10 { background: rgba(255,255,255,.07) !important; }
body.cv-dark .hover\:bg-white\/10:hover, body.cv-dark .hover\:bg-white\/20:hover { background: rgba(250,204,21,.1) !important; }
