/* ============================================================
   SELFMADE NERDSTUFF — Showroom · geteiltes Stylesheet
   Farben & Schriften aus der originalen style.css
   ============================================================ */

@font-face { font-family:"Figtree-XB"; src:url("assets/fonts/Figtree-Bold.ttf") format("truetype"); font-weight:800; }
@font-face { font-family:"Figtree";    src:url("assets/fonts/Figtree-SemiBold.ttf") format("truetype"); font-weight:600; }
@font-face { font-family:"Figtree";    src:url("assets/fonts/Figtree-Medium.ttf") format("truetype"); font-weight:500; }
@font-face { font-family:"Figtree";    src:url("assets/fonts/Figtree-Light.ttf") format("truetype"); font-weight:300; }
@font-face { font-family:"Encode";     src:url("assets/fonts/EncodeSansSemiExpanded-Regular.ttf") format("truetype"); font-weight:400; }
@font-face { font-family:"Encode";     src:url("assets/fonts/EncodeSansSemiExpanded-Bold.ttf") format("truetype"); font-weight:700; }

:root{
  --bg:#06171E;
  --bg-2:#081f29;
  --surface:#13242c;
  --surface-2:#28272A;
  --accent:#2AE1E8;
  --accent-2:#1bb8be;
  --accent-soft:rgba(42,225,232,.13);
  --line:rgba(255,255,255,.11);
  --line-2:rgba(255,255,255,.06);
  --text:#eef8fa;
  --muted:rgba(238,248,250,.62);
  --faint:rgba(238,248,250,.40);
  --maxw:1320px;
  --pad:clamp(18px,5vw,72px);
  --ease:cubic-bezier(.4,0,.15,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:"Figtree",system-ui,sans-serif;font-weight:300;
  line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:"Figtree-XB",sans-serif;font-weight:800;line-height:1.05;margin:0;color:#fff;letter-spacing:-.01em;}
::selection{background:var(--accent);color:var(--bg);}

/* ---------- shared atoms ---------- */
.eyebrow{
  font-family:"Encode",sans-serif;font-weight:700;font-size:.7rem;
  letter-spacing:.3em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);opacity:.7;}
.eyebrow.center{justify-content:center;}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--accent);opacity:.7;}
.eyebrow.bare::before{display:none;}

.section{padding:clamp(60px,10vw,140px) var(--pad);position:relative;}
.wrap{max-width:var(--maxw);margin:0 auto;}
.narrow{max-width:880px;margin:0 auto;}

.sec-head{margin-bottom:clamp(34px,6vw,68px);}
.sec-head h2{font-size:clamp(2rem,6vw,4.2rem);margin-top:16px;}
.sec-head p{color:var(--muted);max-width:56ch;margin:18px 0 0;font-size:clamp(1rem,2.4vw,1.16rem);}
.meta-key{font-family:"Encode",sans-serif;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--faint);}

.btn{display:inline-flex;align-items:center;gap:11px;font-family:"Encode",sans-serif;font-size:.74rem;
  letter-spacing:.15em;text-transform:uppercase;padding:15px 26px;border-radius:3px;cursor:pointer;
  border:1px solid var(--accent);color:var(--accent);background:var(--accent-soft);transition:.3s var(--ease);}
.btn:hover{background:var(--accent);color:var(--bg);gap:18px;}
.btn.ghost{border-color:var(--line);color:var(--text);background:none;}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft);}

.tag{font-family:"Encode",sans-serif;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;
  padding:6px 12px;border:1px solid var(--line);border-radius:999px;color:var(--muted);white-space:nowrap;}
.tag.accent{border-color:var(--accent);color:var(--accent);background:var(--accent-soft);}

/* ============================================================
   NAV (injected)
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;justify-content:space-between;
  padding:15px var(--pad);transition:background .4s var(--ease),backdrop-filter .4s,border-color .4s,padding .4s var(--ease);
  border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(6,23,30,.82);backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--line-2);padding-top:10px;padding-bottom:10px;}
.brand{display:flex;align-items:center;gap:12px;z-index:2;}
.brand img{width:40px;height:40px;object-fit:contain;}
.brand-txt{display:flex;flex-direction:column;line-height:1;}
.brand-txt b{font-family:"Encode",sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.13em;color:#fff;white-space:nowrap;}
.brand-txt span{font-family:"Encode",sans-serif;font-size:.5rem;letter-spacing:.28em;color:var(--accent);margin-top:5px;white-space:nowrap;}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none;margin:0;padding:0;}
.nav-links a{font-family:"Encode",sans-serif;font-size:.73rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);position:relative;padding:6px 0;transition:color .25s;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--accent);transition:width .3s var(--ease);}
.nav-links a:hover,.nav-links a.active{color:#fff;}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:2;}
.burger span{width:24px;height:2px;background:#fff;transition:.3s var(--ease);}
.nav.open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav.open .burger span:nth-child(2){opacity:0;}
.nav.open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ============================================================
   HERO — editorial w/ logo emblem
   ============================================================ */
