/* =====================================================================
   KILLER GRUPPE v2 — „Der Hof", Light edition
   Warm paper base · green + dark as earned accents · bigger logos
   ===================================================================== */

/* ---------------------------------------------------------------- tokens */
:root{
  /* brand */
  --green:        #a3c300;   /* fills, lines, station nodes — always dark text on it */
  --green-deep:   #6f8600;   /* green-as-TEXT on paper (passes AA) */

  /* warm paper base (the new world) */
  --paper:        #f6f4ee;   /* page background, ~90% of surface */
  --paper-2:      #efece3;   /* alternating section / card fill */
  --paper-3:      #e9e5d8;   /* warmest sandy panel (form ground) */

  /* warm ink */
  --ink:          #1a1d16;   /* body + headline text on paper */
  --ink-strong:   #11140e;   /* emphasis text + the dark surfaces */
  --mute:         #6b7263;   /* captions, vermerk, labels */
  --hairline:     #dcd9cd;   /* borders, table rules, the Gleis line */

  /* surviving dark (accent only — ops band + footer) */
  --asphalt:      #1c1f17;
  --concrete:     #c9ccc2;   /* light text on the dark band/footer */

  /* reserved operational accent — DARK-BAND ONLY */
  --amber:        #e8a317;

  /* type scale — calmer */
  --fs-hero:    clamp(2.1rem, 4.2vw + .9rem, 3.9rem);
  --fs-h2:      clamp(1.7rem, 2.6vw + .6rem, 2.9rem);
  --fs-figure:  clamp(2.2rem, 4vw, 3.8rem);
  --fs-label:   clamp(.72rem, .22vw + .68rem, .82rem);
  --fs-lead:    clamp(1.08rem, .8vw + .92rem, 1.35rem);
  --fs-body:    clamp(1rem, .35vw + .92rem, 1.13rem);
  --fs-mono:    clamp(.72rem, .25vw + .68rem, .84rem);
  --fs-phone:   clamp(1.7rem, 3.8vw, 2.7rem);

  /* layout */
  --rail: 56px;
  --rail-x: 28px;
  --pad-x: clamp(1.25rem, 4vw, 3.5rem);
  --measure: 64ch;
  --maxw: 1180px;

  --serif: "Newsreader", Georgia, "Times New Roman", serif;
  --cond:  "Saira Condensed", "Arial Narrow", system-ui, sans-serif;
  --mono:  "Space Mono", ui-monospace, "Courier New", monospace;

  --ease: cubic-bezier(.165,.84,.44,1);
}

/* ---------------------------------------------------------------- reset */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif);
  font-size:var(--fs-body);
  line-height:1.6;
  letter-spacing:.01em;
  font-synthesis:none;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  padding-left:var(--rail);
}

img{ max-width:100%; display:block; }
a{ color:inherit; }
strong{ font-weight:500; color:var(--ink-strong); }
em{ font-style:normal; }

::selection{ background:var(--green); color:var(--ink-strong); }

.visually-hidden{
  position:absolute!important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}

.skip-link{
  position:absolute; left:8px; top:-60px; z-index:200;
  background:var(--green); color:var(--ink-strong);
  font-family:var(--mono); font-weight:700; letter-spacing:.04em; text-transform:uppercase;
  padding:.6rem 1rem; text-decoration:none; border-radius:2px;
  transition:top .2s var(--ease);
}
.skip-link:focus{ top:8px; }

a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible{
  outline:2px solid var(--green-deep);
  outline-offset:2px;
}
.sec--ops a:focus-visible, .sec--ops button:focus-visible,
.endstop a:focus-visible{ outline-color:var(--amber); }

/* ---------------------------------------------------------------- gleis spine */
.gleis-line{
  position:fixed; top:0; bottom:0;
  left:calc(var(--rail-x) - 1px); width:2px;
  z-index:1; pointer-events:none;
}
.gleis-line__draw{
  position:absolute; inset:0; background:var(--hairline);
  transform-origin:top center;
}
.js .gleis-line__draw{ transform:scaleY(0); animation:railDraw .8s var(--ease) .15s forwards; }
@keyframes railDraw{ to{ transform:scaleY(1); } }

/* ---------------------------------------------------------------- per-section rail marker */
.rail{
  position:absolute; top:2.4rem; left:calc(-1 * var(--rail-x));
  width:var(--rail); transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:.4rem;
  z-index:3; pointer-events:none;
}
/* full-bleed bands carry the node on themselves */
.sec--ops .rail, .sec--riders .rail, .endstop .rail{ left:var(--rail-x); }
.rail__node{
  width:13px; height:13px; border-radius:50%;
  border:2px solid var(--green); background:var(--paper);
  transition:background-color .35s var(--ease), box-shadow .35s var(--ease);
}
.sec--ops .rail__node, .endstop .rail__node{ background:var(--asphalt); }
.rail.is-active .rail__node{ background:var(--green); box-shadow:0 0 0 4px rgba(163,195,0,.18); }
.rail.is-passed .rail__node{ background:var(--green-deep); border-color:var(--green-deep); }
.rail--amber .rail__node{ border-color:var(--amber); }
.rail--amber.is-active .rail__node{ background:var(--amber); box-shadow:0 0 0 4px rgba(232,163,23,.18); }
.rail__node--terminus{ width:17px; height:17px; background:var(--green); border-color:var(--green); }
.rail__idx{ font-family:var(--mono); font-size:.68rem; color:var(--mute); }
.rail__km{ display:none; } /* fictional km narrative retired */

