/* Glasmalerei Dr. H. Oidtmann — Relaunch · MMC-Werbung */
/* ===========================================================
   Glasmalerei Dr. H. Oidtmann — Stylesheet
   =========================================================== */
:root{
  --ink:#0d0f12;
  --ink-2:#14171c;
  --ink-3:#1c2028;
  --lead:#2a2f38;
  --cream:#efe9dc;
  --cream-dim:#b7b1a5;
  --muted:#8a8579;
  --cobalt:#2f6fb0;
  --ruby:#b23a3a;
  --amber:#c9962e;
  --gold:#c9a24a;
  --maxw:1240px;
  --gut:clamp(1.25rem,4vw,3rem);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);color:var(--cream);
  font-family:'Inter',system-ui,sans-serif;font-weight:300;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4,.display{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;line-height:1.1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.narrow{max-width:820px;margin-inline:auto}
.eyebrow{font-family:'Inter',sans-serif;font-weight:500;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}
.gold{color:var(--gold)}

/* ---------- HEADER / NAV ---------- */
.site-head{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--gut);
  transition:background .4s ease,padding .4s ease,border-color .4s ease;
  border-bottom:1px solid transparent;
}
.site-head.solid,.site-head.scrolled{
  background:rgba(13,15,18,.92);backdrop-filter:blur(12px);
  padding:.7rem var(--gut);border-bottom:1px solid rgba(201,162,74,.18);
}
.site-head .logo{height:56px;width:auto;transition:height .4s ease;opacity:.98;filter:drop-shadow(0 2px 10px rgba(0,0,0,.8))}
.site-head.solid .logo,.site-head.scrolled .logo{height:44px}
.nav-right{display:flex;align-items:center;gap:1.8rem}
.nav{display:flex;gap:1.9rem;align-items:center}
.nav a{font-size:.82rem;letter-spacing:.04em;color:var(--cream-dim);transition:color .25s;position:relative}
.nav a:hover,.nav a.active{color:var(--cream)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--gold)}
.nav a.cta{border:1px solid var(--gold);color:var(--gold);padding:.5rem 1.1rem;border-radius:1px;letter-spacing:.08em}
.nav a.cta:hover{background:var(--gold);color:var(--ink)}
.nav a.cta::after{display:none}

/* language switch */
.lang{display:flex;align-items:center;gap:.5rem;border:1px solid var(--lead);border-radius:2px;padding:.32rem .55rem}
.lang-mobile{display:none}
.lang button{background:none;border:0;cursor:pointer;padding:.1rem .25rem;display:flex;align-items:center;gap:.3rem;opacity:.5;transition:opacity .25s;font-family:inherit;color:var(--cream-dim);font-size:.72rem;letter-spacing:.08em}
.lang button.on{opacity:1;color:var(--cream)}
.lang button:hover{opacity:.85}
.lang .flag{width:18px;height:13px;border-radius:1px;display:block;object-fit:cover;box-shadow:0 0 0 1px rgba(255,255,255,.12)}
.lang .sep{width:1px;height:14px;background:var(--lead)}

.burger{display:none;background:none;border:0;color:var(--cream);cursor:pointer;flex-direction:column;gap:5px}
.burger span{display:block;width:26px;height:1.5px;background:var(--cream)}

/* ---------- HERO ---------- */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(13,15,18,.45) 0%,rgba(13,15,18,.15) 22%,rgba(13,15,18,.2) 45%,rgba(13,15,18,.78) 78%,rgba(13,15,18,.96) 100%)}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 2.4s ease-in-out;animation:kenburns 21s ease-in-out infinite;will-change:transform,opacity}
.hero-slide.active{opacity:1}
@keyframes kenburns{0%{transform:scale(1.06)}100%{transform:scale(1.16) translate(-1.5%,-1.5%)}}

