/* ============================================================
   Milo Ritzbilder — stylesheet
   Polished-granite aesthetic: charcoal base, gold accent,
   Cormorant Garamond display + Manrope body + Space Mono labels.
   ============================================================ */

:root{
  --granite:#141317;
  --granite-deep:#0d0c0f;
  --granite-soft:#1e1c22;
  --bone:#ece6da;
  --bone-dim:#a7a194;
  --pewter:#6c665d;
  --gold:#c9a86a;
  --gold-soft:#d8be8d;
  --line:rgba(236,230,218,0.13);
  --display:'Cormorant Garamond',Georgia,serif;
  --body:'Manrope',-apple-system,sans-serif;
  --mono:'Space Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--granite);
  color:var(--bone);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* polished granite speckle + grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(1px 1px at 20% 30%, rgba(236,230,218,0.10), transparent),
    radial-gradient(1px 1px at 70% 60%, rgba(201,168,106,0.10), transparent),
    radial-gradient(1px 1px at 40% 80%, rgba(236,230,218,0.08), transparent),
    radial-gradient(1px 1px at 85% 15%, rgba(236,230,218,0.07), transparent),
    radial-gradient(1px 1px at 55% 45%, rgba(201,168,106,0.07), transparent);
  background-size:340px 340px;opacity:.6;
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:0.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
::selection{background:var(--gold);color:var(--granite-deep)}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px;position:relative;z-index:1}

/* Accessibility: skip link + focus rings */
.skip-link{
  position:absolute;left:16px;top:-60px;z-index:200;
  background:var(--gold);color:var(--granite-deep);
  padding:10px 18px;border-radius:2px;font-family:var(--mono);
  font-size:.8rem;text-decoration:none;transition:top .25s ease;
}
.skip-link:focus{top:16px}
a:focus-visible,button:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}

/* ---------- NAV ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 32px;transition:all .4s ease;
}
nav.scrolled{background:rgba(13,12,15,0.82);backdrop-filter:blur(14px);padding:15px 32px;box-shadow:0 1px 0 var(--line)}
.brand{font-family:var(--display);font-weight:600;font-size:1.5rem;letter-spacing:.04em;color:var(--bone);text-decoration:none}
.brand span{color:var(--gold)}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links a{color:var(--bone-dim);text-decoration:none;font-size:.74rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;font-family:var(--mono);position:relative;transition:color .3s}
.nav-links a:hover{color:var(--bone)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .35s ease}
.nav-links a:hover::after{width:100%}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--bone)}

/* ---------- HERO ---------- */
header{position:relative;min-height:100vh;display:flex;align-items:center;padding:120px 0 80px;overflow:hidden;background:radial-gradient(120% 80% at 75% 30%, rgba(201,168,106,0.08), transparent 55%)}
.hero-content{position:relative;z-index:2}
.hero-eyebrow{font-family:var(--mono);color:var(--gold);font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;margin-bottom:30px;opacity:0;animation:rise .9s .2s ease forwards}
.hero-title{font-family:var(--display);font-weight:500;font-size:clamp(3rem,9vw,7.2rem);line-height:0.95;letter-spacing:-0.01em}
.hero-title .ln{display:block;overflow:hidden}
.hero-title .ln span{display:block;opacity:0;transform:translateY(110%);animation:slideUp 1s ease forwards}
.hero-title .ln:nth-child(1) span{animation-delay:.35s}
.hero-title .ln:nth-child(2) span{animation-delay:.5s}
.hero-title .ln:nth-child(3) span{animation-delay:.65s}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-sub{color:var(--bone-dim);font-size:clamp(1.02rem,1.5vw,1.18rem);max-width:50ch;margin-top:36px;font-weight:300;opacity:0;animation:rise .9s .95s ease forwards}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap;margin-top:42px;opacity:0;animation:rise .9s 1.1s ease forwards}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;text-decoration:none;font-weight:500;font-size:.88rem;letter-spacing:.04em;border-radius:2px;transition:all .3s ease;cursor:pointer;border:none;font-family:var(--body)}
.btn-primary{background:var(--gold);color:var(--granite-deep)}
.btn-primary:hover{background:var(--gold-soft);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line);color:var(--bone);background:none}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ---------- SECTIONS ---------- */
section{padding:clamp(80px,12vh,150px) 0;position:relative;z-index:1}
.sec-head{display:flex;align-items:baseline;gap:16px;margin-bottom:60px;flex-wrap:wrap}
.sec-num{font-family:var(--mono);color:var(--gold);font-size:.8rem;letter-spacing:.1em}
.sec-title{font-family:var(--display);font-weight:500;font-size:clamp(2.1rem,4.6vw,3.6rem);line-height:1.04;letter-spacing:-0.01em;max-width:20ch}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- INTRO ---------- */
.intro-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:center}
.intro-lead{font-family:var(--display);font-weight:400;font-size:clamp(1.6rem,2.7vw,2.3rem);line-height:1.32}
.intro-lead em{font-style:italic;color:var(--gold)}
.intro-body p{color:var(--bone-dim);font-size:1.05rem;margin-bottom:18px}
.intro-body p:last-child{margin-bottom:0}