/* ---------------------------------------------------------------- masthead */
.masthead{
  position:sticky; top:0; z-index:100;
  background:rgba(246,244,238,.9); backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--hairline);
  margin-left:calc(-1 * var(--rail));
}
.masthead__inner{
  max-width:calc(var(--maxw) + var(--rail)); margin:0 auto;
  padding:.7rem var(--pad-x); padding-left:var(--rail);
  display:flex; align-items:center; gap:1rem;
  min-height:78px;
}
.lockup{ display:flex; align-items:center; gap:1rem; text-decoration:none; flex:0 0 auto; }
.lockup__citybus{ height:46px; width:auto; border-radius:3px; display:block; }
.lockup__divider{ width:1px; height:40px; background:var(--hairline); }
.lockup__112{ height:30px; width:auto; display:block; }

.topnav{ margin-left:auto; display:flex; align-items:center; }
.topnav__toggle{
  display:none; align-items:center; gap:.5rem;
  background:none; border:1px solid var(--hairline); border-radius:3px;
  color:var(--ink); padding:.5rem .75rem; cursor:pointer;
  font-family:var(--mono); font-weight:700; text-transform:uppercase; letter-spacing:.08em; font-size:.78rem;
}
.topnav__bars{ display:inline-flex; flex-direction:column; gap:3px; width:18px; }
.topnav__bars span{ height:2px; background:var(--ink); border-radius:2px; }
.topnav__menu{
  list-style:none; display:flex; align-items:center; gap:1rem; margin:0; padding:0;
}
.topnav__menu a{
  font-family:var(--mono); font-weight:400; font-size:var(--fs-label);
  text-transform:uppercase; letter-spacing:.1em; text-decoration:none;
  color:var(--ink); padding:.35rem 0; position:relative;
}
.topnav__menu a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px;
  background:var(--green); transition:right .25s var(--ease);
}
.topnav__menu a:hover::after, .topnav__menu a:focus-visible::after{ right:0; }

.callplate{
  flex:0 0 auto; display:inline-flex; align-items:center; gap:.5rem;
  border:none; border-radius:3px; background:var(--green);
  padding:.6rem .85rem; text-decoration:none; color:var(--ink-strong);
  font-family:var(--mono); font-weight:700; font-size:.82rem; white-space:nowrap;
  transition:background-color .2s var(--ease), transform .2s var(--ease);
}
.callplate__ico{ font-size:.95rem; }
.callplate:hover{ background:#b4d40d; transform:translateY(-1px); }

/* ---------------------------------------------------------------- sections */
main{ display:block; }
.sec{
  position:relative;
  max-width:var(--maxw);
  margin:0 auto;
  padding:clamp(3.5rem,7vw,6rem) var(--pad-x);
}
.sec--zahlen{ padding-block:clamp(2.5rem,4.5vw,3.75rem); }
.sec--succession{ padding-top:clamp(3rem,6vw,5rem); }

/* full-bleed bands */
.sec--ops{
  background:var(--ink-strong); color:var(--concrete);
  max-width:none; margin-left:calc(-1 * var(--rail)); width:100vw;
  padding-inline:0;
}
.sec--ops > *:not(.rail){ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad-x); }

/* alternating warm band */
.sec--riders{ background:var(--paper-2); max-width:none; margin-left:calc(-1 * var(--rail)); width:100vw; }
.sec--riders > *:not(.rail){ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad-x); }

.sec__head{ max-width:var(--measure); margin-bottom:clamp(1.5rem,3vw,2.5rem); }
.label{
  font-family:var(--mono); font-weight:400; font-size:var(--fs-label);
  text-transform:uppercase; letter-spacing:.14em; color:var(--green-deep);
  margin:0 0 .9rem; display:flex; align-items:center; gap:.6rem;
}
.label::before{ content:""; width:20px; height:2px; background:var(--green); display:inline-block; }
.label--amber{ color:var(--amber); }
.label--amber::before{ background:var(--amber); }

.sec__title{
  font-family:var(--cond); font-weight:700;
  font-size:var(--fs-h2); line-height:1.05; letter-spacing:-.01em;
  color:var(--ink-strong); margin:0;
}
.sec__title em{ font-family:var(--serif); font-weight:500; font-style:italic; letter-spacing:0; color:var(--green-deep); }
.sec--ops .sec__title{ color:var(--paper); }
.sec--ops .sec__title em{ color:var(--amber); }
.sec__intro{
  font-size:var(--fs-lead); color:var(--ink); margin:1.1rem 0 0; max-width:var(--measure);
}
.sec--ops .sec__intro{ color:var(--concrete); }

/* kicker */
.kicker{
  font-family:var(--mono); font-size:var(--fs-mono); color:var(--mute);
  text-transform:uppercase; letter-spacing:.1em; margin:0 0 1.1rem;
  display:flex; align-items:center; gap:.55rem;
}
.kicker__tick{ width:9px; height:9px; background:var(--green); display:inline-block; }