.hero-content{position:absolute;z-index:3;left:0;right:0;bottom:clamp(3rem,9vh,7rem);padding-inline:var(--gut)}
.hero-content .inner{display:inline-block;max-width:640px;padding:2rem 2.4rem 2.2rem;background:linear-gradient(135deg,rgba(13,15,18,.62),rgba(13,15,18,.34));backdrop-filter:blur(7px);border:1px solid rgba(201,162,74,.18);border-left:2px solid var(--gold);box-shadow:0 30px 80px -30px rgba(0,0,0,.9)}
.hero-content .eyebrow{opacity:0;animation:rise .9s ease .4s forwards}
.hero-content h1{font-size:clamp(2.6rem,7vw,6rem);max-width:16ch;margin:.4rem 0 1.2rem;text-shadow:0 2px 40px rgba(0,0,0,.5);opacity:0;animation:rise 1s ease .55s forwards}
.hero-content h1 em{font-style:italic;color:var(--gold)}
.hero-lede{max-width:46ch;color:var(--cream-dim);font-size:1.05rem;opacity:0;animation:rise 1s ease .75s forwards}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.hero-dots{position:absolute;z-index:4;bottom:2rem;right:var(--gut);display:flex;gap:.6rem}
.hero-dots button{width:30px;height:2px;background:rgba(239,233,220,.3);border:0;cursor:pointer;transition:background .3s;padding:0}
.hero-dots button.on{background:var(--gold)}
.scroll-hint{position:absolute;z-index:4;bottom:2rem;left:50%;transform:translateX(-50%);color:var(--cream-dim);font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scroll-hint::after{content:"";width:1px;height:38px;background:linear-gradient(var(--gold),transparent);animation:pulse 2.4s ease infinite}
@keyframes pulse{0%,100%{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- PAGE HERO (subpages) ---------- */
.page-hero{position:relative;min-height:52vh;display:flex;align-items:flex-end;overflow:hidden;padding-bottom:clamp(2.5rem,6vh,4rem)}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);filter:brightness(.55) saturate(.95)}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,15,18,.7),rgba(13,15,18,.45) 40%,rgba(13,15,18,.95))}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-size:clamp(2.4rem,6vw,4.4rem);margin:.5rem 0 .6rem;max-width:20ch}
.page-hero p{color:var(--cream-dim);max-width:54ch;font-size:1.08rem}
.crumb{font-size:.74rem;letter-spacing:.1em;color:var(--muted);text-transform:uppercase}
.crumb a:hover{color:var(--gold)}

/* ---------- SECTION SCAFFOLD ---------- */
section{position:relative}
.band{padding-block:clamp(4.5rem,11vh,9rem)}
.band-sm{padding-block:clamp(3rem,7vh,5rem)}
.section-head{max-width:62ch;margin-bottom:3.2rem}
.section-head h2{font-size:clamp(2rem,4.6vw,3.4rem);margin:.6rem 0 1rem}
.section-head p{color:var(--cream-dim);font-size:1.08rem}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
.rule{display:flex;align-items:center;gap:1rem;margin:0 auto}
.rule::before,.rule::after{content:"";height:1px;background:linear-gradient(90deg,transparent,rgba(201,162,74,.5),transparent);flex:1}
.rule span{width:7px;height:7px;background:var(--gold);transform:rotate(45deg)}

/* prose for subpages */
.prose{max-width:760px;margin-inline:auto}
.prose h2{font-size:clamp(1.7rem,3.4vw,2.5rem);margin:2.6rem 0 1rem}
.prose h3{font-size:1.4rem;margin:2rem 0 .8rem;color:var(--cream)}
.prose p{color:var(--cream-dim);margin-bottom:1.2rem}
.prose strong{color:var(--cream);font-weight:500}
.prose ul{list-style:none;margin:1.2rem 0 1.6rem}
.prose ul li{position:relative;padding-left:1.6rem;margin-bottom:.7rem;color:var(--cream-dim)}
.prose ul li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;background:var(--gold);transform:rotate(45deg)}
.prose blockquote{border-left:2px solid var(--gold);padding:.4rem 0 .4rem 1.6rem;margin:1.8rem 0;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:var(--cream)}
.prose .lead{font-size:1.2rem;color:var(--cream);font-family:'Cormorant Garamond',serif;line-height:1.5;margin-bottom:1.8rem}
.figure-wide{margin:2.4rem 0;border:1px solid var(--lead);box-shadow:0 30px 80px -30px rgba(0,0,0,.9)}
.figure-wide figcaption,.cap-line{font-size:.78rem;color:var(--muted);margin-top:.7rem;text-align:center}

/* ---------- INTRO ---------- */
.intro-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,6vw,5rem);align-items:center}
.intro-text h2{font-size:clamp(2.2rem,4.6vw,3.6rem);margin-bottom:1.4rem}
.intro-text p{color:var(--cream-dim);margin-bottom:1.1rem;max-width:54ch}
.intro-text strong{color:var(--cream);font-weight:500}
.intro-figure{position:relative}
.intro-figure img{border:1px solid var(--lead);box-shadow:0 30px 80px -30px rgba(0,0,0,.9)}
.intro-figure figcaption{margin-top:.8rem;font-size:.78rem;color:var(--muted);letter-spacing:.03em}
.estd{position:absolute;top:-2.2rem;left:-1.2rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(3rem,7vw,5.5rem);color:rgba(201,162,74,.16);z-index:-1}

/* ---------- STATS ---------- */
.stats{border-block:1px solid var(--lead);background:var(--ink-2)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:center}
.stat .num{font-family:'Cormorant Garamond',serif;font-size:clamp(2.4rem,5vw,3.6rem);color:var(--gold);line-height:1}
.stat .lab{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-dim);margin-top:.6rem}