.hero{min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden;padding:118px var(--pad) 60px;}
.hero-grid-bg{position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(ellipse 90% 80% at 72% 35%,#000 30%,transparent 80%);}
.hero-glow{position:absolute;z-index:0;width:58vw;height:58vw;max-width:720px;max-height:720px;border-radius:50%;
  background:radial-gradient(circle,var(--accent-soft),transparent 65%);filter:blur(18px);top:-6%;right:-6%;pointer-events:none;}
.hero .wrap{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(30px,5vw,72px);align-items:center;position:relative;z-index:2;}
.hero-eyebrow{margin-bottom:24px;}
.hero h1{font-size:clamp(2.8rem,8.4vw,6.6rem);letter-spacing:-.025em;}
.hero h1 .ln{display:block;}
.hero h1 em{font-style:normal;color:var(--accent);}
.hero-lede{color:var(--muted);font-size:clamp(1.05rem,2.4vw,1.3rem);max-width:48ch;margin:28px 0 0;}
.hero-stats{display:flex;gap:36px;margin-top:42px;flex-wrap:wrap;}
.hero-stat b{font-family:"Figtree-XB";font-size:clamp(1.7rem,3.6vw,2.5rem);color:#fff;display:block;line-height:1;}
.hero-stat span{font-family:"Encode",sans-serif;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);margin-top:9px;display:block;}
.hero-emblem{position:relative;justify-self:center;width:min(460px,86%);}
.hero-emblem::before{content:"";position:absolute;inset:-8%;background:radial-gradient(circle,var(--accent-soft),transparent 62%);filter:blur(14px);z-index:0;}
.hero-emblem img{position:relative;z-index:1;width:100%;border-radius:14px;filter:drop-shadow(0 30px 70px rgba(0,0,0,.6));animation:float 7s var(--ease) infinite;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-14px);}}
.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;
  font-family:"Encode",sans-serif;font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;color:var(--faint);
  display:flex;flex-direction:column;align-items:center;gap:9px;}
.scroll-cue i{width:1px;height:34px;background:linear-gradient(var(--accent),transparent);animation:cue 1.8s var(--ease) infinite;}
@keyframes cue{0%{transform:scaleY(.2);transform-origin:top;opacity:0;}40%{opacity:1;}100%{transform:scaleY(1);transform-origin:top;opacity:0;}}

/* ============================================================
   MATERIAL SELECT (home) — two calm large cards
   ============================================================ */
.materials{background:var(--bg-2);}
.mat-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.5vw,28px);}
.mat-card{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--surface);
  display:flex;flex-direction:column;min-height:440px;transition:transform .45s var(--ease),border-color .35s,box-shadow .45s;}
.mat-card:hover{transform:translateY(-6px);border-color:var(--accent);box-shadow:0 30px 60px -30px rgba(0,0,0,.85);}
.mat-previews{position:relative;flex:1;display:flex;gap:2px;min-height:240px;overflow:hidden;}
.mat-previews .pv{position:relative;flex:1;overflow:hidden;background:var(--surface-2);}
.mat-previews .pv img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);}
.mat-card:hover .mat-previews .pv img{transform:scale(1.07);}
.mat-previews::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 35%,rgba(6,23,30,.55) 70%,rgba(6,23,30,1) 90%);}
.mat-body{position:relative;padding:28px clamp(22px,3vw,38px) 30px;z-index:2;margin-top:-60px;}
.mat-kicker{font-family:"Encode",sans-serif;font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);}
.mat-body h3{font-size:clamp(1.9rem,3.4vw,2.8rem);margin:12px 0 0;}
.mat-body p{color:var(--muted);margin:14px 0 0;font-size:1.02rem;max-width:42ch;}
.mat-meta{display:flex;gap:26px;margin:24px 0 26px;}
.mat-meta .k b{font-family:"Figtree-XB";color:#fff;font-size:1.5rem;display:block;line-height:1;}
.mat-meta .k span{font-family:"Encode",sans-serif;font-size:.55rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-top:6px;display:block;}
.mat-go{display:inline-flex;align-items:center;gap:10px;font-family:"Encode",sans-serif;font-size:.72rem;letter-spacing:.15em;
  text-transform:uppercase;color:#fff;border-bottom:1px solid var(--accent);padding-bottom:6px;transition:gap .25s var(--ease);width:fit-content;}
.mat-card:hover .mat-go{gap:18px;color:var(--accent);}

/* ============================================================
   HOME WERKBANK TEASER + ABOUT TEASER
   ============================================================ */
.teaser{background:var(--bg);}
.teaser-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:42px;}
.about-teaser{background:var(--bg-2);}
.about-teaser .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,5vw,64px);align-items:center;}
.about-teaser .at-media{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/5;box-shadow:0 36px 70px -32px rgba(0,0,0,.8);}
.about-teaser .at-media img{width:100%;height:100%;object-fit:cover;}
.about-teaser h2{font-size:clamp(1.9rem,5vw,3.4rem);margin:16px 0 0;}
.about-teaser p{color:var(--muted);margin:22px 0 0;font-size:1.06rem;max-width:48ch;}
.about-teaser .btn{margin-top:30px;}

