/* ==========================================================================
   LINGEN MEDIA & STUDIO-VERLEIH · Lingen (Ems)
   Build-spezifisches Stylesheet — eigenwillige, einmalige Klassenbenennung
   ========================================================================== */

:root {
  --slate-deep:    #111317;
  --slate-void:    #0b0d10;
  --slate-bed:     #1a1d24;
  --slate-bed-up:  #22262f;
  --rim-bold:      #2d3748;
  --rim-quiet:     #212833;
  --rim-ghost:     #1d242e;
  --letter-bright: #f8f9fa;
  --letter-soft:   #98a2b0;
  --letter-dim:    #69727f;
  --volt:          #2b6cb0;
  --volt-up:       #4a90d9;
  --volt-fog:      rgba(43, 108, 176, 0.14);
  --diode-green:   #38a169;
  --diode-amber:   #d69e2e;
  --diode-red:     #c0524f;

  --type-grotesk: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --type-relay:   ui-monospace, "SF Mono", "Cascadia Mono", "Roboto Mono", Menlo, Consolas, monospace;

  --inset-xs: 0.55rem;
  --inset-sm: 0.9rem;
  --inset-md: 1.5rem;
  --inset-lg: 2.6rem;
  --inset-xl: 4.5rem;

  --arc: 6px;
  --arc-wide: 11px;
  --span-clamp: 1250px;
  --ridge-height: 78px;
  --drift: cubic-bezier(0.2, 0.62, 0.34, 1);
}

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

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--ridge-height) + 1rem);
  -webkit-text-size-adjust: 100%;
}

body {
  background: var(--slate-deep);
  color: var(--letter-bright);
  font-family: var(--type-grotesk);
  font-size: 1rem;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; height: auto; }
a { color: var(--volt-up); text-decoration: none; transition: color 0.16s var(--drift); }
a:hover { color: var(--letter-bright); }
h1, h2, h3, h4 { line-height: 1.13; font-weight: 660; letter-spacing: -0.02em; }
p { color: var(--letter-soft); }
strong { color: var(--letter-bright); font-weight: 600; }
::selection { background: var(--volt); color: #fff; }
:focus-visible { outline: 2px solid var(--volt-up); outline-offset: 3px; }

/* ----------  Breitenklammer & Sektionstakt  ---------- */
.span-cradle {
  width: 100%;
  max-width: var(--span-clamp);
  margin-inline: auto;
  padding-inline: clamp(1.1rem, 4vw, 2.6rem);
}
.deck-rhythm { padding-block: var(--inset-xl); }

/* ----------  Kennsatz  ---------- */
.reel-chit {
  font-family: var(--type-relay);
  font-size: 0.73rem;
  letter-spacing: 0.27em;
  text-transform: uppercase;
  color: var(--volt-up);
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
}
.reel-chit::before { content: ""; width: 30px; height: 1px; background: var(--volt); }

.prologue-knot { max-width: 60ch; margin-bottom: var(--inset-lg); }
.prologue-knot h2 { margin-block: 0.85rem 0.6rem; font-size: clamp(1.7rem, 1.3rem + 1.7vw, 2.5rem); }
.prologue-knot p { font-size: clamp(1.04rem, 0.95rem + 0.45vw, 1.2rem); }

/* ----------  Kopf-Laufband  ---------- */
.crawl-shelf {
  background: var(--slate-void);
  border-bottom: 1px solid var(--rim-ghost);
  font-family: var(--type-relay);
  font-size: 0.71rem;
  letter-spacing: 0.12em;
  color: var(--letter-dim);
}
.crawl-shelf .span-cradle {
  display: flex; align-items: center; justify-content: space-between;
  height: 33px; text-transform: uppercase; white-space: nowrap; overflow: hidden;
}
.spark-tie { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--letter-soft); }
.spark-bead {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--diode-green);
  box-shadow: 0 0 0 0 rgba(56, 161, 105, 0.5);
  animation: ember 2.7s infinite;
}
@keyframes ember {
  0%   { box-shadow: 0 0 0 0 rgba(56, 161, 105, 0.45); }
  70%  { box-shadow: 0 0 0 7px rgba(56, 161, 105, 0); }
  100% { box-shadow: 0 0 0 0 rgba(56, 161, 105, 0); }
}
.crawl-distal { display: none; }

