/* =====================================================================
   KARL EHLERS EISENBAU — Schlosserei · Metallbau · Kunstschmiede
   Industrial-Craft Editorial Design System
   ===================================================================== */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;600;700&family=Inter:wght@400;500;600;700&display=swap');

/* ---------- Tokens ---------- */
:root{
  /* dark steel base */
  --ink:#0E1116;
  --steel-900:#14181E;
  --steel-850:#171C23;
  --steel-800:#1B212A;
  --steel-700:#232B36;
  --steel-600:#2E3844;
  --line-dark:rgba(255,255,255,.10);
  --line-dark-2:rgba(255,255,255,.06);

  /* light paper */
  --paper:#F5F2EB;
  --paper-2:#EDE8DD;
  --paper-3:#E4DDCE;

  /* text */
  --t-light:#EEF0F3;
  --t-light-dim:#AEB7C4;
  --t-dark:#171A20;
  --t-dark-dim:#5A6472;

  /* brand */
  --blue:#2743E6;        /* heritage cobalt */
  --blue-deep:#1A2CA6;
  --blue-soft:#5A72F0;
  --ember:#E5622B;       /* forge / action */
  --ember-2:#F1833B;
  --ember-glow:rgba(229,98,43,.35);
  --metal:#C7CDD6;

  --radius:3px;
  --radius-lg:6px;
  --maxw:1240px;
  --gutter:clamp(20px,5vw,64px);
  --ease:cubic-bezier(.22,.61,.36,1);

  --font-display:'Barlow Condensed',system-ui,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--ink);
  color:var(--t-light);
  line-height:1.65;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:2px solid var(--ember);outline-offset:3px;border-radius:2px}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--tight{padding-block:clamp(48px,6vw,80px)}
.bg-paper{background:var(--paper);color:var(--t-dark)}
.bg-paper-2{background:var(--paper-2);color:var(--t-dark)}
.bg-steel{background:var(--steel-900)}
.bg-steel-800{background:var(--steel-800)}

/* ---------- Type ---------- */
.display{
  font-family:var(--font-display);
  font-weight:700;
  line-height:.94;
  letter-spacing:-.01em;
  text-transform:uppercase;
}
h1.display{font-size:clamp(2.9rem,8vw,6.2rem)}
h2.display{font-size:clamp(2.2rem,5.2vw,4.1rem)}
h3.display{font-size:clamp(1.5rem,2.6vw,2.1rem)}

.eyebrow{
  font-family:var(--font-body);
  font-weight:600;
  font-size:.74rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:.7em;
  color:var(--ember);
}
.eyebrow--blue{color:var(--blue-soft)}
.bg-paper .eyebrow{color:var(--ember)}
.bg-paper .eyebrow--blue{color:var(--blue)}
.eyebrow::before{
  content:"";width:34px;height:2px;background:currentColor;display:inline-block;
}
.eyebrow--center::before{display:none}

.lead{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--t-light-dim);max-width:60ch;line-height:1.7}
.bg-paper .lead,.bg-paper-2 .lead{color:var(--t-dark-dim)}
.num-index{font-variant-numeric:tabular-nums;font-weight:600;color:var(--t-light-dim);letter-spacing:.05em}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ember);--fg:#fff;
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-display);text-transform:uppercase;
  font-weight:600;font-size:1.02rem;letter-spacing:.04em;
  padding:.92em 1.7em;background:var(--bg);color:var(--fg);
  border-radius:var(--radius);position:relative;overflow:hidden;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  min-height:48px;
}
.btn svg{width:19px;height:19px;transition:transform .3s var(--ease)}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 26px -8px var(--ember-glow)}
.btn:hover svg{transform:translateX(4px)}
.btn--ghost{--bg:transparent;--fg:var(--t-light);box-shadow:inset 0 0 0 1.5px var(--line-dark)}
.btn--ghost:hover{--bg:rgba(255,255,255,.05);box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.28)}
.bg-paper .btn--ghost{--fg:var(--t-dark);box-shadow:inset 0 0 0 1.5px rgba(0,0,0,.16)}
.bg-paper .btn--ghost:hover{--bg:rgba(0,0,0,.04);box-shadow:inset 0 0 0 1.5px rgba(0,0,0,.34)}
.btn--blue{--bg:var(--blue)}
.btn--blue:hover{box-shadow:0 10px 26px -8px rgba(39,67,230,.4)}
.link-arrow{
  display:inline-flex;align-items:center;gap:.5em;font-weight:600;
  font-size:.92rem;letter-spacing:.02em;color:var(--ember);
  transition:gap .25s var(--ease);
}
.bg-paper .link-arrow{color:var(--blue)}
.link-arrow svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.link-arrow:hover{gap:.85em}
.link-arrow:hover svg{transform:translateX(3px)}