/* ---------- SERVICES ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--lead);border:1px solid var(--lead)}
.svc{position:relative;background:var(--ink-2);padding:2.4rem 2rem;transition:background .4s;overflow:hidden;isolation:isolate;display:block}
.svc::before{content:"";position:absolute;inset:0;z-index:-2;background-image:var(--i);background-size:cover;background-position:center;opacity:0;transform:scale(1.08);transition:opacity .7s ease,transform 1.2s ease}
.svc::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(13,15,18,.82),rgba(13,15,18,.9));opacity:0;transition:opacity .7s ease}
.svc:hover::before{opacity:.5;transform:scale(1)}
.svc:hover::after{opacity:1}
.svc:hover{background:transparent}
.svc .no{font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--gold);letter-spacing:.1em}
.svc h3{font-size:1.7rem;margin:.7rem 0 .9rem}
.svc p{color:var(--cream-dim);font-size:.95rem}
.svc .more{display:inline-block;margin-top:1.3rem;font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid transparent;transition:border-color .3s}
.svc:hover .more{border-color:var(--gold)}

/* ---------- GALLERY ---------- */
.gallery{background:var(--ink-2);border-block:1px solid var(--lead)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:230px;gap:16px}
.gal-item{position:relative;overflow:hidden;background:#000;border:1px solid var(--lead);transition:border-color .5s}
.gal-item::after{content:"";position:absolute;inset:10px;z-index:3;pointer-events:none;border:1px solid rgba(201,162,74,0);transition:border-color .5s}
.gal-item:hover{border-color:rgba(201,162,74,.55)}
.gal-item:hover::after{border-color:rgba(201,162,74,.5)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.2,.8,.2,1),filter 1.1s ease;filter:saturate(.9) brightness(.86)}
.gal-item:hover img{transform:scale(1.08);filter:saturate(1.12) brightness(1.04)}
.gal-item .cap{position:absolute;inset:auto 0 0 0;z-index:4;padding:1.4rem 1.3rem 1.2rem;font-size:.82rem;color:var(--cream);background:linear-gradient(transparent,rgba(7,8,10,.92));opacity:0;transform:translateY(14px);transition:.5s}
.gal-item:hover .cap{opacity:1;transform:none}
.gal-item .cap b{font-weight:500;font-family:'Cormorant Garamond',serif;font-size:1.15rem}
.gal-item .cap span{display:block;color:var(--gold);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;margin-top:.3rem}
.span-2c{grid-column:span 2}.span-2r{grid-row:span 2}

/* ---------- TIMELINE ---------- */
.tl{position:relative;max-width:920px;margin:0 auto}
.tl::before{content:"";position:absolute;left:50%;top:6px;bottom:6px;width:1px;background:linear-gradient(var(--gold),var(--lead));transform:translateX(-50%)}
.tl-item{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:2.6rem;align-items:center;padding-bottom:3rem}
.tl-item .portrait{justify-self:end;width:100%;max-width:230px}
.tl-item .portrait img{width:100%;aspect-ratio:4/5;object-fit:cover;border:1px solid var(--lead);filter:saturate(.92) brightness(.95);box-shadow:0 20px 50px -24px rgba(0,0,0,.9)}
.tl-item .portrait.wide img{aspect-ratio:3/2;object-fit:cover;object-position:center;width:100%}
.tl-item .portrait.wide{max-width:100%;grid-column:1 / -1}
.tl-item .portrait figcaption{margin-top:.5rem;font-size:.72rem;color:var(--muted);text-align:right}
.tl-item .body{padding-left:.4rem}
.tl-item:nth-child(even) .portrait{order:2;justify-self:start}
.tl-item:nth-child(even) .portrait figcaption{text-align:left}
.tl-item:nth-child(even) .body{order:1;text-align:right;padding-left:0;padding-right:.4rem}
.tl-item::before{content:"";position:absolute;left:50%;top:50%;width:15px;height:15px;background:var(--ink);border:1px solid var(--gold);transform:translate(-50%,-50%) rotate(45deg);z-index:2}
.tl-item .yr{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold);font-size:1.4rem}
.tl-item h3{font-size:1.5rem;margin:.15rem 0 .55rem}
.tl-item p{color:var(--cream-dim);font-size:.93rem}
.tl-item .body a.read{display:inline-block;margin-top:.7rem;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid transparent}
.tl-item .body a.read:hover{border-color:var(--gold)}

/* ---------- CTA ---------- */
.cta-band{position:relative;background:var(--ink-2);border-block:1px solid var(--lead);text-align:center;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 120%,rgba(47,111,176,.18),transparent 60%),radial-gradient(ellipse at 20% 0%,rgba(178,58,58,.12),transparent 55%)}
.cta-band .wrap{position:relative}
.cta-band h2{font-size:clamp(2.2rem,5vw,4rem);margin-bottom:1.2rem}
.cta-band p{color:var(--cream-dim);max-width:46ch;margin:0 auto 2.2rem}
.btn{display:inline-block;border:1px solid var(--gold);color:var(--gold);padding:.95rem 2.4rem;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;transition:.3s}
.btn:hover{background:var(--gold);color:var(--ink)}
.btn-solid{background:var(--gold);color:var(--ink);margin-left:.8rem}
.btn-solid:hover{background:transparent;color:var(--gold)}