/* ----------  Navigationsgrat  ---------- */
.ridge-bar {
  position: sticky; top: 0; z-index: 70;
  background: rgba(17, 19, 23, 0.88);
  backdrop-filter: saturate(140%) blur(13px);
  -webkit-backdrop-filter: saturate(140%) blur(13px);
  border-bottom: 1px solid var(--rim-ghost);
}
.ridge-bar .span-cradle {
  display: flex; align-items: center; justify-content: space-between;
  height: var(--ridge-height); gap: 1rem;
}
.crest-tie {
  display: inline-flex; align-items: center; gap: 0.7rem;
  color: var(--letter-bright); font-weight: 700;
}
.crest-tie:hover { color: var(--letter-bright); }
.crest-pip { color: var(--volt-up); font-size: 1.2rem; transform: translateY(-1px); }
.crest-column { display: flex; flex-direction: column; line-height: 1; letter-spacing: 0.12em; font-size: 1rem; }
.crest-subline {
  font-family: var(--type-relay); font-size: 0.55rem; letter-spacing: 0.2em;
  color: var(--letter-dim); margin-top: 4px; font-weight: 500;
}

.hatch-toggle { display: none; }
.hatch-lever {
  display: inline-flex; flex-direction: column; justify-content: center; gap: 5px;
  width: 44px; height: 44px; padding: 0 10px; cursor: pointer;
  border: 1px solid var(--rim-bold); border-radius: var(--arc);
}
.hatch-lever span {
  display: block; height: 1.5px; background: var(--letter-bright);
  transition: transform 0.3s var(--drift), opacity 0.16s var(--drift);
}

.beacon-fan {
  position: fixed; inset: var(--ridge-height) 0 auto 0;
  background: var(--slate-void); border-bottom: 1px solid var(--rim-bold);
  display: flex; flex-direction: column;
  padding: var(--inset-sm) clamp(1.1rem, 4vw, 2.6rem) var(--inset-md);
  gap: 0.2rem;
  max-height: 0; overflow: hidden; visibility: hidden; opacity: 0;
  transition: max-height 0.3s var(--drift), opacity 0.3s var(--drift), visibility 0.3s var(--drift);
}
.beacon-fan a {
  color: var(--letter-soft); font-size: 0.95rem; padding: 0.75rem 0;
  border-bottom: 1px solid var(--rim-ghost);
}
.beacon-fan a:hover { color: var(--letter-bright); }
.beacon-flare {
  margin-top: 0.6rem; border: 1px solid var(--volt) !important;
  border-radius: var(--arc); text-align: center;
  color: var(--letter-bright) !important; background: var(--volt-fog);
  text-transform: uppercase; font-size: 0.77rem !important;
  font-family: var(--type-relay); letter-spacing: 0.1em;
}
.hatch-toggle:checked ~ .beacon-fan { max-height: 80vh; visibility: visible; opacity: 1; }
.hatch-toggle:checked ~ .hatch-lever span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.hatch-toggle:checked ~ .hatch-lever span:nth-child(2) { opacity: 0; }
.hatch-toggle:checked ~ .hatch-lever span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ----------  Tastflächen  ---------- */
.tap-slug {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem;
  padding: 0.85rem 1.65rem; font-family: var(--type-relay); font-size: 0.8rem;
  letter-spacing: 0.12em; text-transform: uppercase; font-weight: 500;
  border-radius: var(--arc); border: 1px solid transparent; cursor: pointer;
  transition: background 0.16s var(--drift), border-color 0.16s var(--drift), transform 0.16s var(--drift), color 0.16s var(--drift);
}
.tap-slug:hover { transform: translateY(-2px); }
.tap-slug-charged { background: var(--volt); color: #fff; }
.tap-slug-charged:hover { background: var(--volt-up); color: #fff; }
.tap-slug-bare { border-color: var(--rim-bold); color: var(--letter-bright); }
.tap-slug-bare:hover { border-color: var(--volt-up); color: var(--letter-bright); }
.slug-cluster { display: flex; flex-wrap: wrap; gap: var(--inset-sm); margin-top: var(--inset-md); }

/* ----------  Schaufront / Hero  ---------- */
.marquee-stage {
  position: relative; border-bottom: 1px solid var(--rim-ghost); overflow: hidden;
}
.marquee-pane { position: absolute; inset: 0; z-index: 0; }
.marquee-pane img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(0.16) contrast(1.06) brightness(0.5);
}
.marquee-pane::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(17,19,23,0.5) 0%, rgba(17,19,23,0.8) 60%, var(--slate-deep) 100%),
    linear-gradient(90deg, rgba(17,19,23,0.92) 0%, rgba(17,19,23,0.22) 74%);
}
.marquee-copy {
  position: relative; z-index: 1;
  padding-block: clamp(4.5rem, 13vw, 9.5rem); max-width: 68ch;
}
.marquee-copy h1 { font-size: clamp(2.2rem, 1.4rem + 3.4vw, 3.9rem); margin-block: var(--inset-md); }
.marquee-lede { font-size: clamp(1.05rem, 0.95rem + 0.5vw, 1.24rem); color: var(--letter-soft); max-width: 56ch; }
.gauge-band {
  display: flex; flex-wrap: wrap; gap: 1.4rem 2.6rem;
  margin-top: var(--inset-lg); padding-top: var(--inset-md);
  border-top: 1px solid var(--rim-bold);
  font-family: var(--type-relay); font-size: 0.78rem; letter-spacing: 0.07em;
}
.gauge-band div { color: var(--letter-dim); }
.gauge-band strong { display: block; color: var(--letter-bright); font-size: 1.05rem; margin-bottom: 2px; }