/* ---------------------------------------------------------------- HERO (photo-forward) */
.sec--hero{
  position:relative; z-index:2; isolation:isolate;
  max-width:none; margin-left:calc(-1 * var(--rail)); width:100vw;
  padding:0; min-height:min(86vh,760px);
  display:flex; align-items:flex-end;
  overflow:hidden;
}
.hero__photo{ position:absolute; inset:0; z-index:-2; }
.hero__photo img{ width:100%; height:100%; object-fit:cover; object-position:50% 78%; }
.hero__scrim{
  position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(17,20,14,.12) 0%, rgba(17,20,14,0) 32%, rgba(17,20,14,.55) 74%, rgba(17,20,14,.86) 100%);
}
.hero__inner{
  width:100%; max-width:var(--maxw); margin:0 auto;
  padding:0 var(--pad-x) clamp(2.25rem,4vw,3.5rem);
  display:flex; flex-direction:column; gap:1.5rem;
}
.hero__panel{ max-width:36ch; }
.sec--hero .kicker{ color:#e3e7d8; }
.sec--hero .kicker__tick{ background:var(--green); }
.hero__title{
  font-family:var(--cond); font-weight:700; font-size:var(--fs-hero);
  line-height:1.04; letter-spacing:-.015em; color:var(--paper);
  margin:0 0 1rem; text-shadow:0 1px 30px rgba(17,20,14,.4);
}
.hero__title em{ font-family:var(--serif); font-weight:500; font-style:italic; letter-spacing:0; color:var(--green); }
.hero__lead{ font-size:var(--fs-lead); color:#e7e9df; max-width:46ch; margin:0; text-shadow:0 1px 14px rgba(17,20,14,.5); }
.hero__actions{ display:flex; flex-wrap:wrap; gap:.85rem; align-items:center; margin-top:1.4rem; }
.hero__chip{
  position:absolute; top:calc(var(--pad-x) + .5rem); right:var(--pad-x); margin:0;
  font-family:var(--mono); font-size:var(--fs-mono); color:var(--paper);
  background:rgba(17,20,14,.55); padding:.4rem .65rem; letter-spacing:.04em; backdrop-filter:blur(2px);
}

/* buttons */
.btn-green{
  display:inline-flex; align-items:center; gap:.55rem; cursor:pointer;
  background:var(--green); color:var(--ink-strong); border:none; border-radius:3px;
  font-family:var(--mono); font-weight:700; text-transform:uppercase; letter-spacing:.05em; font-size:var(--fs-label);
  padding:.85rem 1.5rem; text-decoration:none;
  transition:transform .2s var(--ease), background-color .2s var(--ease);
}
.btn-green:hover{ background:#b4d40d; transform:translateX(3px); }
.btn-ghost-light{
  display:inline-flex; align-items:center; gap:.5rem; text-decoration:none;
  border:1px solid rgba(246,244,238,.45); border-radius:3px; color:var(--paper);
  font-family:var(--mono); font-weight:700; font-size:.82rem; padding:.8rem 1.2rem;
  transition:background-color .2s var(--ease), border-color .2s var(--ease);
}
.btn-ghost-light:hover{ background:rgba(246,244,238,.12); border-color:var(--paper); }

/* ---------------------------------------------------------------- VERMERK */
.vermerk{
  display:flex; align-items:baseline; gap:.7rem;
  border-top:1px solid var(--hairline); margin:clamp(2rem,4vw,3rem) 0 0; padding-top:.7rem;
}
.vermerk__stamp{ flex:0 0 auto; width:8px; height:8px; background:var(--green); transform:translateY(1px); }
.vermerk__text{ font-family:var(--mono); font-size:var(--fs-mono); color:var(--mute); letter-spacing:.03em; line-height:1.5; }
.sec--ops .vermerk{ border-top-color:var(--hairline); }
.vermerk--amber .vermerk__stamp{ background:var(--amber); }
.vermerk--amber .vermerk__text{ color:var(--amber); }

/* ---------------------------------------------------------------- BRANDS split */
.split{ display:grid; grid-template-columns:1.25fr 1fr; gap:0; border:1px solid var(--hairline); border-radius:6px; overflow:hidden; box-shadow:0 1px 3px rgba(26,29,22,.06); }
.split__panel{ padding:clamp(1.75rem,3vw,2.75rem); }
.split__panel--primary{ background:var(--paper); }
.split__panel--ops{ background:var(--paper-2); border-left:1px solid var(--hairline); }
.split__logo{ height:52px; width:auto; border-radius:3px; margin-bottom:1.2rem; }
.split__logo112{ height:38px; width:auto; margin-bottom:1.2rem; }
.split__role{
  font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  font-size:1.1rem; color:var(--ink-strong); margin:0 0 .6rem;
}
.split__text{ margin:0 0 1.25rem; max-width:42ch; color:var(--ink); }
.chips{ list-style:none; display:flex; flex-wrap:wrap; gap:.45rem; margin:0 0 1.4rem; padding:0; }
.chip{
  position:relative; display:inline-flex; align-items:center;
  background:var(--green); color:var(--ink-strong);
  font-family:var(--mono); font-weight:700; font-size:.72rem; letter-spacing:.02em;
  padding:.3rem .5rem; border-radius:2px;
}
.chip__name{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); }
.status{ font-family:var(--mono); font-size:var(--fs-mono); color:var(--green-deep); margin:0 0 1.4rem; display:flex; align-items:center; gap:.5rem; letter-spacing:.04em; text-transform:uppercase; }
.status__dot{ width:9px; height:9px; border-radius:50%; background:var(--green); }

.textlink{
  font-family:var(--mono); font-weight:700; text-transform:uppercase; letter-spacing:.06em;
  font-size:var(--fs-label); text-decoration:none; color:var(--green-deep);
  display:inline-flex; align-items:center; gap:.4rem;
  border-bottom:2px solid transparent; padding-bottom:1px; transition:border-color .2s var(--ease), gap .2s var(--ease);
}
.textlink:hover, .textlink:focus-visible{ border-color:currentColor; gap:.65rem; }
.textlink--amber{ color:var(--amber); }
.textlink--sm{ font-family:var(--mono); font-weight:400; text-transform:none; letter-spacing:0; font-size:.82rem; }

.bridge{ text-align:center; font-family:var(--serif); font-style:italic; font-size:var(--fs-lead); color:var(--ink); margin:clamp(1.5rem,3vw,2.25rem) 0 0; }
.bridge em{ font-style:italic; color:var(--green-deep); }

/* ---------------------------------------------------------------- FAHRGAST-Leiste */
.leiste{ list-style:none; margin:0 0 clamp(2.5rem,5vw,4rem); padding:0; border:1px solid var(--hairline); border-radius:6px; overflow:hidden; background:var(--paper); }
.leiste li + li .leiste__row{ border-top:1px solid var(--hairline); }
.leiste__row{
  display:flex; align-items:center; gap:clamp(.9rem,2vw,1.6rem);
  min-height:80px; padding:1.1rem clamp(1rem,2.5vw,1.75rem);
  text-decoration:none; color:inherit; position:relative; isolation:isolate;
}
.leiste__row::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:0; background:var(--paper-3); z-index:-1; transition:width .25s var(--ease); }
.leiste__row:hover::before, .leiste__row:focus-visible::before{ width:100%; }
.leiste__chip{
  flex:0 0 auto; width:40px; height:40px; display:grid; place-items:center;
  background:var(--green); color:var(--ink-strong); border-radius:3px;
  font-family:var(--cond); font-weight:800; font-size:1.3rem;
}
.leiste__main{ display:flex; flex-direction:column; gap:.25rem; min-width:0; }
.leiste__label{ font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.03em; font-size:1.22rem; color:var(--ink-strong); }
.leiste__say{ font-size:1rem; color:var(--ink); }
.leiste__vermerk{ font-family:var(--mono); font-size:.68rem; color:var(--mute); letter-spacing:.03em; text-transform:uppercase; margin-top:.15rem; }
.leiste__go{ flex:0 0 auto; margin-left:auto; font-family:var(--cond); font-size:1.5rem; color:var(--green-deep); transition:transform .2s var(--ease); }
.leiste__row:hover .leiste__go{ transform:translateX(4px); }

/* ---------------------------------------------------------------- VER partner banner + line chips */
.verbanner{
  display:flex; align-items:center; gap:clamp(1rem,2.5vw,2rem); flex-wrap:wrap;
  background:var(--paper); border:1px solid var(--hairline); border-radius:6px;
  box-shadow:0 1px 3px rgba(26,29,22,.05);
  padding:clamp(1.1rem,2.2vw,1.5rem) clamp(1.25rem,2.5vw,1.9rem);
  margin:0 0 clamp(1.5rem,3vw,2.25rem);
}
.verbanner__logo{ height:54px; width:auto; flex:0 0 auto; }
.verbanner__text{ display:flex; flex-direction:column; gap:.55rem; min-width:0; }
.verbanner__lead{ margin:0; font-family:var(--serif); font-size:var(--fs-lead); color:var(--ink-strong); line-height:1.35; }
.verbanner__lines{ margin:0; display:flex; align-items:center; flex-wrap:wrap; gap:.5rem; }
.verbanner__lineslabel{ font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--mute); margin-right:.3rem; }
.lc{ display:inline-flex; align-items:center; justify-content:center; min-width:42px; background:var(--green); color:var(--ink-strong); font-family:var(--mono); font-weight:700; font-size:.78rem; padding:.28rem .45rem; border-radius:3px; }
.lc--line{ min-width:0; font-size:1rem; padding:.34rem .7rem; letter-spacing:.02em; }