/* ---------- LEISTUNGEN ---------- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.service{background:var(--granite);padding:44px 34px;transition:background .4s ease}
.service:hover{background:var(--granite-soft)}
.service-no{font-family:var(--mono);color:var(--gold);font-size:.78rem;margin-bottom:24px;letter-spacing:.1em}
.service h3{font-family:var(--display);font-weight:600;font-size:1.7rem;margin-bottom:12px;line-height:1.1}
.service p{color:var(--bone-dim);font-size:.97rem}
.service .tag{display:inline-block;margin-top:18px;font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;color:var(--pewter);text-transform:uppercase;border:1px solid var(--line);padding:5px 10px;border-radius:2px}

/* ---------- TWO MODES ---------- */
.modes{background:var(--granite-deep)}
.modes-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:10px}
.mode{border:1px solid var(--line);border-radius:3px;padding:46px 40px;position:relative;overflow:hidden;background:linear-gradient(160deg,var(--granite-soft),var(--granite))}
.mode::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--gold)}
.mode .mode-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.mode h3{font-family:var(--display);font-weight:500;font-size:2rem;line-height:1.1;margin-bottom:16px}
.mode p{color:var(--bone-dim);font-size:1rem}
.mode .spec{margin-top:22px;font-family:var(--mono);font-size:.82rem;color:var(--bone)}

/* ---------- ABLAUF ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.step{position:relative;padding-top:30px;border-top:1px solid var(--line)}
.step .n{font-family:var(--mono);color:var(--gold);font-size:.9rem;position:absolute;top:-11px;background:var(--granite);padding-right:12px}
.step h4{font-family:var(--display);font-weight:600;font-size:1.45rem;margin-bottom:8px;margin-top:6px}
.step p{color:var(--bone-dim);font-size:.92rem}

/* ---------- ARBEITEN (GALLERY) ---------- */
.gallery{background:var(--granite-deep)}
/* Shared tile look (used by featured cover-grid + full masonry) */
.tile{
  position:relative;overflow:hidden;border-radius:2px;display:block;
  background:linear-gradient(135deg,#26242a,#131216);
  padding:0;border:1px solid var(--line);
  cursor:pointer;width:100%;text-align:left;font-family:inherit;color:inherit;
  transition:transform .4s ease,border-color .4s ease;
}
.tile:hover{transform:translateY(-3px);border-color:rgba(201,168,106,0.4)}
.tile:not(.has-photo){cursor:default}
.tile:not(.has-photo):hover{transform:none;border-color:var(--line)}
.tile:not(.has-photo)::before{content:"";position:absolute;inset:0;opacity:.4;background:repeating-linear-gradient(118deg, rgba(236,230,218,0.05) 0 1px, transparent 1px 18px);z-index:1}
/* soft gold wash on hover only */
.tile.has-photo::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:0;transition:opacity .4s ease;background:linear-gradient(to top, rgba(201,168,106,.14), transparent 55%)}
.tile.has-photo:hover::after{opacity:1}