/* ----------  Werte / Inklusion  ---------- */
.ethos-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--inset-md);
}
.ethos-tile {
  background: var(--slate-bed); border: 1px solid var(--rim-bold);
  border-radius: var(--arc-wide); padding: var(--inset-lg);
  position: relative;
  transition: border-color 0.3s var(--drift), transform 0.3s var(--drift);
}
.ethos-tile::before {
  content: ""; position: absolute; top: -1px; left: -1px;
  width: 40px; height: 2px; background: var(--volt); opacity: 0;
  transition: opacity 0.3s var(--drift);
}
.ethos-tile:hover { border-color: var(--volt); transform: translateY(-3px); }
.ethos-tile:hover::before { opacity: 1; }
.ethos-mark {
  font-family: var(--type-relay); font-size: 0.72rem; letter-spacing: 0.2em;
  color: var(--volt-up);
}
.ethos-tile h3 { font-size: clamp(1.2rem, 1.05rem + 0.5vw, 1.4rem); margin-block: 0.75rem 0.6rem; }
.ethos-tile p { font-size: 0.9rem; }

/* ----------  Merkmal-Tafeln (drei, je eigenes Layout)  ---------- */
.plank-run {
  display: grid; grid-template-columns: 1fr; gap: var(--inset-lg);
  align-items: center; padding-block: var(--inset-xl);
  border-top: 1px solid var(--rim-ghost);
}
.plank-numeral {
  font-family: var(--type-relay);
  font-size: clamp(3rem, 2rem + 6vw, 6.6rem); font-weight: 600; line-height: 0.8;
  color: transparent; -webkit-text-stroke: 1px var(--rim-bold); letter-spacing: -0.04em;
}
.plank-overline {
  font-family: var(--type-relay); font-size: 0.72rem; letter-spacing: 0.23em;
  text-transform: uppercase; color: var(--volt-up); margin-bottom: 0.6rem; display: block;
}
.plank-run h3 { font-size: clamp(1.6rem, 1.3rem + 1.5vw, 2.3rem); margin-bottom: 0.9rem; }
.plank-text p { margin-bottom: var(--inset-md); max-width: 58ch; }
.gear-tally { list-style: none; display: grid; gap: 0.65rem; margin-top: var(--inset-md); }
.gear-tally li {
  display: grid; grid-template-columns: auto 1fr; gap: 0.85rem; align-items: baseline;
  padding-bottom: 0.65rem; border-bottom: 1px solid var(--rim-ghost);
  font-size: 0.87rem; color: var(--letter-soft);
}
.gear-tally li::before { content: "▸"; color: var(--volt-up); font-weight: 700; }
.gear-tally li strong { color: var(--letter-bright); }

