/* Single Rider Lines at Disney World. Type-led hero with an abstract "two lanes merge
   into one" motif, then a live board of rides with current standby waits. Site tokens. */

.srl { max-width: 880px; margin: 0 auto; padding: 0 var(--space-md) var(--space-3xl); }

/* ── Hero ─────────────────────────────────────────────────────────────── */
.srl-hero {
  position: relative;
  padding: var(--space-3xl) 0 var(--space-xl);
  overflow: hidden;
}
.srl-lanes { position: absolute; inset: 0 0 auto; height: 220px; z-index: -1; opacity: 0.5; }
.srl-lane {
  position: absolute; left: 0; right: 0; height: 2px;
  background: repeating-linear-gradient(90deg, var(--gold) 0 14px, transparent 14px 28px);
  background-size: 28px 2px;
  animation: srl-flow 1.6s linear infinite;
}
.srl-lane--a { top: 40px; transform: rotate(-7deg); transform-origin: right center; opacity: 0.5; }
.srl-lane--b { top: 110px; transform: rotate(7deg); transform-origin: right center; opacity: 0.5; }
.srl-lane--merged { top: 75px; left: 55%; background: repeating-linear-gradient(90deg, var(--gold) 0 18px, transparent 18px 30px); height: 3px; opacity: 0.8; }
@keyframes srl-flow { to { background-position: 28px 0; } }

.srl-kicker { font-family: var(--label); font-size: 12px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }
.srl-kicker time { color: var(--gold); }
.srl-title {
  font-family: var(--display); font-weight: 800;
  font-size: clamp(2.2rem, 6vw, 3.6rem); line-height: 1.0;
  letter-spacing: -0.02em; margin: var(--space-sm) 0;
}
.srl-standfirst { font-size: clamp(1.05rem, 2.3vw, 1.3rem); line-height: 1.5; color: var(--ink-soft); max-width: 46ch; margin: 0; }

.srl-lede { font-size: 1.18rem; line-height: 1.6; color: var(--ink); border-left: 3px solid var(--gold); padding-left: var(--space-md); margin: var(--space-2xl) 0; }

/* ── Live board ───────────────────────────────────────────────────────── */
.srl-board { margin: var(--space-2xl) 0; }
.srl-board-head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-sm); margin-bottom: var(--space-md); flex-wrap: wrap; }
.srl-board-title { font-family: var(--display); font-weight: 800; font-size: clamp(1.5rem, 4vw, 2rem); margin: 0; }
.srl-live-dot { font-family: var(--label); font-weight: 700; font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-soft); display: inline-flex; align-items: center; gap: 7px; }
.srl-pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 0 var(--gold); animation: srl-ping 1.8s ease-out infinite; }
@keyframes srl-ping { 0% { box-shadow: 0 0 0 0 oklch(84% 0.13 86 / 0.6); } 70%, 100% { box-shadow: 0 0 0 8px oklch(84% 0.13 86 / 0); } }

.srl-cards { display: grid; gap: var(--space-md); }
.srl-card {
  background: var(--paper-2); border: 1px solid var(--hair);
  border-left: 3px solid var(--rule); border-radius: 14px;
  padding: var(--space-md) var(--space-lg);
}
.srl-card--reliable { border-left-color: var(--gold); }
.srl-card--new { border-left-color: oklch(80% 0.12 150); }
.srl-card--flagged { border-left-color: oklch(72% 0.16 40); }

.srl-card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-sm); margin-bottom: var(--space-sm); }
.srl-card-name { font-family: var(--display); font-weight: 700; font-size: 1.2rem; color: var(--ink); text-decoration: none; display: block; }
.srl-card-name:hover { color: var(--gold); }
.srl-card-park { font-family: var(--label); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); display: block; margin-top: 2px; }
.srl-tier { font-family: var(--label); font-weight: 700; font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; padding: 4px 10px; border-radius: 999px; white-space: nowrap; flex: none; }
.srl-tier--reliable { color: var(--paper); background: var(--gold); }
.srl-tier--new { color: var(--paper); background: oklch(80% 0.12 150); }
.srl-tier--flagged { color: var(--ink); background: oklch(40% 0.06 40); border: 1px solid oklch(72% 0.16 40); }