/* ---------------------------------------------------------------- OPS / Killer_112 (dark band) */
.ops-logo{ display:inline-flex; margin-bottom:1.2rem; }
.ops-logo img{ height:60px; width:auto; }
.ops-banner{ margin:0 0 clamp(2rem,4vw,3rem); }
.ops-banner img{ width:100%; height:clamp(240px,32vw,420px); object-fit:cover; object-position:50% 60%; border-radius:6px; border:1px solid rgba(201,204,194,.18); display:block; }
.ops-banner__cap{ font-family:var(--mono); font-size:var(--fs-mono); color:var(--mute); letter-spacing:.03em; margin:.7rem 0 0; }
.services{ list-style:none; margin:0 0 clamp(2rem,4vw,3rem); padding:0; }
.service{ display:flex; gap:clamp(1rem,2.5vw,2rem); padding:clamp(1.1rem,2vw,1.5rem) 0; border-top:1px solid rgba(201,204,194,.18); }
.service:last-child{ border-bottom:1px solid rgba(201,204,194,.18); }
.service__idx{ flex:0 0 auto; font-family:var(--mono); font-weight:700; color:var(--amber); font-size:.95rem; padding-top:.35rem; min-width:56px; }
.service__body{ display:flex; flex-direction:column; gap:.4rem; }
.service__name{ font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.03em; font-size:clamp(1.3rem,2.5vw,1.85rem); color:var(--paper); line-height:1; }
.service__text{ color:var(--concrete); max-width:52ch; }