/* =====================================================================
   NAV
   ===================================================================== */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  transition:background .35s var(--ease),box-shadow .35s,backdrop-filter .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.nav.is-solid{
  background:rgba(14,17,22,.82);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line-dark);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;
  height:74px;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.brand{display:flex;align-items:center;gap:.72rem;letter-spacing:-.01em}
.brand__crest{
  width:38px;height:38px;flex:none;border-radius:3px;
  display:grid;place-items:center;
  background:linear-gradient(150deg,var(--blue),var(--blue-deep));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.14);
}
.brand__crest svg{width:21px;height:21px;color:#fff}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--font-display);font-weight:700;font-size:1.28rem;text-transform:uppercase;letter-spacing:.01em}
.brand__sub{font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--t-light-dim);font-weight:600;margin-top:3px}

.nav__links{display:flex;align-items:center;gap:2px}
.nav__links a{
  font-family:var(--font-display);text-transform:uppercase;font-weight:600;
  font-size:1.02rem;letter-spacing:.03em;padding:.55em .9em;border-radius:3px;
  color:var(--t-light-dim);position:relative;transition:color .2s;
}
.nav__links a::after{
  content:"";position:absolute;left:.9em;right:.9em;bottom:.35em;height:2px;
  background:var(--ember);transform:scaleX(0);transform-origin:left;
  transition:transform .28s var(--ease);
}
.nav__links a:hover,.nav__links a.active{color:var(--t-light)}
.nav__links a.active::after,.nav__links a:hover::after{transform:scaleX(1)}
.nav__cta{margin-left:1rem}
.nav__phone{
  display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.95rem;
  color:var(--t-light);padding:.5em .7em;
}
.nav__phone svg{width:17px;height:17px;color:var(--ember)}
.nav__burger{display:none;width:46px;height:46px;flex-direction:column;gap:5px;
  align-items:center;justify-content:center;border-radius:4px}