/* FEATURED — Startseite: styled cover grid, a rotating random selection */
.featured-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;grid-auto-rows:200px}
.featured-grid .tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease,opacity .55s ease}
.featured-grid .tile.has-photo:hover img{transform:scale(1.04)}
.featured-grid .tile.is-swapping img{opacity:0}          /* crossfade during live rotation */
.featured-grid .tile.t1{grid-column:span 7;grid-row:span 2}
.featured-grid .tile.t2{grid-column:span 5}
.featured-grid .tile.t3{grid-column:span 5}
.featured-grid .tile.t4{grid-column:span 4}
.featured-grid .tile.t5{grid-column:span 4}
.featured-grid .tile.t6{grid-column:span 4}
.gallery-cta{margin-top:30px}

/* Standalone gallery page: clear the fixed nav */
.gallery-page{padding:132px 0 96px;min-height:80vh}
.gallery-page .back-link{display:inline-block;margin-top:40px}

/* FULL GALLERY — galerie.html: masonry, tiles keep natural aspect ratio */
.gallery-grid{column-count:3;column-gap:14px}
.gallery-grid .tile{break-inside:avoid;margin:0 0 14px}
.gallery-grid .tile img{display:block;width:100%;height:auto;transition:transform .6s ease}
.gallery-grid .tile.has-photo:hover img{transform:scale(1.04)}

/* status line while the library loads / if it can't be reached */
.gallery-status{font-family:var(--mono);font-size:.8rem;letter-spacing:.06em;color:var(--pewter);margin:6px 0 22px}
.gallery-status[hidden]{display:none}
.gallery-note{margin-top:28px;font-family:var(--mono);font-size:.78rem;color:var(--pewter);border-left:2px solid var(--gold);padding-left:16px}

/* ---------- LIGHTBOX ---------- */
.lb{
  position:fixed;inset:0;z-index:1000;display:none;
  align-items:center;justify-content:center;
  background:rgba(8,7,9,0.94);backdrop-filter:blur(6px);
  padding:5vh 5vw;
}
.lb.open{display:flex;animation:lbFade .25s ease}
.lb-figure{position:relative;max-width:100%;max-height:100%;display:flex;flex-direction:column;align-items:center;gap:16px}
.lb img{max-width:100%;max-height:80vh;object-fit:contain;border:1px solid var(--line);border-radius:2px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb figcaption{font-family:var(--mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-dim)}
.lb-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(20,19,23,0.7);border:1px solid var(--line);color:var(--bone);
  width:48px;height:48px;border-radius:50%;cursor:pointer;font-size:1.4rem;
  display:flex;align-items:center;justify-content:center;transition:all .25s ease;
}
.lb-btn:hover{border-color:var(--gold);color:var(--gold)}
.lb-prev{left:-8px}
.lb-next{right:-8px}
.lb-close{
  position:fixed;top:24px;right:28px;width:46px;height:46px;border-radius:50%;
  background:rgba(20,19,23,0.7);border:1px solid var(--line);color:var(--bone);
  cursor:pointer;font-size:1.5rem;line-height:1;transition:all .25s ease;
}
.lb-close:hover{border-color:var(--gold);color:var(--gold)}