/* ---------- RELATED / NEXT PAGES ---------- */
.related{background:var(--ink-2);border-top:1px solid var(--lead)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.related-card{display:block;border:1px solid var(--lead);background:var(--ink);padding:1.8rem;transition:border-color .4s,transform .4s}
.related-card:hover{border-color:rgba(201,162,74,.5);transform:translateY(-3px)}
.related-card .eyebrow{font-size:.66rem}
.related-card h3{font-size:1.35rem;margin:.5rem 0 .5rem}
.related-card p{color:var(--cream-dim);font-size:.88rem}
.related-card .more{display:inline-block;margin-top:.9rem;color:var(--gold);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);padding-block:4rem 2rem;border-top:1px solid var(--lead)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.4rem;margin-bottom:3rem}
footer .logo{height:48px;margin-bottom:1.2rem;opacity:.92}
footer p,footer a{color:var(--cream-dim);font-size:.9rem}
footer h4{font-family:'Inter';font-weight:500;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
footer ul{list-style:none;display:flex;flex-direction:column;gap:.55rem}
footer ul a:hover{color:var(--cream)}
.foot-bot{border-top:1px solid var(--lead);padding-top:1.6rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.78rem;color:var(--muted)}
.foot-bot a{color:var(--gold)}

/* ---------- LANG NOTICE (EN placeholder) ---------- */
.lang-note{position:fixed;left:50%;bottom:2rem;transform:translateX(-50%) translateY(120%);z-index:80;background:var(--ink-3);border:1px solid var(--gold);padding:.9rem 1.4rem;font-size:.85rem;color:var(--cream);box-shadow:0 20px 60px -20px rgba(0,0,0,.9);transition:transform .45s ease;max-width:90vw}
.lang-note.show{transform:translateX(-50%) translateY(0)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);height:100vh;background:#0d0f12;flex-direction:column;justify-content:center;align-items:flex-start;gap:1.6rem;padding:5rem 2.4rem 2rem;transform:translateX(100%);transition:transform .4s ease;border-left:1px solid var(--lead);z-index:58;box-shadow:-30px 0 60px -20px rgba(0,0,0,.9);overflow-y:auto}
  .nav.open{transform:none}
  .nav a{font-size:1.05rem}
  .burger{display:flex;z-index:60}
  .intro-grid{grid-template-columns:1fr;gap:2.5rem}
  .stats .wrap{grid-template-columns:repeat(2,1fr);gap:2rem}
  .svc-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .span-2r{grid-row:span 1}
  .related-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .tl{max-width:520px}
  .tl::before{left:8px}
  .tl-item{grid-template-columns:1fr;gap:1rem;padding-left:2.6rem;padding-bottom:2.4rem}
  .tl-item .portrait{justify-self:start;max-width:160px;order:1}
  .tl-item .body,.tl-item:nth-child(even) .body{order:2;text-align:left;padding:0}
  .tl-item:nth-child(even) .portrait{justify-self:start}
  .tl-item:nth-child(even) .portrait figcaption,.tl-item .portrait figcaption{text-align:left}
  .tl-item::before{left:8px;top:.6rem;transform:translate(-50%,0) rotate(45deg)}
}
@media(max-width:540px){
  .gal-grid{grid-template-columns:1fr}
  .span-2c{grid-column:span 1}
  .foot-grid{grid-template-columns:1fr}
  .nav-right{gap:1rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:opacity .3s ease!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   Ergänzungen Relaunch — Subhero & Lightbox · MMC-Werbung
   ============================================================ */
.subhero{min-height:46vh;display:flex;align-items:center;justify-content:center;text-align:center;background-size:cover;background-position:center;padding:7rem 1.5rem 3rem;border-bottom:1px solid var(--lead)}
.subhero .wrap{max-width:760px}
.subhero h1{font-size:clamp(2.4rem,6vw,4rem);margin:.4rem 0}
.subhero .subhero-lede{color:var(--cream-dim);max-width:60ch;margin:1rem auto 0}

#lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,9,11,.96);display:none;align-items:center;justify-content:center;flex-direction:column;padding:2rem;cursor:zoom-out}
#lightbox.on{display:flex}
#lightbox img{max-width:90vw;max-height:82vh;object-fit:contain;border:1px solid var(--lead)}
#lightbox .lb-cap{color:var(--cream);margin-top:1rem;font-size:.9rem;letter-spacing:.03em;text-align:center;max-width:80vw}
#lightbox .lb-x{position:absolute;top:1.4rem;right:1.8rem;color:var(--cream);font-size:2.2rem;cursor:pointer;line-height:1}

.gal-item{cursor:pointer}
.gal-item figcaption{font-size:.72rem}

/* Subseiten-Textbereiche */
.page-sec{padding-block:clamp(3rem,6vw,5rem)}
.page-sec .wrap{max-width:1100px}
.prose{max-width:70ch}
.prose p{margin-bottom:1.1rem;color:var(--cream-dim)}
.prose h2{font-size:clamp(1.7rem,3.5vw,2.4rem);margin:.3rem 0 1.2rem}
.prose h3{color:var(--gold);font-size:1.3rem;margin:2rem 0 .7rem}
.prose ul{margin:1rem 0 1.5rem 1.1rem;color:var(--cream-dim)}
.prose ul li{margin-bottom:.45rem}
.prose ul li::marker{color:var(--gold)}
.prose blockquote{border-left:3px solid var(--gold);padding:.4rem 0 .4rem 1.4rem;margin:1.5rem 0;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:var(--cream)}
.lead-row{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;border-bottom:1px solid var(--lead);padding-bottom:1rem;margin-bottom:1.5rem;flex-wrap:wrap}

@media(max-width:980px){
  /* Sprachwechsler ins geöffnete Menü holen */
  /* Desktop-Sprachwechsler ausblenden, Mobile-Version lebt im Menü */
  .lang-desktop{display:none !important}
  .lang-mobile{display:flex;position:static;margin-top:1.5rem;border:1px solid var(--lead);background:transparent;align-self:flex-start}
  .lang-mobile button{font-size:.9rem;color:var(--cream-dim)}
  .lang-mobile button.on{color:var(--gold)}
  body.menu-open{overflow:hidden}
  body.menu-open{overflow:hidden}
}

/* ============================================================
   Startseite: Leistungs-Blöcke, Mini-Galerien · MMC-Werbung
   ============================================================ */
.hero-inner{max-width:680px}
.hero-title{font-size:clamp(2.6rem,7vw,5rem);line-height:1.05;margin:.3rem 0 1rem}
.hero-title em{color:var(--gold);font-style:italic}
.intro-img{margin:0;position:relative}
.intro-img img{width:100%;border:1px solid var(--lead);filter:saturate(.94) brightness(.92)}
.intro-img figcaption{margin-top:.5rem;font-size:.74rem;color:var(--muted)}
.sec-head{margin-bottom:2.5rem}
.sec-head .intro{max-width:60ch;color:var(--cream-dim);margin-top:.6rem}

.leist-block{margin-bottom:3rem}
.leist-block:last-child{margin-bottom:0}
.leist-block .lead-row h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--cream);margin:0 0 .25rem}
.leist-block .lead-row p{margin:0;color:var(--cream-dim);font-size:.92rem;max-width:58ch}
.mini3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.mini3 .gal-item{aspect-ratio:4/3;overflow:hidden;border:1px solid var(--lead);position:relative}
.mini3 .gal-item img{width:100%;height:100%;object-fit:cover;filter:saturate(.94) brightness(.85);transition:transform .9s,filter .4s}
.mini3 .gal-item:hover img{transform:scale(1.06);filter:saturate(1) brightness(1)}
.mini3 .gal-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.2rem .6rem .55rem;font-size:.68rem;color:var(--cream);background:linear-gradient(transparent,rgba(13,15,18,.95));opacity:0;transition:.3s}
.mini3 .gal-item:hover figcaption{opacity:1}