.nav__burger span{width:24px;height:2px;background:var(--t-light);transition:.3s var(--ease)}
.nav.open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){opacity:0}
.nav.open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.nav__mobile{
  position:fixed;inset:74px 0 0 0;z-index:99;
  background:var(--steel-900);
  transform:translateY(-8px);opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  padding:2rem var(--gutter) 3rem;display:flex;flex-direction:column;gap:.3rem;
  border-top:1px solid var(--line-dark);overflow-y:auto;
}
.nav__mobile.open{opacity:1;transform:none;pointer-events:auto}
.nav__mobile a{
  font-family:var(--font-display);text-transform:uppercase;font-weight:600;
  font-size:1.55rem;padding:.6em 0;border-bottom:1px solid var(--line-dark-2);
  color:var(--t-light-dim);display:flex;justify-content:space-between;align-items:center;
  transition:color .2s,padding-left .2s;
}
.nav__mobile a:hover,.nav__mobile a.active{color:var(--t-light);padding-left:.4em}
.nav__mobile a span{color:var(--ember);font-size:.9rem}
.nav__mobile .btn{margin-top:1.4rem;justify-content:center}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding-top:74px;overflow:hidden;background:var(--ink)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 40%;
  filter:contrast(1.05) saturate(1.02);
  transform:scale(1.08);animation:heroZoom 18s var(--ease) forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(14,17,22,.55) 0%,rgba(14,17,22,.18) 34%,rgba(14,17,22,.72) 78%,var(--ink) 100%),
    linear-gradient(95deg,rgba(14,17,22,.78) 0%,rgba(14,17,22,.30) 55%,rgba(14,17,22,0) 100%);
}
.hero__grid{
  position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line-dark-2) 1px,transparent 1px),
    linear-gradient(90deg,var(--line-dark-2) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(120% 100% at 20% 90%,#000 20%,transparent 75%);
}
.hero__inner{position:relative;z-index:3;width:100%;max-width:var(--maxw);
  margin-inline:auto;padding:0 var(--gutter) clamp(48px,7vw,96px)}
.hero__badge{
  display:inline-flex;align-items:center;gap:.7em;margin-bottom:1.6rem;
  padding:.5em .9em .5em .6em;border-radius:100px;
  background:rgba(255,255,255,.06);border:1px solid var(--line-dark);
  backdrop-filter:blur(6px);font-size:.78rem;font-weight:600;letter-spacing:.06em;
}
.hero__badge b{color:var(--ember)}
.hero__badge .dot{width:7px;height:7px;border-radius:50%;background:var(--ember);
  box-shadow:0 0 0 4px var(--ember-glow)}
.hero h1{max-width:16ch;margin-bottom:1.5rem}
.hero h1 .accent{color:var(--ember);-webkit-text-stroke:0}
.hero h1 .thin{color:var(--t-light-dim)}
.hero__lead{max-width:46ch;font-size:clamp(1.05rem,1.6vw,1.32rem);color:#DDE2E9;margin-bottom:2.2rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero__meta{
  position:relative;z-index:3;border-top:1px solid var(--line-dark);
  margin-top:clamp(40px,6vw,68px);
}
.hero__meta-inner{max-width:var(--maxw);margin-inline:auto;padding:1.4rem var(--gutter);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.hero__stat .n{font-family:var(--font-display);font-weight:700;font-size:clamp(1.9rem,3vw,2.6rem);
  line-height:1;color:var(--t-light)}
.hero__stat .n b{color:var(--ember)}
.hero__stat .l{font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--t-light-dim);margin-top:.4rem}
.hero__scroll{position:absolute;right:var(--gutter);bottom:calc(clamp(48px,7vw,96px) + 78px);
  z-index:3;writing-mode:vertical-rl;font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--t-light-dim);display:flex;align-items:center;gap:1rem}
.hero__scroll::after{content:"";width:1px;height:56px;background:linear-gradient(var(--ember),transparent);
  animation:scrollPulse 2s var(--ease) infinite}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:1}}

/* =====================================================================
   MARQUEE (services strip)
   ===================================================================== */