/* ============================================================
   GALLERY (page) — tidy uniform 4:5 cards
   ============================================================ */
.gal-head{padding-top:clamp(120px,16vw,170px);}
.filters{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:38px;}
.filter{font-family:"Encode",sans-serif;font-size:.64rem;letter-spacing:.13em;text-transform:uppercase;
  padding:9px 16px;border:1px solid var(--line);border-radius:999px;background:none;color:var(--muted);cursor:pointer;transition:.25s var(--ease);}
.filter:hover{border-color:var(--accent);color:#fff;transform:translateY(-2px);}
.filter.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);box-shadow:0 0 16px rgba(42,225,232,.16);}
.filter-count{opacity:.5;margin-left:.15em;}

.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:clamp(12px,1.5vw,18px);}
.gal-card{position:relative;border-radius:9px;overflow:hidden;border:1px solid var(--line);background:var(--surface);
  cursor:pointer;aspect-ratio:4/5;transition:transform .4s var(--ease),border-color .3s,box-shadow .45s;}
.gal-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.gal-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 24px 46px -24px rgba(0,0,0,.9);}
.gal-card:hover img{transform:scale(1.06);}
.gal-card .ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:16px 15px;
  background:linear-gradient(transparent 45%,rgba(6,23,30,.92));opacity:0;transition:opacity .35s var(--ease);}
.gal-card:hover .ov{opacity:1;}
.gal-card .ov b{font-family:"Figtree-XB";font-size:1rem;color:#fff;line-height:1.15;}
.gal-card .ov span{font-family:"Encode",sans-serif;font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-top:6px;}
.gal-badge{position:absolute;top:10px;left:10px;font-family:"Encode",sans-serif;font-size:.5rem;letter-spacing:.13em;
  text-transform:uppercase;padding:5px 8px;border-radius:3px;background:rgba(6,23,30,.72);backdrop-filter:blur(6px);border:1px solid var(--line);color:var(--muted);z-index:2;}
.gal-count{position:absolute;top:10px;right:10px;font-family:"Encode",sans-serif;font-size:.52rem;letter-spacing:.1em;
  padding:5px 8px;border-radius:3px;background:rgba(6,23,30,.72);backdrop-filter:blur(6px);border:1px solid var(--line);color:var(--accent);z-index:2;display:flex;align-items:center;gap:5px;}
.gal-empty{color:var(--faint);font-family:"Encode",sans-serif;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;padding:60px 0;text-align:center;}

/* ============================================================
   WERKBANK
   ============================================================ */
.bank-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;}
.bank-card{position:relative;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--surface);
  transition:transform .4s var(--ease),border-color .3s;}
.bank-card:hover{transform:translateY(-5px);border-color:var(--accent);}
.bank-media{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--surface-2);}
.bank-media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.bank-card:hover .bank-media img{transform:scale(1.06);}
.bank-media::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(6,23,30,.85));}
.bank-status{position:absolute;top:11px;left:11px;display:inline-flex;align-items:center;gap:8px;z-index:2;
  font-family:"Encode",sans-serif;font-size:.55rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);
  padding:6px 11px;border-radius:999px;background:rgba(6,23,30,.72);backdrop-filter:blur(6px);border:1px solid var(--line);}