/* Kontaktformular */
.kontakt-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;max-width:1000px;margin:0 auto;align-items:start}
.k-info h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--cream);margin-bottom:1rem}
.k-info p{color:var(--cream-dim);margin-bottom:1rem;line-height:1.7}
.k-info a{color:var(--gold)}
.k-form{display:flex;flex-direction:column;gap:1rem}
.k-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--cream-dim)}
.k-form input,.k-form textarea{background:var(--ink-2);border:1px solid var(--lead);color:var(--cream);padding:.8rem 1rem;font-family:inherit;font-size:.95rem;border-radius:1px;transition:border-color .3s}
.k-form input:focus,.k-form textarea:focus{outline:none;border-color:var(--gold)}
.k-form .btn{align-self:flex-start;margin-top:.5rem;cursor:pointer}
.form-note{font-size:.78rem;color:var(--muted);text-transform:none;letter-spacing:0}

@media(max-width:780px){
  .mini3{grid-template-columns:1fr 1fr 1fr}
  /* Mobile: Bildunterschrift UNTER das Bild statt als Overlay */
  .mini3{gap:.6rem}
  .mini3 .gal-item{aspect-ratio:auto;border:none;position:static;display:flex;flex-direction:column}
  .mini3 .gal-item img{aspect-ratio:4/3;object-fit:cover;border:1px solid var(--lead)}
  .mini3 .gal-item figcaption{position:static;opacity:1;background:none;padding:.4rem .1rem 0;color:var(--muted);font-size:.66rem;line-height:1.3;transform:none}
  .leist-block .lead-row{flex-direction:column;align-items:flex-start;gap:.8rem}
  .kontakt-grid{grid-template-columns:1fr;gap:2rem}
}

/* ============================================================
   Publikationen — aufklappbare Gruppen · MMC-Werbung
   ============================================================ */