.marquee{background:var(--ember);color:#fff;overflow:hidden;border-block:1px solid rgba(0,0,0,.12)}
.marquee__track{display:flex;gap:2.5rem;width:max-content;
  animation:marquee 34s linear infinite;padding-block:.85rem}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee span{font-family:var(--font-display);text-transform:uppercase;font-weight:600;
  font-size:1.05rem;letter-spacing:.05em;display:inline-flex;align-items:center;gap:2.5rem;white-space:nowrap}
.marquee span::after{content:"";width:6px;height:6px;background:#fff;border-radius:50%;opacity:.7}
@keyframes marquee{to{transform:translateX(-50%)}}

/* =====================================================================
   INTRO / SPLIT
   ===================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem);align-items:center}
.split--reverse .split__media{order:2}
.split__head{max-width:52ch;margin-bottom:2.2rem}
.split__head h2{margin:1rem 0 1.4rem}
.figure{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--steel-800)}
.figure img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.figure:hover img{transform:scale(1.04)}
.figure--tall{aspect-ratio:4/5}
.figure--wide{aspect-ratio:3/2}
.figure__tag{position:absolute;left:0;bottom:1.1rem;background:var(--ink);color:#fff;
  font-family:var(--font-display);text-transform:uppercase;font-weight:600;letter-spacing:.05em;
  padding:.5em 1em;font-size:.9rem}
.figure__badge{position:absolute;top:1rem;right:1rem;background:#fff;border-radius:50%;
  width:96px;height:96px;padding:8px;box-shadow:0 8px 24px rgba(0,0,0,.25)}
.figure__badge img{width:100%;height:100%;object-fit:contain}

.motto{
  font-family:var(--font-display);text-transform:uppercase;font-weight:600;
  font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.08;letter-spacing:-.01em;
  border-left:3px solid var(--ember);padding-left:1.4rem;margin-block:2rem;
}
.motto b{color:var(--blue)}
.bg-steel .motto b,.bg-steel-800 .motto b{color:var(--blue-soft)}

/* feature list */
.feat-list{display:grid;gap:.2rem;margin-top:1.6rem}
.feat-list li{display:flex;gap:1rem;align-items:flex-start;padding:.9rem 0;border-top:1px solid var(--line-dark)}
.bg-paper .feat-list li,.bg-paper-2 .feat-list li{border-top-color:rgba(0,0,0,.1)}
.feat-list .ico{flex:none;width:30px;height:30px;color:var(--ember);margin-top:2px}
.feat-list h4{font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:1.15rem;letter-spacing:.01em}
.feat-list p{font-size:.95rem;color:var(--t-light-dim);margin-top:.15rem}
.bg-paper .feat-list p,.bg-paper-2 .feat-list p{color:var(--t-dark-dim)}

/* =====================================================================
   SECTION HEADER
   ===================================================================== */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;
  flex-wrap:wrap;margin-bottom:clamp(2.5rem,5vw,4rem)}
.sec-head__text{max-width:60ch}
.sec-head h2{margin:1.1rem 0 0}
.sec-head p{margin-top:1.1rem}

/* =====================================================================
   SERVICE CARDS
   ===================================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.svc-card{
  position:relative;display:flex;flex-direction:column;
  background:var(--steel-850);border:1px solid var(--line-dark);border-radius:var(--radius-lg);
  overflow:hidden;min-height:340px;transition:transform .4s var(--ease),border-color .4s;
  color:var(--t-light);
}
.svc-card:hover{transform:translateY(-6px);border-color:rgba(229,98,43,.5)}
.svc-card__img{aspect-ratio:16/11;overflow:hidden;position:relative}
.svc-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.svc-card:hover .svc-card__img img{transform:scale(1.07)}
.svc-card__img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(20,24,30,.85))}
.svc-card__no{position:absolute;top:1rem;left:1.1rem;z-index:2;font-family:var(--font-display);
  font-weight:700;font-size:1.05rem;color:var(--ember);letter-spacing:.05em}
.svc-card__body{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.svc-card__body h3{font-family:var(--font-display);text-transform:uppercase;font-weight:700;
  font-size:1.4rem;line-height:1;margin-bottom:.7rem}
.svc-card__body p{font-size:.93rem;color:var(--t-light-dim);flex:1}
.svc-card__link{margin-top:1.1rem;display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-display);text-transform:uppercase;font-weight:600;color:var(--ember);
  font-size:.95rem;letter-spacing:.04em}
.svc-card__link svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.svc-card:hover .svc-card__link svg{transform:translateX(4px)}

/* =====================================================================
   DETAILED SERVICE ROWS (Leistungen page)
   ===================================================================== */
.svc-row{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);
  align-items:center;padding-block:clamp(3rem,6vw,5.5rem);border-top:1px solid var(--line-dark)}
.svc-row:first-of-type{border-top:none}
.svc-row--rev .svc-row__media{order:2}
.svc-row__no{font-family:var(--font-display);font-weight:700;font-size:clamp(3rem,6vw,5rem);
  line-height:1;color:transparent;-webkit-text-stroke:1.5px var(--ember);opacity:.9;margin-bottom:1rem}
.svc-row h3{margin-bottom:1.2rem}
.svc-row__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:5/4;background:var(--steel-800)}
.svc-row__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.svc-row:hover .svc-row__media img{transform:scale(1.05)}
.chk{display:grid;gap:.65rem;margin-top:1.4rem}
.chk li{display:flex;gap:.8rem;align-items:flex-start;font-size:.98rem;color:var(--t-light-dim)}
.chk .ico{flex:none;width:22px;height:22px;color:var(--ember);margin-top:2px}
.bg-paper .chk li,.bg-paper-2 .chk li{color:var(--t-dark-dim)}

/* =====================================================================
   GALLERY
   ===================================================================== */