.plank-pane {
  position: relative; border: 1px solid var(--rim-bold);
  border-radius: var(--arc-wide); overflow: hidden; background: var(--slate-bed);
}
.plank-pane img {
  width: 100%; aspect-ratio: 16 / 9; object-fit: cover;
  filter: grayscale(0.1) contrast(1.05) brightness(0.88);
  transition: filter 0.3s var(--drift), transform 0.3s var(--drift);
}
.plank-pane:hover img { filter: grayscale(0) brightness(1); transform: scale(1.02); }
.pane-flap {
  position: absolute; left: 0; bottom: 0;
  background: rgba(11,13,16,0.86); border-top: 1px solid var(--rim-bold);
  border-right: 1px solid var(--rim-bold); padding: 0.55rem 1rem;
  font-family: var(--type-relay); font-size: 0.67rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--letter-soft);
}

/* ----------  Preis-Staffel  ---------- */
.scale-row {
  display: grid; gap: var(--inset-md); grid-template-columns: 1fr; align-items: start;
}
.scale-plate {
  background: var(--slate-bed); border: 1px solid var(--rim-bold);
  border-radius: var(--arc-wide); padding: var(--inset-lg);
  display: flex; flex-direction: column; gap: var(--inset-md);
}
.scale-plate-aura {
  border-color: var(--volt);
  background: linear-gradient(180deg, var(--slate-bed-up), var(--slate-bed));
  position: relative;
}
.scale-plate-aura::after {
  content: "Häufig gebucht"; position: absolute; top: var(--inset-lg); right: var(--inset-lg);
  font-family: var(--type-relay); font-size: 0.6rem; letter-spacing: 0.13em;
  text-transform: uppercase; color: var(--volt-up);
  border: 1px solid var(--volt); border-radius: 999px; padding: 0.25rem 0.7rem;
}
.scale-name {
  font-family: var(--type-relay); font-size: 0.78rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--volt-up);
}
.scale-fee { display: flex; align-items: baseline; gap: 0.4rem; }
.scale-fee .num { font-size: clamp(2.1rem, 1.6rem + 2vw, 2.9rem); font-weight: 660; letter-spacing: -0.03em; }
.scale-fee .unit { font-family: var(--type-relay); font-size: 0.77rem; color: var(--letter-dim); }
.scale-blurb { font-size: 0.87rem; color: var(--letter-soft); }
.scale-tally { list-style: none; display: grid; gap: 0.7rem; margin-top: 0.3rem; }
.scale-tally li {
  display: grid; grid-template-columns: auto 1fr; gap: 0.7rem; font-size: 0.87rem;
  color: var(--letter-soft); padding-bottom: 0.7rem; border-bottom: 1px solid var(--rim-ghost);
}
.scale-tally li::before { content: "✓"; color: var(--diode-green); font-weight: 700; }
.scale-tally li.mute::before { content: "–"; color: var(--letter-dim); }
.scale-plate .tap-slug { margin-top: auto; width: 100%; }

/* ----------  Klappfragen  ---------- */
.probe-pile { display: grid; gap: var(--inset-sm); }
details.probe-leaf {
  background: var(--slate-bed); border: 1px solid var(--rim-bold);
  border-radius: var(--arc-wide); overflow: hidden;
  transition: border-color 0.3s var(--drift);
}
details.probe-leaf[open] { border-color: var(--volt); }
details.probe-leaf summary {
  list-style: none; cursor: pointer; display: flex; align-items: center;
  justify-content: space-between; gap: var(--inset-md);
  padding: var(--inset-md) var(--inset-lg);
  font-size: clamp(1.04rem, 0.95rem + 0.4vw, 1.2rem); font-weight: 600;
  color: var(--letter-bright); user-select: none;
}
details.probe-leaf summary::-webkit-details-marker { display: none; }
.leaf-tick { position: relative; flex: none; width: 22px; height: 22px; }
.leaf-tick::before, .leaf-tick::after {
  content: ""; position: absolute; top: 50%; left: 50%;
  width: 13px; height: 1.5px; background: var(--volt-up);
  transform: translate(-50%, -50%);
  transition: transform 0.3s var(--drift), opacity 0.3s var(--drift);
}
.leaf-tick::after { transform: translate(-50%, -50%) rotate(90deg); }
details.probe-leaf[open] .leaf-tick::after { opacity: 0; transform: translate(-50%, -50%) rotate(0); }
.leaf-spill { padding: 0 var(--inset-lg) var(--inset-md); color: var(--letter-soft); font-size: 0.88rem; }
.leaf-spill p + p { margin-top: 0.75rem; }