.bank-status i{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);}
.bank-body{padding:18px 18px 22px;}
.bank-body h3{font-size:1.22rem;}
.bank-body .sub{font-family:"Encode",sans-serif;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-top:9px;}

/* process / workflow */
.process{background:var(--bg-2);}
.proc-intro{max-width:60ch;color:var(--muted);font-size:clamp(1.04rem,2.4vw,1.2rem);}
.proc-intro strong{color:var(--text);font-weight:600;}
.steps{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:clamp(38px,6vw,60px);counter-reset:step;}
.step{position:relative;border:1px solid var(--line);border-radius:10px;padding:26px 24px 24px;background:var(--surface);overflow:hidden;transition:.35s var(--ease);}
.step:hover{border-color:var(--accent);transform:translateY(-4px);}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);position:absolute;top:14px;right:18px;
  font-family:"Figtree-XB";font-size:2.4rem;color:var(--line);transition:color .35s;}
.step:hover::before{color:var(--accent-soft);}
.step .sk{font-family:"Encode",sans-serif;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);}
.step h4{font-size:1.22rem;margin:12px 0 0;}
.step p{color:var(--muted);margin:11px 0 0;font-size:.96rem;}

/* ============================================================
   ABOUT page
   ============================================================ */
.about-hero{padding-top:clamp(120px,16vw,180px);display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,68px);align-items:center;}
.about-portrait{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/5;box-shadow:0 40px 80px -30px rgba(0,0,0,.8);}
.about-portrait img{width:100%;height:100%;object-fit:cover;}
.about-portrait .plate{position:absolute;left:14px;bottom:14px;padding:11px 15px;background:rgba(6,23,30,.62);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:4px;}
.about-portrait .plate b{font-family:"Figtree-XB";font-size:1rem;color:#fff;display:block;}
.about-portrait .plate span{font-family:"Encode",sans-serif;font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);}
.about-hero h1{font-size:clamp(2.4rem,6vw,4.4rem);margin:18px 0 0;}
.about-lede{color:var(--muted);font-size:clamp(1.06rem,2.4vw,1.26rem);margin:24px 0 0;max-width:52ch;}
.about-lede strong{color:var(--text);font-weight:600;}

.passion-block{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;padding:clamp(46px,8vw,96px) 0;border-top:1px solid var(--line-2);}
.passion-block:last-of-type{border-bottom:1px solid var(--line-2);}
.passion-block.flip .pb-media{order:2;}
.pb-media{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line);aspect-ratio:1/1;box-shadow:0 34px 70px -32px rgba(0,0,0,.8);}
.pb-media img{width:100%;height:100%;object-fit:cover;}
.pb-body .pk{font-family:"Encode",sans-serif;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);}
.pb-body h3{font-size:clamp(1.7rem,4vw,2.6rem);margin:14px 0 0;}
.pb-body h4{font-family:"Figtree";font-weight:600;color:var(--accent);font-size:1rem;margin:22px 0 6px;}
.pb-body p{color:var(--muted);margin:0;font-size:1.02rem;}
.pb-body p + p{margin-top:14px;}

.timeline{margin-top:clamp(40px,6vw,72px);border-top:1px solid var(--line-2);}
.tl-row{display:grid;grid-template-columns:120px 1fr;gap:30px;padding:26px 0;border-bottom:1px solid var(--line-2);align-items:baseline;}
.tl-year{font-family:"Figtree-XB";font-size:1.5rem;color:var(--accent);}
.tl-row p{margin:0;color:var(--muted);}
.tl-row b{color:#fff;font-weight:600;}

/* ============================================================
   KONTAKT
   ============================================================ */
.contact-hero{padding-top:clamp(120px,16vw,180px);}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,5vw,60px);align-items:start;}
.contact-intro h1{font-size:clamp(2.2rem,5.5vw,3.8rem);margin:16px 0 0;}
.contact-intro p{color:var(--muted);font-size:clamp(1.04rem,2.4vw,1.2rem);margin:22px 0 0;max-width:46ch;}
.contact-intro strong{color:var(--text);font-weight:600;}
.social-list{display:flex;flex-direction:column;gap:12px;margin-top:34px;}
.social-link{display:flex;align-items:center;gap:16px;padding:15px 18px;border:1px solid var(--line);border-radius:8px;background:var(--surface);transition:.3s var(--ease);}
.social-link:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateX(5px);}
.social-link .ic{width:40px;height:40px;border-radius:8px;display:grid;place-items:center;background:rgba(42,225,232,.1);flex-shrink:0;}
.social-link .ic img{width:20px;height:20px;filter:brightness(0) saturate(100%) invert(82%) sepia(58%) saturate(1352%) hue-rotate(130deg) brightness(98%) contrast(90%);}
.social-link b{font-family:"Figtree";font-weight:600;color:#fff;font-size:1rem;}
.social-link span{font-family:"Encode",sans-serif;font-size:.58rem;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);display:block;margin-top:3px;}
.social-link .arrow{margin-left:auto;color:var(--faint);transition:.25s;}
.social-link:hover .arrow{color:var(--accent);transform:translateX(4px);}