.gal-filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.4rem}
.gal-filters button{
  font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:1rem;
  letter-spacing:.03em;padding:.55em 1.15em;border-radius:100px;
  border:1px solid var(--line-dark);color:var(--t-light-dim);
  transition:all .25s var(--ease);min-height:44px;
}
.bg-paper .gal-filters button{border-color:rgba(0,0,0,.14);color:var(--t-dark-dim)}
.gal-filters button:hover{color:var(--t-light);border-color:rgba(255,255,255,.3)}
.bg-paper .gal-filters button:hover{color:var(--t-dark);border-color:rgba(0,0,0,.4)}
.gal-filters button.active{background:var(--ember);border-color:var(--ember);color:#fff}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;grid-auto-flow:dense}
.gal-item{
  position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;
  aspect-ratio:1;background:var(--steel-800);
  transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.gal-item.tall{grid-row:span 2;aspect-ratio:1/2}
.gal-item.wide{grid-column:span 2;aspect-ratio:2/1}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gal-item:hover img{transform:scale(1.06)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(14,17,22,.8));
  opacity:0;transition:opacity .3s}
.gal-item:hover::after{opacity:1}
.gal-item__cap{position:absolute;left:.9rem;bottom:.8rem;right:.9rem;z-index:2;
  font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:.92rem;
  color:#fff;opacity:0;transform:translateY(8px);transition:all .3s var(--ease);display:flex;align-items:center;gap:.5em}
.gal-item__cap svg{width:16px;height:16px;color:var(--ember)}
.gal-item:hover .gal-item__cap{opacity:1;transform:none}
.gal-item.hide{display:none}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(8,10,14,.94);
  backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s var(--ease);padding:clamp(1rem,4vw,3rem)}
.lb.open{opacity:1;pointer-events:auto}
.lb__img{max-width:min(1100px,92vw);max-height:82vh;border-radius:var(--radius);
  box-shadow:0 30px 80px rgba(0,0,0,.6);transform:scale(.96);transition:transform .35s var(--ease);object-fit:contain}
.lb.open .lb__img{transform:scale(1)}
.lb__cap{position:absolute;bottom:clamp(1rem,3vw,2rem);left:0;right:0;text-align:center;
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;color:var(--t-light-dim);font-size:1rem}
.lb__btn{position:absolute;background:rgba(255,255,255,.08);border:1px solid var(--line-dark);
  width:52px;height:52px;border-radius:50%;display:grid;place-items:center;color:#fff;
  transition:background .2s,transform .2s;backdrop-filter:blur(4px)}
.lb__btn:hover{background:var(--ember);transform:scale(1.05)}
.lb__btn svg{width:22px;height:22px}
.lb__close{top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem)}
.lb__prev{left:clamp(1rem,3vw,2rem);top:50%;transform:translateY(-50%)}
.lb__next{right:clamp(1rem,3vw,2rem);top:50%;transform:translateY(-50%)}
.lb__prev:hover,.lb__next:hover{transform:translateY(-50%) scale(1.05)}

/* =====================================================================
   TIMELINE (Geschichte)
   ===================================================================== */
.timeline{position:relative;max-width:920px;margin-inline:auto}
.timeline::before{content:"";position:absolute;left:0;top:8px;bottom:0;width:2px;
  background:linear-gradient(var(--ember),var(--blue),transparent)}
.tl-item{position:relative;padding:0 0 clamp(2.5rem,4vw,3.5rem) clamp(2.2rem,5vw,3.5rem)}
.tl-item::before{content:"";position:absolute;left:-7px;top:6px;width:16px;height:16px;border-radius:50%;
  background:var(--ember);box-shadow:0 0 0 5px rgba(229,98,43,.18)}
.tl-item__year{font-family:var(--font-display);font-weight:700;font-size:clamp(1.6rem,3vw,2.2rem);
  line-height:1;color:var(--ember);margin-bottom:.5rem}
.tl-item__year.blue{color:var(--blue-soft)}
.tl-item h4{font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:1.25rem;margin-bottom:.5rem}
.tl-item p{color:var(--t-light-dim);max-width:60ch}
.bg-paper .tl-item p{color:var(--t-dark-dim)}