/* ---------- KONTAKT ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px}
.contact-info dt{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;margin-top:32px}
.contact-info dt:first-child{margin-top:0}
.contact-info dd{font-family:var(--display);font-size:1.65rem;font-weight:500}
.contact-info dd a{color:inherit;text-decoration:none;border-bottom:1px solid var(--line)}
.contact-info dd a:hover{color:var(--gold)}
.contact-info dd.small{font-family:var(--body);font-size:1.02rem;font-weight:400;color:var(--bone-dim);line-height:1.7}
.contact-side{border:1px solid var(--line);border-radius:3px;padding:46px 40px;background:linear-gradient(160deg,var(--granite-soft),var(--granite));align-self:start}
.contact-side h3{font-family:var(--display);font-size:1.9rem;font-weight:500;margin-bottom:14px}
.contact-side p{color:var(--bone-dim);font-size:1rem;margin-bottom:24px}

/* ---------- FOOTER ---------- */
footer{background:var(--granite-deep);padding:56px 0 38px;border-top:1px solid var(--line)}
.foot-grid{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
.foot-brand{font-family:var(--display);font-size:1.9rem;color:var(--bone);font-weight:500}
.foot-brand span{color:var(--gold)}
.foot-meta{font-family:var(--mono);font-size:.74rem;line-height:1.95;color:var(--pewter)}
.foot-meta a{color:var(--bone-dim);text-decoration:none}
.foot-meta a:hover{color:var(--gold)}

/* ---------- LEGAL PAGES ---------- */
.legal{padding:160px 0 100px;min-height:80vh}
.legal .eyebrow{font-family:var(--mono);color:var(--gold);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px}
.legal h1{font-family:var(--display);font-weight:500;font-size:clamp(2.3rem,5vw,3.4rem);line-height:1.05;margin-bottom:40px}
.legal h2{font-family:var(--display);font-weight:600;font-size:1.5rem;margin:40px 0 14px}
.legal p,.legal li{color:var(--bone-dim);font-size:1.02rem;margin-bottom:14px;max-width:70ch}
.legal ul{padding-left:22px;margin-bottom:14px}
.legal a{color:var(--gold);text-decoration:none;border-bottom:1px solid var(--line)}
.legal a:hover{border-color:var(--gold)}
.ph{color:var(--gold-soft);background:rgba(201,168,106,0.10);padding:1px 7px;border-radius:2px;font-family:var(--mono);font-size:.92em}
.legal dl{margin-bottom:20px}
.legal dt{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-top:20px}
.legal dd{font-size:1.05rem;color:var(--bone)}
.back-link{display:inline-flex;align-items:center;gap:8px;margin-top:50px;font-family:var(--mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--bone-dim);text-decoration:none}
.back-link:hover{color:var(--gold)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:860px){
  .nav-links{position:fixed;inset:0;background:var(--granite-deep);flex-direction:column;justify-content:center;gap:30px;transform:translateX(100%);transition:transform .4s ease}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.05rem}
  .nav-toggle{display:block;z-index:101}
  .intro-grid,.contact-grid,.modes-grid{grid-template-columns:1fr;gap:36px}
  .services{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr;gap:34px 24px}
  .gallery-grid{column-count:2}
  .featured-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .featured-grid .tile.t1,.featured-grid .tile.t2,.featured-grid .tile.t3,.featured-grid .tile.t4,.featured-grid .tile.t5,.featured-grid .tile.t6{grid-column:span 1;grid-row:span 1}
  .featured-grid .tile.t1{grid-column:span 2}
  .lb-prev{left:4px}.lb-next{right:4px}
}

@keyframes slideUp{to{opacity:1;transform:none}}
@keyframes rise{to{opacity:1;transform:none}}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .hero-title .ln span,.hero-eyebrow,.hero-sub,.hero-actions{opacity:1;transform:none}
}

/* ============================================================
   Redesign pass — taste-skill elevation (additive overrides)
   Depth, cursor-tracked spotlight, staggered entry, pressed
   states, tinted shadows, dvh viewport, balanced text wrapping.
   ============================================================ */

/* viewport: kill the iOS Safari 100vh address-bar jump */
header{min-height:100dvh}
.legal{min-height:80dvh}

/* typography: balance headlines, prevent body orphans */
.hero-title,.sec-title,.intro-lead,.service h3,.mode h3,.contact-side h3,.legal h1{text-wrap:balance}
.hero-sub,.intro-body p,.service p,.mode p,.contact-side p,.step p,.legal p{text-wrap:pretty}

/* ambient gold light pooling into otherwise-flat sections */
#leistungen{background:radial-gradient(78% 60% at 10% 2%,rgba(201,168,106,0.055),transparent 58%)}
#vorteile{background:radial-gradient(70% 62% at 92% 8%,rgba(201,168,106,0.055),transparent 58%)}
#ablauf{background:radial-gradient(64% 72% at 50% 0%,rgba(201,168,106,0.045),transparent 56%)}
#kontakt{background:radial-gradient(60% 70% at 88% 12%,rgba(201,168,106,0.05),transparent 60%)}

/* buttons: gold-tinted lift shadow + physical pressed feedback */
.btn-primary{box-shadow:0 12px 32px -16px rgba(201,168,106,0.6)}
.btn-primary:hover{box-shadow:0 18px 40px -16px rgba(201,168,106,0.72)}
.btn:active{transform:translateY(0) scale(.985)}