.opscall{
  background:rgba(0,0,0,.28); border:1px solid rgba(201,204,194,.18); border-left:3px solid var(--amber);
  border-radius:6px;
  padding:clamp(1.5rem,3vw,2.5rem); display:flex; flex-direction:column; gap:.65rem; align-items:flex-start;
}
.opscall__kicker{ font-family:var(--mono); font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--concrete); margin:0; font-size:var(--fs-label); }
.opscall__num{
  font-family:var(--mono); font-weight:700; font-size:var(--fs-phone);
  color:var(--amber); text-decoration:none; line-height:1; letter-spacing:-.01em;
  font-variant-numeric:tabular-nums;
  border-bottom:3px solid transparent; transition:border-color .2s var(--ease);
}
.opscall__num:hover{ border-color:var(--amber); }
.opscall__sign{ font-family:var(--mono); font-size:var(--fs-mono); color:var(--mute); margin:0; letter-spacing:.03em; }
.btn-amber{
  margin-top:.5rem; display:inline-flex; align-items:center; gap:.55rem;
  background:var(--amber); color:var(--ink-strong); text-decoration:none;
  font-family:var(--mono); font-weight:700; text-transform:uppercase; letter-spacing:.05em; font-size:var(--fs-label);
  padding:.85rem 1.4rem; border-radius:3px; transition:transform .2s var(--ease), background-color .2s var(--ease);
}
.btn-amber:hover{ background:#f3b943; transform:translateX(3px); }

/* ---------------------------------------------------------------- ZAHLEN colophon */
.colophon{
  font-family:var(--serif); font-size:clamp(1.4rem,2.6vw,2.25rem); line-height:1.5;
  color:var(--ink); max-width:26ch; margin:0;
}
.colophon .num{
  font-family:var(--cond); font-weight:800; font-style:normal;
  background:var(--green); color:var(--ink-strong); padding:.02em .28em; border-radius:3px;
  letter-spacing:-.01em; display:inline-block; font-variant-numeric:tabular-nums;
}
.colophon__foot{ font-family:var(--mono); font-size:var(--fs-mono); color:var(--mute); text-transform:uppercase; letter-spacing:.08em; margin:1.4rem 0 0; }

/* ---------------------------------------------------------------- ABOUT / Über uns */
.sec--about .colophon{ margin-bottom:clamp(2rem,4vw,3rem); max-width:32ch; }
.about-grid{ display:grid; grid-template-columns:1.5fr 1fr; gap:clamp(1.5rem,3vw,2.5rem); align-items:stretch; }
.about-photo{ margin:0; }
.about-photo img{ width:100%; height:clamp(280px,30vw,420px); object-fit:cover; object-position:50% 58%; border-radius:6px; display:block; }
.about-photo__cap{ font-family:var(--mono); font-size:var(--fs-mono); color:var(--mute); letter-spacing:.02em; margin:.6rem 0 0; }
.about-jobs{ background:var(--paper-2); border:1px solid var(--hairline); border-left:3px solid var(--green); border-radius:6px; padding:clamp(1.5rem,3vw,2rem); display:flex; flex-direction:column; align-items:flex-start; justify-content:center; gap:.85rem; }
.about-jobs__kicker{ font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.05em; font-size:1.25rem; color:var(--ink-strong); margin:0; }
.about-jobs__text{ margin:0; color:var(--ink); max-width:44ch; }

/* ---------------------------------------------------------------- LED-Zielanzeige (destination blind) */
.blind{
  --blind-led:#b9f12a;
  position:relative;
  margin:clamp(1.5rem,3vw,2.25rem) 0 clamp(2rem,4vw,3rem);
  padding:clamp(8px,1.4vw,13px);
  background:#15180e;
  border:1px solid #000;
  border-radius:10px;
  box-shadow:0 2px 8px rgba(26,29,22,.2);
}
.blind__screen{
  position:relative; overflow:hidden;
  height:clamp(46px,6.5vw,74px);
  background:#090c05;
  border-radius:4px;
  box-shadow:inset 0 0 22px rgba(0,0,0,.9), inset 0 0 2px rgba(185,241,42,.25);
  display:flex; align-items:center;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
}
.blind__track{
  position:relative; z-index:1;
  display:flex; align-items:center; white-space:nowrap;
  font-family:var(--mono); font-weight:700;
  font-size:clamp(1.05rem,2.3vw,1.6rem);
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--blind-led);
  text-shadow:0 0 4px rgba(185,241,42,.9), 0 0 13px rgba(185,241,42,.55);
  will-change:transform;
  animation:blindScroll 26s linear infinite;
}
.blind__seg{ display:inline-flex; align-items:center; padding-right:2.6em; }
.blind__stop{ padding:0 1.3em; }
.blind__stop--sev{ color:#e8a317; text-shadow:0 0 4px rgba(232,163,23,.9), 0 0 13px rgba(232,163,23,.5); }
@keyframes blindScroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
/* round dot-matrix grid over the glowing text */
.blind__screen::after{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background-image:radial-gradient(circle, transparent 0 1.15px, #090c05 1.7px);
  background-size:3px 3px;
}
@media (prefers-reduced-motion:reduce){
  .blind__track{ animation:none; transform:none; }
  .blind__screen{ -webkit-mask-image:linear-gradient(90deg,#000 90%,transparent); mask-image:linear-gradient(90deg,#000 90%,transparent); }
}

/* ---------------------------------------------------------------- SUCCESSION (photo-forward) */
.succ{ display:block; }
.succ__photo{ margin:0 0 1.25rem; }
.succ__photo img{ width:100%; max-height:min(60vh,560px); object-fit:cover; border-radius:6px; }
.succ__names{ display:flex; flex-wrap:wrap; gap:1.25rem 2.5rem; margin:0 0 clamp(1.75rem,3vw,2.5rem); }
.succ__name{ display:flex; flex-direction:column; font-family:var(--mono); }
.succ__name strong{ font-weight:700; color:var(--ink-strong); font-size:.95rem; letter-spacing:.02em; }
.succ__name span{ font-size:.72rem; color:var(--mute); text-transform:uppercase; letter-spacing:.06em; margin-top:.15rem; }
.succ__name::before{ content:""; width:24px; height:2px; background:var(--green); margin-bottom:.5rem; }
.succ__text{ max-width:var(--measure); }
.succ__text p{ margin:0 0 1.1rem; font-size:var(--fs-body); }
.succ__text p:first-child{ font-size:var(--fs-lead); color:var(--ink-strong); }

/* ---------------------------------------------------------------- KONTAKT */
.kontakt{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.75rem,4vw,3.5rem); align-items:start; }
.kontakt__num{
  display:inline-block; font-family:var(--mono); font-weight:700; font-size:var(--fs-phone);
  color:var(--green-deep); text-decoration:none; line-height:1; margin:0 0 1.5rem;
  font-variant-numeric:tabular-nums; border-bottom:3px solid transparent; transition:border-color .2s var(--ease);
}
.kontakt__num:hover{ border-color:var(--green-deep); }
.kontakt__dl{ margin:0 0 2rem; display:grid; gap:.9rem; }
.kontakt__dl > div{ display:grid; grid-template-columns:9rem 1fr; gap:1rem; border-top:1px solid var(--hairline); padding-top:.7rem; }
.kontakt__dl dt{ font-family:var(--mono); font-weight:700; text-transform:uppercase; letter-spacing:.06em; font-size:.74rem; color:var(--mute); margin:0; }
.kontakt__dl dd{ margin:0; color:var(--ink); }

.netz{ margin:0; }
.netz__svg{ width:100%; max-width:340px; height:auto; color:var(--green-deep); display:block; }
.netz__path{ stroke-dasharray:1; stroke-dashoffset:0; }
.js .netz__path{ stroke-dasharray:600; stroke-dashoffset:600; }
.js .netz.is-drawn .netz__path{ stroke-dashoffset:0; transition:stroke-dashoffset 1.1s var(--ease); }
.netz__stops circle{ fill:var(--green-deep); }
.netz__labels{ display:flex; justify-content:space-between; gap:.25rem; margin-top:.5rem; max-width:340px; }
.netz__labels span{ font-family:var(--mono); font-size:.6rem; color:var(--mute); text-transform:uppercase; letter-spacing:.02em; }

/* contact slip / form */
.slip{ background:var(--paper-3); border:1px solid var(--hairline); border-radius:6px; padding:clamp(1.5rem,3vw,2rem); }
.slip__head{ font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-strong); margin:0 0 1.25rem; padding-bottom:.75rem; border-bottom:1px solid var(--hairline); font-size:1.1rem; }
.field{ margin-bottom:1rem; }
.field label{ display:block; font-family:var(--mono); font-weight:400; text-transform:uppercase; letter-spacing:.08em; font-size:.72rem; color:var(--mute); margin-bottom:.4rem; }
.field input, .field select, .field textarea{
  width:100%; background:#fffdf8; border:1px solid var(--hairline); border-radius:3px;
  color:var(--ink); font-family:var(--serif); font-size:1rem; padding:.7rem .8rem;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--green-deep); }
.field textarea{ resize:vertical; }
.slip .btn-green{ width:auto; }
.slip__note{ font-family:var(--mono); font-size:.72rem; color:var(--mute); margin:.9rem 0 0; }
.field__opt{ font-family:var(--serif); font-weight:400; text-transform:none; letter-spacing:0; font-size:.85em; color:var(--mute); }

/* ---------------------------------------------------------------- contact form (cases) */
.cform{ /* container */ }
.cform__heading{ font-family:var(--cond); font-weight:700; font-size:clamp(1.8rem,2.6vw+.7rem,2.6rem); line-height:1.03; letter-spacing:-.01em; color:var(--green-deep); margin:0 0 .85rem; }
.cform__prompt{ font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-strong); font-size:1.1rem; margin:0 0 1rem; }
.cform__choices{ display:flex; flex-wrap:wrap; gap:.65rem; }
.cform__choice{
  cursor:pointer; font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.03em; font-size:.95rem;
  background:var(--paper); color:var(--ink-strong); border:1px solid var(--hairline); border-radius:4px;
  padding:.8rem 1.25rem; transition:border-color .2s var(--ease), background-color .2s var(--ease), color .2s var(--ease);
}
.cform__choice:hover{ border-color:var(--green-deep); }
.cform__choice.is-active{ background:var(--green); border-color:var(--green); color:var(--ink-strong); }