/* =====================================================================
   STATS band
   ===================================================================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-dark);
  border:1px solid var(--line-dark);border-radius:var(--radius-lg);overflow:hidden}
.stats div{background:var(--steel-850);padding:clamp(1.5rem,3vw,2.4rem);text-align:center}
.stats .n{font-family:var(--font-display);font-weight:700;font-size:clamp(2.2rem,4vw,3.2rem);line-height:1;color:var(--t-light)}
.stats .n b{color:var(--ember)}
.stats .l{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--t-light-dim);margin-top:.6rem}

/* =====================================================================
   CTA band
   ===================================================================== */
.cta-band{position:relative;overflow:hidden;background:var(--steel-900);isolation:isolate}
.cta-band__bg{position:absolute;inset:0;z-index:-1;opacity:.22}
.cta-band__bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3)}
.cta-band::after{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(80% 120% at 80% 0%,rgba(229,98,43,.18),transparent 60%)}
.cta-band__inner{display:grid;grid-template-columns:1.3fr 1fr;gap:2.5rem;align-items:center}
.cta-band h2{margin:1rem 0 1.3rem}
.cta-card{background:var(--steel-800);border:1px solid var(--line-dark);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,3vw,2.2rem)}
.cta-card .row{display:flex;align-items:center;gap:1rem;padding:.9rem 0;border-top:1px solid var(--line-dark)}
.cta-card .row:first-child{border-top:none}
.cta-card .ico{flex:none;width:42px;height:42px;border-radius:8px;display:grid;place-items:center;
  background:rgba(229,98,43,.12);color:var(--ember)}
.cta-card .ico svg{width:20px;height:20px}
.cta-card .k{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--t-light-dim)}
.cta-card .v{font-family:var(--font-display);font-weight:600;font-size:1.25rem;text-transform:uppercase}
.cta-card a.v:hover{color:var(--ember)}

/* =====================================================================
   PAGE HERO (interior)
   ===================================================================== */
.phero{position:relative;padding:calc(74px + clamp(60px,10vw,120px)) 0 clamp(48px,7vw,80px);
  overflow:hidden;background:var(--steel-900)}
.phero__bg{position:absolute;inset:0;z-index:0;opacity:.28}
.phero__bg img{width:100%;height:100%;object-fit:cover}
.phero::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,rgba(14,17,22,.6),var(--steel-900)),
  radial-gradient(70% 100% at 85% 10%,rgba(39,67,230,.16),transparent 60%)}