.form-card{border:1px solid var(--line);border-radius:12px;padding:clamp(26px,4vw,40px);background:var(--surface);}
.form-group{margin-bottom:20px;}
.form-group label{font-family:"Encode",sans-serif;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:9px;}
.form-group input,.form-group textarea{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:7px;
  color:var(--text);font-family:"Figtree";font-size:1rem;padding:13px 15px;transition:border-color .25s;resize:vertical;}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--faint);}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.submit-btn{width:100%;border:0;border-radius:7px;background:var(--accent);color:var(--bg);font-family:"Encode",sans-serif;font-weight:700;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;padding:16px;cursor:pointer;transition:.3s var(--ease);}
.submit-btn:hover{background:#fff;}
.success-text{display:none;color:var(--accent);font-family:"Figtree";font-weight:600;text-align:center;margin-top:16px;line-height:1.5;}

/* ============================================================
   LEGAL (impressum/datenschutz)
   ============================================================ */
.legal{padding-top:clamp(120px,16vw,180px);}
.legal h1{font-size:clamp(2rem,5vw,3.4rem);}
.legal h2{font-size:1.4rem;margin:38px 0 0;color:var(--accent);}
.legal h3{font-size:1.1rem;margin:26px 0 0;}
.legal p{color:var(--muted);margin:12px 0 0;}
.legal a{color:var(--accent);}

/* ============================================================
   FOOTER (injected)
   ============================================================ */
.foot{background:var(--bg);border-top:1px solid var(--line);padding:clamp(54px,8vw,88px) var(--pad) 38px;}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;}
.foot-brand{display:flex;align-items:center;gap:16px;}
.foot-brand img{width:54px;height:54px;object-fit:contain;}
.foot-brand b{font-family:"Figtree-XB";font-size:clamp(1.4rem,3.4vw,2rem);color:#fff;display:block;}
.foot-brand p{font-family:"Encode",sans-serif;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin:8px 0 0;}
.foot-nav{display:flex;gap:30px;flex-wrap:wrap;}
.foot-nav a{font-family:"Encode",sans-serif;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);transition:color .25s;}
.foot-nav a:hover{color:var(--accent);}
.foot-socials{display:flex;gap:12px;margin-top:6px;}
.foot-socials a{width:44px;height:44px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;transition:.3s var(--ease);}
.foot-socials a:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-3px);}
.foot-socials img{width:19px;height:19px;filter:brightness(0) saturate(100%) invert(82%) sepia(58%) saturate(1352%) hue-rotate(130deg) brightness(98%) contrast(90%);}
.foot-bot{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-top:clamp(38px,6vw,60px);padding-top:24px;border-top:1px solid var(--line-2);}
.foot-bot small{color:var(--faint);font-size:.78rem;}
.foot-bot nav{display:flex;gap:22px;}
.foot-bot nav a{font-family:"Encode",sans-serif;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);transition:color .25s;}
.foot-bot nav a:hover{color:var(--accent);}

/* ============================================================
   BACK TO TOP
   ============================================================ */
.to-top{position:fixed;right:clamp(16px,4vw,28px);bottom:clamp(16px,4vw,28px);z-index:70;
  width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:rgba(6,23,30,.72);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--accent);font-size:1.25rem;line-height:1;
  cursor:pointer;display:grid;place-items:center;opacity:0;transform:translateY(12px);pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease),background .25s,color .25s,border-color .25s;}