.pub-group{border:1px solid var(--lead);border-radius:2px;margin-bottom:1rem;background:var(--ink-2);overflow:hidden}
.pub-group summary{cursor:pointer;padding:1.1rem 1.4rem;font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--cream);list-style:none;display:flex;justify-content:space-between;align-items:center;transition:color .25s}
.pub-group summary::-webkit-details-marker{display:none}
.pub-group summary::after{content:"+";color:var(--gold);font-size:1.4rem;transition:transform .3s}
.pub-group[open] summary::after{transform:rotate(45deg)}
.pub-group summary:hover{color:var(--gold)}
.pub-count{font-family:'Inter';font-size:.7rem;color:var(--muted);border:1px solid var(--lead);border-radius:10px;padding:.1rem .6rem;margin-left:auto;margin-right:1rem}
.pub-list{list-style:none;margin:0;padding:0 1.4rem 1.2rem}
.pub-list li{padding:.6rem 0;border-top:1px solid rgba(42,47,56,.5);color:var(--cream-dim);font-size:.88rem;line-height:1.5}
.pub-list li:first-child{border-top:none}

/* ============================================================
   FIX Mobile-Menü: deckender Hintergrund auf Unterseiten
   ============================================================ */
@media(max-width:980px){
  /* Header beim offenen Menü voll deckend + über allem */
  body.menu-open .site-head{background:#0d0f12;z-index:60}
  /* Logo + Burger über dem Menü sichtbar halten */
  .site-head .brand{z-index:61;position:relative}
  .burger{z-index:61;position:relative}
}

/* ============================================================
   Zeitstrahl-Scroll-Effekt: Einträge von links/rechts · MMC-Werbung
   ============================================================ */
.tl-item.reveal-left{opacity:0;transform:translateX(-60px);transition:opacity 1s cubic-bezier(.22,.61,.36,1),transform 1s cubic-bezier(.22,.61,.36,1)}
.tl-item.reveal-right{opacity:0;transform:translateX(60px);transition:opacity 1s cubic-bezier(.22,.61,.36,1),transform 1s cubic-bezier(.22,.61,.36,1)}
.tl-item.reveal-left.in,.tl-item.reveal-right.in{opacity:1;transform:none}
/* Rauten-Knoten am Zeitstrahl pulsiert kurz beim Erscheinen */
.tl-item::before{transition:background .5s ease,box-shadow .5s ease}
.tl-item.in::before{box-shadow:0 0 0 4px rgba(201,162,74,.12)}

@media(max-width:980px){
  /* Mobil: dezenter, kein horizontaler Überlauf */
  .tl-item.reveal-left{transform:translateX(-28px)}
  .tl-item.reveal-right{transform:translateX(28px)}
}
@media(prefers-reduced-motion:reduce){
  .tl-item.reveal-left,.tl-item.reveal-right{opacity:1;transform:none;transition:none}
}

/* ============================================================
   Hero-Text-Lesbarkeit · MMC-Werbung
   ============================================================ */
.hero-content .eyebrow{text-shadow:0 2px 12px rgba(0,0,0,.7)}
.hero-title{text-shadow:0 3px 24px rgba(0,0,0,.55)}
.hero-lede{text-shadow:0 2px 14px rgba(0,0,0,.7)}
	  /* ============================================================
   Hero-Text: lesbarer Glas-Kasten · MMC-Werbung
   ============================================================ */
.hero-content .inner,
.hero-inner{
  display:inline-block;
  max-width:640px;
  padding:1.8rem 2rem 1.9rem;
  background:linear-gradient(135deg,rgba(13,15,18,.74),rgba(13,15,18,.52));
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(201,162,74,.22);
  border-left:2px solid var(--gold);
  box-shadow:0 30px 80px -30px rgba(0,0,0,.9);
  border-radius:2px;
}
@media(max-width:540px){
  .hero-content .inner,
  .hero-inner{
    padding:1.4rem 1.3rem 1.5rem;
    background:linear-gradient(135deg,rgba(13,15,18,.82),rgba(13,15,18,.62));
  }
}


/* ============================================================
   Light & Scroll Effekte v2 (KRÄFTIG) · MMC-Werbung
   Stärker sichtbar + wirkt auch auf der Startseite (.hero)
   ============================================================ */

/* ---- 1) Scroll-Reveal seitenweit (deutlicher) ---- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s cubic-bezier(.22,.61,.36,1),transform 1s cubic-bezier(.22,.61,.36,1)}
.reveal.in{opacity:1;transform:none}

/* Absätze/Listen in .prose nacheinander einblenden (deutlicher Versatz) */
.prose.fx-stagger > *{opacity:0;transform:translateY(30px);transition:opacity .9s ease,transform .9s ease}
.prose.fx-stagger.in > *{opacity:1;transform:none}
.prose.fx-stagger.in > *:nth-child(2){transition-delay:.08s}
.prose.fx-stagger.in > *:nth-child(3){transition-delay:.16s}
.prose.fx-stagger.in > *:nth-child(4){transition-delay:.24s}
.prose.fx-stagger.in > *:nth-child(5){transition-delay:.32s}
.prose.fx-stagger.in > *:nth-child(n+6){transition-delay:.40s}

/* ---- 2) Gold-Lichtschein hinter Überschriften (KRÄFTIG) ----
   Jetzt auch auf der Startseite: .hero-title / .hero-inner h1 */
.page-hero .wrap h1,
.hero-content h1,.hero-title,
.section-head h2,
.prose > h2:first-child{position:relative}

.page-hero .wrap h1::before,
.hero-content h1::before,.hero-title::before,
.section-head h2::before,
.prose > h2:first-child::before{
  content:"";position:absolute;z-index:-1;
  left:-14%;top:50%;width:84%;height:300%;
  transform:translateY(-50%);
  background:radial-gradient(ellipse at left center,
    rgba(201,162,74,.55),rgba(201,162,74,.20) 42%,transparent 72%);
  filter:blur(22px);pointer-events:none;
  opacity:0;transition:opacity 1.1s ease .15s;
}
/* Startseiten-Hero sofort leuchten lassen (kein Scroll nötig) */
.hero-content h1::before,.hero-title::before{opacity:1;animation:glowPulse 5s ease-in-out 1s infinite}

.page-hero .wrap h1.glow::before,
.section-head h2.glow::before,
.prose > h2:first-child.glow::before{opacity:1}
.page-hero .wrap h1.glow::before{animation:glowPulse 5s ease-in-out 1.2s infinite}
@keyframes glowPulse{0%,100%{opacity:.7}50%{opacity:1}}

/* ---- 3) Shimmer-Lichtkante auf Bildern (kräftiger) ---- */
.fade-band,.intro-figure img,.intro-img img,.figure-wide,.gal-item,.mini3 .gal-item,.fx-shimmer{position:relative;overflow:hidden}
.fade-band::after,
.fx-shimmer::after,
.gal-item::before,
.mini3 .gal-item::before{
  content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(105deg,
    transparent 28%,
    rgba(255,250,235,.18) 45%,
    rgba(255,250,235,.42) 50%,
    rgba(255,250,235,.18) 55%,
    transparent 72%);
  transform:translateX(-130%);
}
.fade-band.shimmer::after,
.fx-shimmer.shimmer::after,
.gal-item.shimmer::before,
.mini3 .gal-item.shimmer::before{animation:shimmer 1.4s ease-out}
@keyframes shimmer{from{transform:translateX(-130%)}to{transform:translateX(130%)}}

/* ---- 4) Ken-Burns Zoom (etwas kräftiger) ---- */
.page-hero .bg{animation:kb 22s ease-in-out infinite alternate}
.fade-band.has-kb{background-size:cover;animation:kbBand 26s ease-in-out infinite alternate}
@keyframes kb{0%{transform:scale(1.05)}100%{transform:scale(1.16) translate(-1.5%,-1.5%)}}
@keyframes kbBand{0%{background-size:110%}100%{background-size:126%}}

/* Goldrahmen beim Reveal auf fade-band */
.fade-band{position:relative}
.fade-band.in{box-shadow:inset 0 0 0 1px rgba(201,162,74,.30)}

@media(prefers-reduced-motion:reduce){
  .reveal,.prose.fx-stagger > *{opacity:1!important;transform:none!important;transition:none!important}
  .page-hero .wrap h1::before,.hero-content h1::before,.hero-title::before,
  .section-head h2::before,.prose > h2:first-child::before{opacity:1;animation:none}
  .page-hero .bg,.fade-band.has-kb{animation:none}
  .fade-band::after,.fx-shimmer::after,.gal-item::before,.mini3 .gal-item::before{display:none}
}

/* ============================================================
   Leistungs-Kacheln: Bild beim Hover · MMC-Werbung
   ============================================================ */
.related-card.svc-hover{position:relative;overflow:hidden;isolation:isolate}
.related-card.svc-hover::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background-image:var(--i);background-size:cover;background-position:center;
  opacity:0;transform:scale(1.08);
  transition:opacity .7s ease,transform 1.4s ease;
}
.related-card.svc-hover::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(13,15,18,.78),rgba(13,15,18,.88));
  opacity:0;transition:opacity .7s ease;
}
.related-card.svc-hover:hover::before{opacity:.55;transform:scale(1)}
.related-card.svc-hover:hover::after{opacity:1}
.related-card.svc-hover:hover{background:transparent;border-color:rgba(201,162,74,.6)}
/* Text bleibt beim Hover gut lesbar */
.related-card.svc-hover:hover h3,
.related-card.svc-hover:hover .eyebrow,
.related-card.svc-hover:hover .more{color:var(--cream)}
.related-card.svc-hover:hover .more{color:var(--gold)}
.related-card.svc-hover:hover p{color:var(--cream)}