@supports (interpolate-size: allow-keywords) {
  :root { interpolate-size: allow-keywords; }
  details.probe-leaf::details-content {
    block-size: 0; overflow: clip; opacity: 0;
    transition: block-size 0.3s var(--drift), opacity 0.3s var(--drift), content-visibility 0.3s allow-discrete;
  }
  details.probe-leaf[open]::details-content { block-size: auto; opacity: 1; }
}

/* ----------  Kontaktkonsole  ---------- */
.relay-hull {
  background: var(--slate-bed); border: 1px solid var(--rim-bold);
  border-radius: var(--arc-wide); padding: clamp(1.5rem, 4vw, 3rem);
}
.relay-weft { display: grid; grid-template-columns: 1fr; gap: var(--inset-md); }
.cell-stack { display: flex; flex-direction: column; gap: 0.45rem; }
.cell-stack-broad { grid-column: 1 / -1; }
.cell-stack label {
  font-family: var(--type-relay); font-size: 0.72rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--letter-soft);
}
.cell-stack label .due { color: var(--volt-up); }
.cell-stack input, .cell-stack select, .cell-stack textarea {
  background: var(--slate-void); border: 1px solid var(--rim-bold);
  border-radius: var(--arc); color: var(--letter-bright);
  font-family: var(--type-grotesk); font-size: 1rem; padding: 0.8rem 0.95rem; width: 100%;
  transition: border-color 0.16s var(--drift), background 0.16s var(--drift);
}
.cell-stack textarea { resize: vertical; min-height: 135px; }
.cell-stack input:focus, .cell-stack select:focus, .cell-stack textarea:focus {
  outline: none; border-color: var(--volt-up); background: var(--slate-bed-up);
}
.cell-stack input::placeholder, .cell-stack textarea::placeholder { color: var(--letter-dim); }

.pledge-bar {
  grid-column: 1 / -1; display: grid; grid-template-columns: auto 1fr; gap: 0.85rem;
  align-items: start; background: var(--slate-void); border: 1px solid var(--rim-ghost);
  border-radius: var(--arc); padding: var(--inset-md);
}
.pledge-bar input[type="checkbox"] {
  appearance: none; -webkit-appearance: none; width: 22px; height: 22px;
  border: 1px solid var(--rim-bold); border-radius: 4px; background: var(--slate-bed);
  cursor: pointer; position: relative; flex: none; margin-top: 2px;
  transition: border-color 0.16s var(--drift), background 0.16s var(--drift);
}
.pledge-bar input[type="checkbox"]:checked { background: var(--volt); border-color: var(--volt); }
.pledge-bar input[type="checkbox"]:checked::after {
  content: ""; position: absolute; left: 7px; top: 3px; width: 6px; height: 11px;
  border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg);
}
.pledge-bar label { font-size: 0.87rem; color: var(--letter-soft); line-height: 1.55; }

/* ----------  Aufruf-Tafel  ---------- */
.summon-plate {
  background: linear-gradient(135deg, var(--slate-bed-up), var(--slate-bed));
  border: 1px solid var(--rim-bold); border-radius: var(--arc-wide);
  padding: clamp(2rem, 5vw, 3.5rem); display: grid; gap: var(--inset-md);
}
.summon-plate h2 { font-size: clamp(1.7rem, 1.3rem + 1.7vw, 2.5rem); }
.summon-plate p { max-width: 58ch; font-size: clamp(1.04rem, 0.95rem + 0.45vw, 1.2rem); }