.cform__form{
  background:var(--paper-3); border:1px solid var(--hairline); border-radius:6px;
  padding:clamp(1.5rem,3vw,2rem); margin-top:1.25rem;
}
.cform__formhead{ display:flex; align-items:baseline; justify-content:space-between; gap:1rem; margin-bottom:1.25rem; padding-bottom:.75rem; border-bottom:1px solid var(--hairline); }
.cform__title{ font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-strong); font-size:1.15rem; margin:0; }
.cform__back{ cursor:pointer; background:none; border:none; padding:0; font-family:var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.06em; color:var(--mute); transition:color .2s var(--ease); }
.cform__back:hover{ color:var(--green-deep); }

.cform__grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(150px, 1fr)); gap:.85rem 1rem; margin-bottom:1rem; }
.cform__grid .field{ margin-bottom:0; }

.cform__fieldset{ border:none; padding:0; margin:0 0 1.1rem; }
.cform__fieldset legend{ padding:0; font-family:var(--serif); font-size:1rem; color:var(--ink-strong); margin-bottom:.55rem; }
.cform__radio{ display:inline-flex; align-items:center; gap:.45rem; margin-right:1.5rem; font-family:var(--serif); color:var(--ink); cursor:pointer; }
.cform__radio input{ accent-color:var(--green-deep); width:1.05em; height:1.05em; }