/* Touch-Geräte: Bild dezent dauerhaft andeuten (kein Hover vorhanden) */
@media(hover:none){
  .related-card.svc-hover::before{opacity:.12;transform:scale(1)}
  .related-card.svc-hover::after{opacity:.9}
}

/* ============================================================
   Ausbildung: Lichtbild läuft vom Rand ins Schwarz · MMC-Werbung
   ============================================================ */
.page-sec.has-sidelight{position:relative;overflow:hidden}
.page-sec.has-sidelight::before{
  content:"";position:absolute;z-index:0;pointer-events:none;
  top:0;bottom:0;right:0;width:42%;
  background-image:var(--side);
  background-size:cover;background-position:center;
  opacity:.22;
  /* nach links hin ins Seitenschwarz ausblenden */
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.4) 40%,#000 100%);
          mask-image:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.4) 40%,#000 100%);
}
/* zusätzlicher dunkler Schleier, damit Text immer lesbar bleibt */
.page-sec.has-sidelight::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(90deg,var(--ink) 30%,rgba(13,15,18,.4) 70%,rgba(13,15,18,.2));
}
.page-sec.has-sidelight .wrap{position:relative;z-index:1}

/* Mobil: Bild als ganz blasser Vollflächen-Hauch hinter dem Text */
@media(max-width:780px){
  .page-sec.has-sidelight::before{width:100%;opacity:.10;
    -webkit-mask-image:linear-gradient(180deg,transparent,#000 40%,#000 60%,transparent);
            mask-image:linear-gradient(180deg,transparent,#000 40%,#000 60%,transparent);}
  .page-sec.has-sidelight::after{background:linear-gradient(180deg,rgba(13,15,18,.85),rgba(13,15,18,.7))}
}
@media(prefers-reduced-motion:reduce){
  .related-card.svc-hover::before{transition:opacity .3s ease}
}

/* ============================================================
   Intro-Overlay — "Durch das Fenster treten" · MMC-Werbung
   Nur Startseite. Zoom + Ausblenden beim Scrollen.
   ============================================================ */
.intro-gate{
  position:fixed;inset:0;z-index:300;
  display:flex;align-items:center;justify-content:center;
  background:var(--ink);
  overflow:hidden;
  will-change:opacity;
}
.intro-gate.gone{opacity:0;pointer-events:none;visibility:hidden;transition:opacity .6s ease,visibility 0s .6s}

/* Das Glasfenster-Bild, das herangezoomt wird */
.intro-gate .ig-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transform:scale(1);
  will-change:transform,filter;
  filter:brightness(.62) saturate(1.05);
}
/* dunkler Rand-Vignette + Verlauf unten für Lesbarkeit */
.intro-gate::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse at center,transparent 40%,rgba(13,15,18,.55) 100%),
    linear-gradient(180deg,rgba(13,15,18,.4),transparent 30%,transparent 65%,rgba(13,15,18,.75));
}