.phero__inner{position:relative;z-index:2}
.phero h1{margin:1.2rem 0 1.2rem;max-width:18ch}
.phero .lead{color:#DDE2E9}
.crumbs{display:flex;gap:.6em;align-items:center;font-size:.82rem;color:var(--t-light-dim);font-weight:500}
.crumbs a:hover{color:var(--ember)}
.crumbs span{opacity:.5}

/* =====================================================================
   CONTACT
   ===================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,3.5rem)}
.info-card{display:flex;gap:1.1rem;align-items:flex-start;padding:1.3rem 0;border-top:1px solid var(--line-dark)}
.info-card:first-child{border-top:none;padding-top:0}
.info-card .ico{flex:none;width:46px;height:46px;border-radius:8px;display:grid;place-items:center;
  background:rgba(39,67,230,.12);color:var(--blue-soft)}
.info-card .ico svg{width:21px;height:21px}
.info-card .k{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--t-light-dim);margin-bottom:.25rem}
.info-card .v{font-size:1.12rem;font-weight:500;line-height:1.5}
.info-card a.v:hover,.info-card .v a:hover{color:var(--ember)}
.form{display:grid;gap:1.1rem}
.form .frow{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--t-light-dim);font-weight:600}
.field label .req{color:var(--ember)}
.field input,.field textarea{
  background:var(--steel-800);border:1px solid var(--line-dark);border-radius:var(--radius);
  padding:.85em 1em;color:var(--t-light);font-family:inherit;font-size:1rem;transition:border-color .2s,background .2s;
  min-height:48px;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ember);background:var(--steel-700)}
.field input::placeholder,.field textarea::placeholder{color:#5c6675}
.form__foot{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between}
.form__note{font-size:.82rem;color:var(--t-light-dim);max-width:34ch}
.form__ok{display:none;padding:1rem 1.2rem;border-radius:var(--radius);background:rgba(39,67,230,.12);
  border:1px solid rgba(90,114,240,.4);color:#cdd6ff;font-size:.95rem}
.form__ok.show{display:block}
.map-wrap{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line-dark);aspect-ratio:16/7;background:var(--steel-800)}
.map-wrap iframe{width:100%;height:100%;border:0;filter:grayscale(.4) contrast(1.05)}

/* checklist inline (legal) */
.prose{max-width:78ch}
.prose h2{font-family:var(--font-display);text-transform:uppercase;font-weight:700;font-size:1.7rem;
  margin:2.4rem 0 1rem}
.prose h3{font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:1.25rem;margin:1.8rem 0 .7rem}
.prose p,.prose li{color:var(--t-light-dim);margin-bottom:.9rem}
.bg-paper .prose p,.bg-paper .prose li{color:var(--t-dark-dim)}
.prose ul{padding-left:1.2rem;list-style:disc}
.prose li{margin-bottom:.4rem}
.prose a{color:var(--ember);text-decoration:underline;text-underline-offset:3px}
.prose strong{color:var(--t-light)}
.bg-paper .prose strong{color:var(--t-dark)}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{background:var(--ink);border-top:1px solid var(--line-dark);padding-top:clamp(3.5rem,6vw,5rem)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:2.5rem;padding-bottom:3rem}
.footer__brand .brand{margin-bottom:1.2rem}
.footer__brand p{color:var(--t-light-dim);font-size:.94rem;max-width:36ch}
.footer__logo{margin-top:1.4rem;background:#fff;border-radius:4px;padding:.7rem 1rem;display:inline-block;max-width:260px}
.footer__logo img{width:100%}
.footer col,.footer__col h5{}
.footer__col h5{font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:1.05rem;
  letter-spacing:.05em;margin-bottom:1.1rem;color:var(--t-light)}
.footer__col a,.footer__col li{display:block;color:var(--t-light-dim);font-size:.94rem;padding:.32rem 0;transition:color .2s,padding-left .2s}
.footer__col a:hover{color:var(--ember);padding-left:.3em}
.footer__contact li{display:flex;gap:.6rem;align-items:flex-start}
.footer__contact svg{width:16px;height:16px;color:var(--ember);flex:none;margin-top:4px}
.footer__bottom{border-top:1px solid var(--line-dark);padding-block:1.6rem;display:flex;
  justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.footer__bottom p{font-size:.85rem;color:var(--t-light-dim)}
.footer__bottom nav{display:flex;gap:1.4rem}
.footer__bottom nav a{font-size:.85rem;color:var(--t-light-dim)}
.footer__bottom nav a:hover{color:var(--ember)}

/* =====================================================================
   REVEAL ANIMATION
   ===================================================================== */
[data-reveal]{opacity:0;transform:translateY(26px);
  transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
[data-reveal][data-delay="4"]{transition-delay:.32s}
[data-reveal][data-delay="5"]{transition-delay:.4s}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1024px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .gal-grid{grid-template-columns:repeat(3,1fr)}
  .footer__top{grid-template-columns:1fr 1fr;gap:2rem}
  .hero__meta-inner{grid-template-columns:repeat(2,1fr);gap:1.6rem 2rem}
}
@media (max-width:860px){
  .nav__links,.nav__cta,.nav__phone{display:none}
  .nav__burger{display:flex}
  .split{grid-template-columns:1fr;gap:2.5rem}
  .split--reverse .split__media{order:0}
  .svc-row{grid-template-columns:1fr;gap:2rem}
  .svc-row--rev .svc-row__media{order:0}
  .cta-band__inner{grid-template-columns:1fr;gap:2rem}
  .contact-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:620px){
  :root{--gutter:20px}
  .svc-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}
  .gal-item.wide{grid-column:span 2}
  .gal-item.tall{grid-row:span 1;aspect-ratio:1}
  .hero__meta-inner{grid-template-columns:1fr 1fr}
  .form .frow{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;align-items:flex-start}
  .hero__scroll{display:none}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero__media img{transform:none}
  [data-reveal]{opacity:1;transform:none}
}