.cform__trip{ margin:0 0 1rem; }
.cform__triphint{ font-family:var(--mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; color:var(--mute); margin:0 0 .6rem; }

.cform__hint{ font-family:var(--serif); font-size:.98rem; color:var(--ink); background:var(--paper); border-left:3px solid var(--green); border-radius:0 4px 4px 0; padding:.8rem 1rem; margin:0 0 1.25rem; }
.cform__hintlink{ color:var(--green-deep); text-decoration:underline; text-underline-offset:2px; }
.cform__note{ font-family:var(--serif); font-size:.98rem; line-height:1.55; color:var(--ink); background:var(--paper); border-left:3px solid var(--green); border-radius:0 4px 4px 0; padding:.85rem 1.1rem; margin:0 0 1.25rem; }

/* file upload (Lebenslauf) */
.field input[type="file"]{ padding:.55rem .7rem; font-family:var(--mono); font-size:.82rem; cursor:pointer; color:var(--ink); }
.field input[type="file"]::file-selector-button{
  font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:.75rem;
  background:var(--green); color:var(--ink-strong); border:none; border-radius:3px; padding:.5rem .9rem; margin-right:.85rem; cursor:pointer;
  transition:background-color .2s var(--ease);
}
.field input[type="file"]::file-selector-button:hover{ background:#b4d40d; }

/* honeypot — visually hidden, off-screen, not focusable */
.cform__hp{ position:absolute !important; left:-9999px !important; width:1px; height:1px; opacity:0; pointer-events:none; }

/* submit feedback */
.cform__error{ font-family:var(--mono); font-size:.8rem; line-height:1.5; color:#b23b2e; margin:.9rem 0 0; }
.cform__success{ background:var(--paper-3); border:1px solid var(--hairline); border-left:3px solid var(--green); border-radius:6px; padding:clamp(1.5rem,3vw,2rem); }
.cform__success-title{ font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--green-deep); font-size:1.35rem; margin:0 0 .5rem; }
.cform__success p{ margin:0 0 .4rem; color:var(--ink); }
.cform__dev{ font-family:var(--mono); font-size:.74rem; color:var(--mute); margin-top:.8rem; }
.cform__dev a{ color:var(--green-deep); }

/* ---------------------------------------------------------------- legal (Impressum/Datenschutz) */
.sec--legal{ padding-top:clamp(2.5rem,5vw,4rem); }
.legal{ max-width:72ch; display:flex; flex-direction:column; gap:clamp(1.75rem,3.5vw,2.75rem); }
.legal__block{ }
.legal__co{ font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.03em; font-size:1.35rem; color:var(--ink-strong); margin:0 0 .85rem; padding-bottom:.55rem; border-bottom:1px solid var(--hairline); }
.legal__block h3{ font-family:var(--cond); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:1rem; color:var(--ink-strong); margin:1.3rem 0 .4rem; }
.legal__block p{ margin:0 0 .7rem; color:var(--ink); }
.legal__addr{ font-size:var(--fs-lead); color:var(--ink-strong); }
.legal__sub{ font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:var(--mute); margin:1.1rem 0 .35rem; }
.legal__dl{ margin:.4rem 0 1rem; display:grid; gap:.5rem; }
.legal__dl > div{ display:grid; grid-template-columns:12rem 1fr; gap:1rem; border-top:1px solid var(--hairline); padding-top:.55rem; }
.legal__dl dt{ font-family:var(--mono); font-weight:700; text-transform:uppercase; letter-spacing:.05em; font-size:.72rem; color:var(--mute); margin:0; }
.legal__dl dd{ margin:0; color:var(--ink); }
@media (max-width:560px){ .legal__dl > div{ grid-template-columns:1fr; gap:.15rem; } }

/* ---------------------------------------------------------------- FOOTER / Endhaltestelle */
.endstop{
  position:relative; background:var(--ink-strong); color:var(--concrete);
  border-top:1px solid var(--hairline);
  margin-left:calc(-1 * var(--rail)); width:100vw;
  margin-top:clamp(2rem,4vw,3rem);
}
.endstop .rail__node{ background:var(--asphalt); }
.endstop__inner{ max-width:var(--maxw); margin:0 auto; padding:clamp(3rem,5vw,4.5rem) var(--pad-x); padding-left:max(var(--pad-x), var(--rail)); }
.endstop__here{ font-family:var(--mono); font-size:var(--fs-mono); color:var(--mute); text-transform:uppercase; letter-spacing:.1em; margin:0 0 1.5rem; }
.endstop__lockup{ display:flex; align-items:center; gap:1.1rem; margin-bottom:2.5rem; }
.endstop__lockup .lockup__citybus{ height:52px; border-radius:3px; }
.lockup__plate{ display:inline-flex; align-items:center; justify-content:center; background:var(--paper); border-radius:3px; padding:6px 9px; }
.endstop__lockup .lockup__112{ height:34px; }
.endstop__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; padding-bottom:2.5rem; border-bottom:1px solid rgba(201,204,194,.18); }
.endstop__h{ font-family:var(--mono); font-weight:700; text-transform:uppercase; letter-spacing:.1em; font-size:.78rem; color:var(--green); margin:0 0 1rem; }
.endstop__col a, .endstop__col span{ display:block; text-decoration:none; color:var(--concrete); font-size:.95rem; padding:.32rem 0; }
.endstop__col a{ transition:color .2s var(--ease); }
.endstop__col a:hover{ color:var(--green); }
.endstop__base{ display:flex; flex-wrap:wrap; gap:1rem 2rem; justify-content:space-between; align-items:center; padding-top:1.75rem; }
.endstop__note{ font-family:var(--mono); font-size:.74rem; color:var(--mute); margin:0; max-width:60ch; line-height:1.6; }
.endstop__note a{ color:var(--green); }
.endstop__legal{ display:flex; gap:1.25rem; align-items:center; }
.endstop__legal a, .endstop__legal span{ font-family:var(--mono); font-size:.74rem; color:var(--mute); text-decoration:none; }
.endstop__legal a:hover{ color:var(--green); }

/* ---------------------------------------------------------------- reveal */
.js [data-reveal]{ opacity:0; transform:translateY(12px); }
.js [data-reveal].is-in{ opacity:1; transform:none; transition:opacity .6s var(--ease), transform .6s var(--ease); }

/* ================================================================ RESPONSIVE */
@media (max-width:1199px){
  .topnav{ margin-left:auto; }
  .topnav__menu{
    position:absolute; top:100%; right:var(--pad-x); left:auto; min-width:230px;
    flex-direction:column; align-items:stretch; gap:0;
    background:var(--paper); border:1px solid var(--hairline); border-radius:6px;
    padding:.5rem; margin-top:.5rem;
    display:none; box-shadow:0 14px 34px rgba(26,29,22,.14);
  }
  .topnav__menu.is-open{ display:flex; }
  .topnav__menu li{ border-bottom:1px solid var(--hairline); }
  .topnav__menu li:last-child{ border-bottom:none; }
  .topnav__menu a{ display:block; padding:.85rem .6rem; }
  .topnav__menu a::after{ display:none; }
  .topnav__toggle{ display:inline-flex; }
}

@media (max-width:1023px){
  :root{ --rail:48px; --rail-x:24px; }
  .split{ grid-template-columns:1fr; }
  .split__panel--ops{ border-left:none; border-top:1px solid var(--hairline); }
  .about-grid{ grid-template-columns:1fr; }
  .kontakt{ grid-template-columns:1fr; }
  .endstop__cols{ grid-template-columns:1fr 1fr; }
}

@media (max-width:639px){
  .callplate__num{ display:none; }
  .callplate{ padding:.55rem .7rem; }
  .callplate__ico{ font-size:1.1rem; }

  /* rail collapses entirely — node becomes an inline badge at each heading */
  :root{ --rail:0px; --rail-x:0px; }
  body{ padding-left:0; }
  .gleis-line{ display:none; }
  .masthead{ margin-left:0; }
  .masthead__inner{ padding-left:var(--pad-x); }
  .sec--ops, .sec--riders, .endstop{ margin-left:0; width:auto; }
  .sec--hero{ margin-left:0; width:auto; }
  .endstop__inner{ padding-left:var(--pad-x); }

  .rail{
    position:static; transform:none; width:auto; left:auto; top:auto;
    flex-direction:row; align-items:center; gap:.5rem;
    margin-bottom:1rem;
  }
  .sec--ops .rail, .sec--riders .rail, .endstop .rail{ left:auto; }
  .rail__idx{ order:-1; }
  .rail__idx::before{ content:"■ "; color:var(--green-deep); }
  .sec--ops .rail__idx::before{ color:var(--amber); }
  .sec--ops .rail__idx, .endstop .rail__idx{ color:var(--concrete); }

  .lockup__citybus{ height:34px; }
  .lockup__divider{ height:30px; }
  .lockup__112{ height:24px; }
  .lockup{ gap:.65rem; }
  .masthead__inner{ gap:.6rem; padding-right:1rem; min-height:66px; }
  .topnav__toggle-label{ display:none; }
  .topnav__toggle{ padding:.5rem .6rem; }

  .sec--hero{ min-height:min(80vh,620px); }
  .hero__panel{ max-width:none; }
  .hero__chip{ display:none; }
  .leiste__row{ flex-wrap:wrap; }
  .leiste__go{ display:none; }
  .kontakt__dl > div{ grid-template-columns:1fr; gap:.2rem; }
  .endstop__cols{ grid-template-columns:1fr; gap:1.5rem; }
  .succ__names{ gap:1rem 1.5rem; }
  .verbanner{ gap:.85rem; }
  .verbanner__logo{ height:46px; }
}

/* narrow phones: keep the bigger logos, drop the duplicate call-pill
   (phone stays reachable in the hero CTA, the menu, and the footer) */
@media (max-width:479px){
  .callplate{ display:none; }
  .lockup__citybus{ height:32px; }
  .lockup__112{ height:23px; }
}

/* ================================================================ reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  .js .gleis-line__draw{ transform:scaleY(1); animation:none; }
  .js [data-reveal]{ opacity:1; transform:none; }
  .js .netz__path{ stroke-dashoffset:0; }
  .rail__node{ transition:none; }
}

/* no-js fallback */
.no-js [data-reveal]{ opacity:1; transform:none; }