/* cards: cursor-tracked spotlight glow (set via --mx/--my in main.js) */
.service{position:relative;isolation:isolate}
.service>*{position:relative;z-index:1}
.service::after{content:"";position:absolute;inset:0;z-index:0;opacity:0;pointer-events:none;
  background:radial-gradient(220px circle at var(--mx,50%) var(--my,50%),rgba(201,168,106,0.15),transparent 60%);
  transition:opacity .35s ease}
.service:hover::after{opacity:1}

/* elevated panels: tinted depth shadow + spotlight */
.mode,.contact-side{isolation:isolate;box-shadow:0 28px 64px -36px rgba(8,7,9,0.95)}
.mode>*,.contact-side>*{position:relative;z-index:1}
.mode::after,.contact-side::after{content:"";position:absolute;inset:0;z-index:0;opacity:0;pointer-events:none;
  border-radius:inherit;
  background:radial-gradient(340px circle at var(--mx,50%) var(--my,50%),rgba(201,168,106,0.12),transparent 62%);
  transition:opacity .4s ease}
.mode:hover::after,.contact-side:hover::after{opacity:1}

/* gallery: tinted elevation + lighter scrim so the engravings read */
.tile{box-shadow:0 20px 44px -30px rgba(8,7,9,0.95)}
.tile.has-photo img{filter:brightness(1.05) contrast(1.02)}
.tile.has-photo::after{background:linear-gradient(to top,rgba(201,168,106,0.16),transparent 55%)}

/* nav scrollspy: mark the section you're in */
.nav-links a.active{color:var(--bone)}
.nav-links a.active::after{width:100%}

/* staggered card entry — never mount a whole row at once */
.services.reveal .service,.modes-grid.reveal .mode,.steps.reveal .step{
  opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.services.reveal.in .service,.modes-grid.reveal.in .mode,.steps.reveal.in .step{opacity:1;transform:none}
.services.reveal.in .service:nth-child(2),.modes-grid.reveal.in .mode:nth-child(2),.steps.reveal.in .step:nth-child(2){transition-delay:.08s}
.services.reveal.in .service:nth-child(3),.steps.reveal.in .step:nth-child(3){transition-delay:.16s}
.services.reveal.in .service:nth-child(4),.steps.reveal.in .step:nth-child(4){transition-delay:.24s}
.services.reveal.in .service:nth-child(5){transition-delay:.32s}
.services.reveal.in .service:nth-child(6){transition-delay:.40s}

@media(prefers-reduced-motion:reduce){
  .services .service,.modes-grid .mode,.steps .step{opacity:1!important;transform:none!important}
}

/* ---------- 404 ---------- */
.legal.err{display:flex;flex-direction:column;justify-content:center;text-align:left}
.err-lead{font-size:1.12rem;color:var(--bone-dim);max-width:54ch;margin-bottom:36px}
.err-actions{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:8px}
/* buttons inside .legal must keep their own text colour, not the .legal a gold */
.legal .btn-primary{color:var(--granite-deep);border-bottom:none}
.legal .btn-ghost{color:var(--bone);border-bottom:none}
.legal .btn-ghost:hover{color:var(--gold)}

/* ============================================================
   2026-07 refresh: hero photo, compare slider, stats band,
   card spotlight (uses --mx/--my from main.js), WhatsApp CTA
   ============================================================ */

/* ---------- HERO PHOTO ---------- */
.hero-photo{position:absolute;inset:0;z-index:0}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center 38%;opacity:.34;filter:saturate(.85)}
.hero-photo::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(13,12,15,.92) 0%, rgba(13,12,15,.55) 48%, rgba(13,12,15,.25) 100%),
    linear-gradient(to top, var(--granite) 0%, transparent 30%),
    linear-gradient(to bottom, rgba(13,12,15,.6) 0%, transparent 22%);
}

/* ---------- CARD SPOTLIGHT (was dead code: JS sets --mx/--my) ---------- */
.service,.mode,.contact-side{position:relative}
.service::after,.mode::after,.contact-side::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:0;
  background:radial-gradient(220px circle at var(--mx,50%) var(--my,50%), rgba(201,168,106,0.10), transparent 65%);
  transition:opacity .4s ease;
}
.service:hover::after,.mode:hover::after,.contact-side:hover::after{opacity:1}