.to-top.show{opacity:1;transform:none;pointer-events:auto;}
.to-top:hover{background:var(--accent);color:var(--bg);border-color:var(--accent);}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lb{position:fixed;inset:0;z-index:200;background:rgba(4,15,20,.95);backdrop-filter:blur(14px);display:none;opacity:0;transition:opacity .35s var(--ease);padding:clamp(16px,4vw,48px);}
.lb.open{display:flex;opacity:1;}
.lb-inner{margin:auto;display:grid;grid-template-columns:auto 340px;gap:36px;max-width:1080px;width:100%;align-items:center;}
.lb-stage{position:relative;display:flex;align-items:center;justify-content:center;}
.lb-stage img{max-height:80svh;max-width:100%;border-radius:7px;border:1px solid var(--line);box-shadow:0 40px 90px -30px #000;}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;border:1px solid var(--line);background:rgba(6,23,30,.72);color:#fff;cursor:pointer;display:grid;place-items:center;font-size:1.3rem;transition:.25s var(--ease);}
.lb-nav:hover{background:var(--accent);color:var(--bg);border-color:var(--accent);}
.lb-prev{left:-22px;}.lb-next{right:-22px;}
.lb-info .eyebrow{margin-bottom:16px;}
.lb-info h3{font-size:clamp(1.7rem,4vw,2.5rem);}
.lb-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px;}
.lb-specs{display:flex;gap:30px;margin-top:26px;flex-wrap:wrap;}
.lb-specs .s b{font-family:"Figtree-XB";font-size:1.35rem;color:#fff;display:block;line-height:1;}
.lb-specs .s span{font-family:"Encode",sans-serif;font-size:.54rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-top:7px;display:block;}
.lb-thumbs{display:flex;gap:8px;margin-top:26px;flex-wrap:wrap;}
.lb-thumbs img{width:48px;height:60px;object-fit:cover;border-radius:3px;border:1px solid var(--line);cursor:pointer;opacity:.5;transition:.25s;}
.lb-thumbs img.active,.lb-thumbs img:hover{opacity:1;border-color:var(--accent);}
.lb-count{font-family:"Encode",sans-serif;font-size:.62rem;letter-spacing:.2em;color:var(--faint);margin-top:22px;}
.lb-close{position:fixed;top:20px;right:24px;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:rgba(6,23,30,.72);color:#fff;cursor:pointer;font-size:1.2rem;display:grid;place-items:center;z-index:2;transition:.25s;}
.lb-close:hover{background:var(--accent);color:var(--bg);}

/* ============================================================
   reveal — transform only (opacity untouched → never stuck hidden)
   ============================================================ */
.reveal:not(.in){transform:translateY(20px);}
.reveal{transition:transform .7s var(--ease);}
.reveal.d1{transition-delay:.07s;}
.reveal.d2{transition-delay:.14s;}
.reveal.d3{transition-delay:.21s;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:900px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);flex-direction:column;justify-content:center;gap:28px;
    background:rgba(6,23,30,.97);backdrop-filter:blur(20px);border-left:1px solid var(--line);transform:translateX(100%);transition:transform .4s var(--ease);padding:40px;}
  .nav.open .nav-links{transform:none;}
  /* Auf Mobil kein backdrop-filter an der Navi: dieser erzeugt sonst einen
     "containing block", an dem das fixe Menü klebt — es slidet falsch herein und
     springt beim Öffnen nach unten. Hintergrund/Border bleiben erhalten. */
  .nav.scrolled{backdrop-filter:none;-webkit-backdrop-filter:none;}
  .nav-links a{font-size:1rem;}
  .burger{display:flex;}
  .hero .wrap,.about-teaser .wrap,.about-hero,.passion-block,.passion-block.flip .pb-media,.contact-grid{grid-template-columns:1fr;}
  .passion-block.flip .pb-media{order:0;}
  .hero-emblem{max-width:320px;margin-top:30px;}
  .mat-grid{grid-template-columns:1fr;}
  .teaser-grid{grid-template-columns:1fr 1fr;}
  .lb-inner{grid-template-columns:1fr;gap:18px;}
  .lb-info{display:block;text-align:center;}
  .lb-info .eyebrow,.lb-info .lb-tags,.lb-info .lb-specs,.lb-info .lb-thumbs{display:none;}
  .lb-info h3{font-size:1.4rem;}
  .lb-count{margin-top:10px;}
  .lb-stage img{max-height:66svh;}
  .lb-prev{left:6px;}.lb-next{right:6px;}
  .pb-media{max-width:440px;}
  .about-portrait{max-width:380px;}
}
@media(max-width:560px){
  .gal-grid{grid-template-columns:1fr 1fr;}
  .teaser-grid{grid-template-columns:1fr;}
  .tl-row{grid-template-columns:60px 1fr;gap:16px;}
  .hero-stats{gap:24px;}
  .foot-top{flex-direction:column;}
}