.srl-waits { display: flex; gap: var(--space-sm); margin-bottom: var(--space-sm); }
.srl-wait {
  flex: 1; display: flex; flex-direction: column; gap: 2px;
  background: var(--paper); border: 1px solid var(--hair); border-radius: 10px;
  padding: var(--space-sm) var(--space-md);
}
.srl-wait-v { font-family: var(--display); font-weight: 800; font-size: 1.7rem; line-height: 1; font-variant-numeric: tabular-nums; }
.srl-wait-v small { font-size: 0.55em; font-weight: 600; color: var(--muted); margin-left: 3px; }
.srl-wait-k { font-family: var(--label); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted); }
.srl-wait--standby .srl-wait-v { color: var(--ink-soft); }
.srl-wait--single { border-color: var(--gold-deep); background: oklch(30% 0.06 90); }
.srl-wait--single .srl-wait-v { color: var(--gold); }
.srl-wait--closed, .srl-wait--unknown { flex-basis: 100%; }
.srl-wait--caveat { border-color: oklch(72% 0.16 40); background: oklch(30% 0.05 40); }
.srl-wait-state { font-family: var(--display); font-weight: 700; font-size: 1.05rem; color: var(--ink-soft); }
.srl-wait--closed .srl-wait-state, .srl-wait--caveat .srl-wait-state { color: oklch(78% 0.16 40); }

.srl-card-note { font-size: 0.92rem; line-height: 1.5; color: var(--ink-soft); margin: 0; }
.srl-board-foot { font-size: 0.85rem; color: var(--muted); font-style: italic; margin-top: var(--space-md); }

/* ── Sections ─────────────────────────────────────────────────────────── */
.srl-section { margin: var(--space-2xl) 0; }
.srl-section h2 { font-family: var(--display); font-weight: 800; font-size: clamp(1.5rem, 4vw, 2rem); letter-spacing: -0.01em; margin: 0 0 var(--space-sm); }
.srl p { line-height: 1.6; }
/* Scope the prose link color so it never overrides the CTA button or the card-name links. */
.srl-section a, .srl-board-foot a { color: var(--blue); }

.srl-callout { background: oklch(29% 0.05 282); border: 1px solid var(--rule); border-left: 4px solid var(--gold); border-radius: 12px; padding: var(--space-md) var(--space-lg); margin: var(--space-lg) 0; }
.srl-callout-label { font-family: var(--label); font-weight: 700; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); margin-bottom: var(--space-2xs); }
.srl-callout p { margin: 0; }

/* ── FAQ ──────────────────────────────────────────────────────────────── */
.srl-faq { display: grid; gap: var(--space-xs); }
.srl-faq-item { border: 1px solid var(--hair); border-radius: 12px; background: var(--paper-2); overflow: hidden; }
.srl-faq-item summary { cursor: pointer; padding: var(--space-md) var(--space-lg); font-family: var(--display); font-weight: 700; font-size: 1.02rem; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: var(--space-sm); }
.srl-faq-item summary::-webkit-details-marker { display: none; }
.srl-faq-item summary:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }
.srl-faq-item summary::after { content: "+"; color: var(--gold); font-size: 1.4rem; line-height: 1; flex: none; transition: transform 180ms ease; }
.srl-faq-item[open] summary::after { transform: rotate(45deg); }
.srl-faq-item p { margin: 0; padding: 0 var(--space-lg) var(--space-md); color: var(--ink-soft); line-height: 1.55; }

/* ── CTA / foot ───────────────────────────────────────────────────────── */
.srl-cta { text-align: center; margin: var(--space-2xl) 0; }
.srl-cta p { font-family: var(--display); font-weight: 700; font-size: 1.2rem; margin: 0 0 var(--space-sm); }
.srl-cta-btn { display: inline-block; background: var(--gold); color: var(--paper); font-weight: 700; text-decoration: none; padding: var(--space-sm) var(--space-xl); border-radius: 999px; }
.srl-cta-btn:hover { background: var(--gold-deep); }
.srl-foot { font-size: 0.82rem; color: var(--muted); text-align: center; margin-top: var(--space-2xl); padding-top: var(--space-md); border-top: 1px solid var(--hair); }

@media (max-width: 560px) {
  .srl-waits { flex-direction: column; }
}
@media (prefers-reduced-motion: reduce) {
  .srl-lane, .srl-pulse { animation: none; }
}