/* Inhalt mittig: Logo + Claim */
.intro-gate .ig-content{
  position:relative;z-index:2;text-align:center;
  padding:2rem;max-width:680px;
  animation:igRise 1.4s cubic-bezier(.22,.61,.36,1) both;
}
.intro-gate .ig-logo{height:clamp(64px,12vw,104px);width:auto;margin:0 auto 1.6rem;
  filter:drop-shadow(0 4px 24px rgba(0,0,0,.8));}
.intro-gate .ig-eyebrow{
  font-family:'Inter',sans-serif;font-weight:500;font-size:clamp(.66rem,1.6vw,.8rem);
  letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
  display:block;margin-bottom:1rem;text-shadow:0 2px 12px rgba(0,0,0,.8);}
.intro-gate .ig-title{
  font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;
  font-size:clamp(2.4rem,7vw,5rem);line-height:1.05;color:var(--cream);
  text-shadow:0 3px 30px rgba(0,0,0,.7);}
.intro-gate .ig-title em{font-style:italic;color:var(--gold)}

/* Scroll-Hinweis unten */
.intro-gate .ig-hint{
  position:absolute;left:50%;bottom:2.2rem;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  color:var(--cream-dim);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;
  animation:igHintFade 2.4s ease 1s both;}
.intro-gate .ig-hint::after{
  content:"";width:1px;height:42px;
  background:linear-gradient(var(--gold),transparent);
  animation:igPulse 2s ease infinite;}

@keyframes igRise{from{opacity:0;transform:translateY(30px) scale(.98)}to{opacity:1;transform:none}}
@keyframes igHintFade{from{opacity:0}to{opacity:1}}
@keyframes igPulse{0%,100%{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}

/* Sperrt Scrollen der Seite, solange Gate aktiv (sanft) */
body.intro-active{overflow:hidden;height:100vh}

@media(prefers-reduced-motion:reduce){
  .intro-gate .ig-content,.intro-gate .ig-hint{animation:none}
  .intro-gate .ig-img{filter:brightness(.62)}
}

/* ============================================================
   Header-Lesbarkeit im transparenten Zustand · MMC-Werbung
   Dezenter Schatten-Verlauf von oben, schützt das Menü auf
   hellen Hero-Bildern — noch bevor der Header beim Scrollen
   komplett dunkel wird.
   ============================================================ */
.site-head::before{
  content:"";position:absolute;inset:0 0 auto 0;z-index:-1;
  height:140%;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(13,15,18,.78) 0%,
    rgba(13,15,18,.45) 45%,
    rgba(13,15,18,0) 100%);
  opacity:1;transition:opacity .4s ease;
}
/* Sobald der Header dunkel wird, ist der Verlauf nicht mehr nötig */
.site-head.solid::before,
.site-head.scrolled::before{opacity:0}