/* ---------- VORHER/NACHHER (compare slider) ---------- */
.compare-sec{background:var(--granite-deep)}
.compare-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:70px;align-items:center}
.compare{
  position:relative;aspect-ratio:4/5;max-height:560px;overflow:hidden;
  border:1px solid var(--line);border-radius:3px;background:var(--granite-soft);
  --pos:50%;
}
.compare .cmp-after{position:absolute;inset:0}
.compare .cmp-after img{width:100%;height:100%;object-fit:cover;display:block}
.compare .cmp-before{
  position:absolute;inset:0;z-index:2;
  clip-path:inset(0 calc(100% - var(--pos)) 0 0);
  background:
    repeating-linear-gradient(118deg, rgba(236,230,218,0.04) 0 1px, transparent 1px 16px),
    linear-gradient(150deg,#26242a,#141317);
}
.compare img.cmp-before{clip-path:inset(0 calc(100% - var(--pos)) 0 0);object-fit:cover;width:100%;height:100%;background:none}
.cmp-ph{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;color:var(--pewter);
}
.cmp-ph span{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase}
.cmp-handle{
  position:absolute;top:0;bottom:0;left:var(--pos);z-index:3;width:2px;
  background:var(--gold);transform:translateX(-1px);pointer-events:none;
}
.cmp-handle span{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:44px;height:44px;border-radius:50%;background:var(--granite-deep);
  border:1px solid var(--gold);color:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:.95rem;letter-spacing:-.05em;
}
.cmp-range{
  position:absolute;inset:0;z-index:4;width:100%;height:100%;
  opacity:0;cursor:ew-resize;margin:0;-webkit-appearance:none;appearance:none;
}
.cmp-range:focus-visible ~ .cmp-handle span,
.compare:has(.cmp-range:focus-visible) .cmp-handle span{outline:2px solid var(--gold);outline-offset:3px}
.cmp-label{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.cmp-tag{
  position:absolute;bottom:14px;z-index:3;pointer-events:none;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(13,12,15,.72);border:1px solid var(--line);border-radius:2px;
  padding:5px 10px;color:var(--bone-dim);
}
.cmp-tag-l{left:14px}
.cmp-tag-r{right:14px;color:var(--gold);border-color:rgba(201,168,106,.4)}
.compare-copy p:not(.intro-lead){color:var(--bone-dim);font-size:1.05rem;margin-top:22px}

/* ---------- STATS BAND + ASSURANCES ---------- */
.stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.stat{background:var(--granite);padding:38px 30px}
.stat-n{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,4.5vw,3.8rem);line-height:1;color:var(--bone)}
.stat-n span{color:var(--gold);font-size:.55em;font-style:italic;margin-left:2px}
.stat-l{color:var(--bone-dim);font-size:.92rem;margin-top:12px;max-width:24ch}
.assurances{list-style:none;margin-top:44px;display:grid;grid-template-columns:repeat(3,1fr);gap:34px;padding:0}
.assurances li{color:var(--bone-dim);font-size:.97rem;border-top:1px solid var(--line);padding-top:18px}
.assurances strong{color:var(--bone);font-weight:600}

/* ---------- WHATSAPP CTA ---------- */
.contact-ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn-whatsapp{border:1px solid rgba(201,168,106,.45);color:var(--gold);background:none}
.btn-whatsapp:hover{background:rgba(201,168,106,.08);border-color:var(--gold)}

/* ---------- RESPONSIVE (refresh) ---------- */
@media(max-width:860px){
  .compare-grid{grid-template-columns:1fr;gap:40px}
  .compare{max-height:none;aspect-ratio:3/4}
  .stats{grid-template-columns:1fr 1fr}
  .assurances{grid-template-columns:1fr;gap:22px}
  .hero-photo img{object-position:center}
}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-eyebrow,.hero-sub,.hero-actions,.hero-title .ln span{animation:none;opacity:1;transform:none}
}

/* ---------- HERO VIDEO (progressive enhancement, injected by JS) ---------- */
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 38%;
  opacity:0;transition:opacity 1.2s ease;filter:saturate(.85);
}
.hero-video.playing{opacity:.34}