/* ----------  Rechts-Block (Klartext)  ---------- */
.lexicon-zone { display: grid; gap: var(--inset-lg); }
.lexicon-card {
  background: var(--slate-bed); border: 1px solid var(--rim-ghost);
  border-radius: var(--arc-wide); padding: clamp(1.5rem, 4vw, 2.5rem);
}
.lexicon-card h2 { font-size: clamp(1.2rem, 1.05rem + 0.7vw, 1.5rem); margin-bottom: var(--inset-md); }
.lexicon-card h3 { font-size: 1.05rem; margin-block: var(--inset-md) 0.5rem; color: var(--letter-bright); }
.lexicon-card p, .lexicon-card li { font-size: 0.87rem; color: var(--letter-soft); }
.lexicon-card p + p { margin-top: 0.7rem; }
.lexicon-card ul { margin: 0.6rem 0 0.6rem 1.2rem; display: grid; gap: 0.35rem; }
.registry-grid {
  display: grid; grid-template-columns: 1fr; gap: 0.2rem 1rem;
  font-family: var(--type-relay); font-size: 0.87rem; margin-top: var(--inset-sm);
}
.registry-grid dt { color: var(--letter-dim); letter-spacing: 0.05em; }
.registry-grid dd { color: var(--letter-bright); margin-bottom: 0.6rem; }

/* ----------  Sockel  ---------- */
.base-shelf {
  border-top: 1px solid var(--rim-bold); background: var(--slate-void);
  padding-block: var(--inset-xl) var(--inset-lg); margin-top: var(--inset-xl);
}
.base-weft { display: grid; grid-template-columns: 1fr; gap: var(--inset-lg); }
.base-lead p { font-size: 0.87rem; max-width: 36ch; margin-top: var(--inset-sm); }
.base-col h4 {
  font-family: var(--type-relay); font-size: 0.7rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--letter-dim); margin-bottom: var(--inset-sm);
}
.base-col ul { list-style: none; display: grid; gap: 0.5rem; }
.base-col a { color: var(--letter-soft); font-size: 0.87rem; }
.base-col a:hover { color: var(--letter-bright); }
.base-hem {
  margin-top: var(--inset-lg); padding-top: var(--inset-md);
  border-top: 1px solid var(--rim-ghost); display: flex; flex-wrap: wrap;
  gap: 0.6rem 1.5rem; justify-content: space-between;
  font-family: var(--type-relay); font-size: 0.7rem; letter-spacing: 0.05em; color: var(--letter-dim);
}

/* ----------  Umbruchpunkte  ---------- */
@media (min-width: 600px) {
  .ethos-grid { grid-template-columns: repeat(2, 1fr); }
  .relay-weft { grid-template-columns: 1fr 1fr; }
  .registry-grid { grid-template-columns: 200px 1fr; }
  .registry-grid dt { margin-bottom: 0.6rem; }
}
@media (min-width: 860px) {
  .crawl-distal { display: inline; }
  .ethos-grid { grid-template-columns: repeat(3, 1fr); }
  .scale-row { grid-template-columns: repeat(3, 1fr); }
  .base-weft { grid-template-columns: 1.6fr 1fr 1fr 1fr; }
}
@media (min-width: 980px) {
  :root { --ridge-height: 84px; }
  .hatch-lever { display: none; }
  .beacon-fan {
    position: static; flex-direction: row; align-items: center; gap: 0.35rem;
    max-height: none; visibility: visible; opacity: 1; padding: 0;
    background: none; border: none; overflow: visible;
  }
  .beacon-fan a { border: none; padding: 0.55rem 0.9rem; font-size: 0.85rem; }
  .beacon-flare { margin-top: 0; padding: 0.55rem 1.1rem !important; }

  .plank-run { grid-template-columns: 1.06fr 0.94fr; gap: calc(var(--inset-xl) * 1.25); }
  .plank-run-swap .plank-pane { order: -1; }
  .plank-banner { display: flex; align-items: flex-start; gap: var(--inset-md); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}
