/* ═══════════════════════════════════════════════════════════
   MV Media — Maurice Veith
   Shared stylesheet for all pages
═══════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#090909;
  --bg2:#111111;
  --bg3:#191919;
  --line:rgba(255,255,255,0.07);
  --line2:rgba(255,255,255,0.14);
  --text:#EBEBEB;
  --dim:#666;
  --mid:#999;
  --acc:#C8A96E;
  --acc2:rgba(200,169,110,0.12);
  --f-head:'Syne',sans-serif;
  --f-body:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:var(--f-body);font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh}
::selection{background:var(--acc);color:#000}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .r{opacity:1!important;transform:none!important}
}

/* ── Focus visible ── */
:focus-visible{outline:2px solid var(--acc);outline-offset:3px;border-radius:2px}
button:focus-visible,a:focus-visible{outline:2px solid var(--acc);outline-offset:3px}

/* ── MOBILE OVERLAY ── */
.mob-overlay{position:fixed;inset:0;background:rgba(8,8,8,.98);backdrop-filter:blur(20px);z-index:98;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;overflow-y:auto;padding:5rem 1.5rem}
.mob-overlay.open{opacity:1;visibility:visible}
.mob-overlay a{font-family:var(--f-head);font-size:1.55rem;font-weight:800;color:var(--dim);cursor:pointer;transition:color .2s;padding:.55rem 0;letter-spacing:-.01em;display:block;width:100%;text-align:center}
.mob-overlay a:hover,.mob-overlay a:focus{color:var(--text)}
.mob-overlay .mob-sub{font-size:.55rem;font-weight:600;color:var(--acc);padding:.5rem 0 .2rem;letter-spacing:.28em;text-transform:uppercase;font-family:var(--f-head);opacity:.7}
.mob-overlay .mob-subsub{font-family:var(--f-head);font-size:1.3rem;font-weight:700;color:var(--dim);padding:.45rem 0;padding-left:0;letter-spacing:-.01em;text-align:center}
.mob-overlay .mob-subsub:hover{color:var(--acc)!important}
.mob-overlay .mob-sep{width:40px;height:1px;background:var(--line);margin:.9rem 0}
.mob-overlay .mob-cta{font-family:var(--f-head);font-size:1rem;letter-spacing:.12em;text-transform:uppercase;color:var(--acc);border:1px solid rgba(200,169,110,.35);padding:1rem 3rem;margin-top:1rem;font-weight:700;display:inline-block;width:auto}
.mob-overlay .mob-cta:hover{background:var(--acc);color:#000}
.hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes loaderFade{0%{opacity:0;transform:scale(.9)}60%{opacity:1;transform:scale(1)}100%{opacity:1}}

#loader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .5s .1s,visibility .5s .1s}
#loader.gone{opacity:0;visibility:hidden;pointer-events:none}
#loader .loader-logo{font-family:var(--f-head);font-size:4rem;font-weight:800;color:transparent;-webkit-text-stroke:1.5px #C8A96E;letter-spacing:-.05em;line-height:1;animation:loaderFade .8s ease forwards}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.6rem 3.5rem;transition:background .4s,border-bottom .4s,padding .3s}
nav.solid{background:rgba(9,9,9,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);padding:1.1rem 3.5rem}
.nav-logo{font-family:var(--f-head);font-size:1.8rem;font-weight:800;color:transparent;-webkit-text-stroke:1.5px var(--acc);letter-spacing:-.05em;cursor:pointer;line-height:1;transition:opacity .2s;background:none;border:none;padding:0}
.nav-logo:hover{opacity:.7}
.nav-links{display:flex;align-items:center;gap:2.8rem;list-style:none}
.nav-links a{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);font-weight:400;transition:color .25s;font-family:var(--f-head);cursor:pointer}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-links a.active{position:relative}
.nav-links a.active::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--acc)}
.nav-contact{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-family:var(--f-head);font-weight:600;color:var(--acc);border:1px solid rgba(200,169,110,.35);padding:.55rem 1.5rem;transition:background .25s,color .25s;cursor:pointer;background:transparent;display:inline-block}
.nav-contact:hover{background:var(--acc);color:#000}

/* ── NAV DROPDOWN ── */
.nav-dropdown{position:relative}
.nav-drop-trigger{display:flex;align-items:center;gap:.3rem;cursor:pointer;background:none;border:none;color:inherit;font-family:inherit;font-size:inherit;letter-spacing:inherit;text-transform:inherit;padding:0}
.nav-drop-arrow{font-size:.45rem;opacity:.5;transition:transform .2s;margin-top:1px}
.nav-dropdown.open .nav-drop-arrow,
.nav-dropdown:hover .nav-drop-arrow{transform:rotate(180deg)}
.nav-dropdown-menu{position:absolute;top:calc(100% + 1rem);left:50%;transform:translateX(-50%) translateY(-4px);background:rgba(8,8,8,.98);backdrop-filter:blur(20px);border:1px solid var(--line2);min-width:230px;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s,transform .2s;z-index:200;padding:.4rem 0}
.nav-dropdown.open .nav-dropdown-menu,
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dropdown-menu a{display:block;padding:.65rem 1.2rem;font-family:var(--f-head);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);transition:color .2s,background .2s;white-space:nowrap;cursor:pointer;border-left:2px solid transparent}
.nav-dropdown-menu a:hover,.nav-dropdown-menu a:focus{color:var(--text);background:rgba(255,255,255,.03);border-left-color:var(--acc)}
.nav-dropdown-menu .dd-acc{color:var(--acc)!important}
.nav-dropdown-menu .dd-sep{height:1px;background:var(--line);margin:.3rem 0}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:transparent;border:none}
.hamburger span{display:block;width:22px;height:1px;background:var(--text);transition:all .3s}

/* ── PAGE LAYOUT (multi-page) ── */
main{display:block;min-height:100vh;padding-top:80px;animation:pageIn .5s ease forwards}
@keyframes pageIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ── HERO ── */
.hero{min-height:calc(100vh - 80px);display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}
.hero-left{display:flex;flex-direction:column;justify-content:flex-end;padding:4rem 3.5rem 4rem;border-right:1px solid var(--line);position:relative;z-index:1}
.hero-right{position:relative;overflow:hidden;background:var(--bg2)}
.hero-img-wrap{position:absolute;inset:0;background:var(--bg2);display:flex;align-items:center;justify-content:center}
.hero-img-wrap img,.hero-img-wrap video{width:100%;height:100%;object-fit:cover;opacity:.72;transform:scale(1.08);transition:transform .6s ease}
.hero-number{font-family:var(--f-head);font-size:clamp(5rem,14vw,12rem);font-weight:800;line-height:.85;color:var(--bg3);letter-spacing:-.03em;margin-bottom:2rem;user-select:none;-webkit-text-stroke:1px rgba(255,255,255,.08)}
.hero-tag{font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--acc);margin-bottom:1.2rem;font-family:var(--f-head);display:flex;align-items:center;gap:.8rem}
.hero-tag::before{content:'';display:block;width:20px;height:1px;background:var(--acc)}
.hero-h1{font-family:var(--f-head);font-size:clamp(2.2rem,4.5vw,4rem);font-weight:800;line-height:1.05;letter-spacing:-.02em;margin-bottom:1.5rem}
.hero-h1 em{font-style:italic;font-weight:400;color:var(--mid)}
.hero-sub{font-size:.95rem;color:var(--mid);line-height:1.85;max-width:40ch;margin-bottom:2.5rem;font-weight:300}
.hero-ctas{display:flex;align-items:center;gap:2rem;flex-wrap:wrap}
.hero-corner{position:absolute;bottom:2.5rem;right:2.5rem;text-align:right;z-index:2;padding:1.1rem 1.5rem;border:1px solid rgba(255,255,255,0.12);background:linear-gradient(150deg,rgba(255,255,255,0.11) 0%,rgba(255,255,255,0.03) 55%,rgba(255,255,255,0) 100%),rgba(9,9,9,0.22);-webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%)}
.hero-stat-n{font-family:var(--f-head);font-size:2.8rem;font-weight:800;color:#fff;line-height:1}
.hero-stat-l{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:.25rem}

/* ── BUTTONS ── */
.btn{display:inline-block;font-family:var(--f-head);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:all .25s;background:transparent;border:none;color:inherit;text-align:center}
.btn-solid{background:var(--acc);color:#000;padding:.85rem 2.2rem}
.btn-solid:hover,.btn-solid:focus{opacity:.85;transform:translateY(-1px)}
.btn-line{color:var(--mid);display:inline-flex;align-items:center;gap:.5rem}
.btn-line:hover,.btn-line:focus{color:var(--text)}
.btn-line::after{content:'→';transition:transform .25s}
.btn-line:hover::after,.btn-line:focus::after{transform:translateX(4px)}

/* btn-main (was previously undefined — fixes broken styling on city/service CTAs) */
.btn-main{display:inline-block;font-family:var(--f-head);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;background:var(--acc);color:#000;padding:.85rem 2.2rem;cursor:pointer;transition:all .25s;border:none;text-align:center}
.btn-main:hover,.btn-main:focus{opacity:.85;transform:translateY(-1px)}

/* link-button reset for inline anchor CTAs (used as buttons) */
button.btn,button.btn-main,button.btn-solid,button.btn-line{font:inherit;font-family:var(--f-head)}

/* ── PORT HERO (city / service pages) ── */
.port-hero{padding:5rem 3.5rem 3rem;border-bottom:1px solid var(--line)}
.port-title{font-family:var(--f-head);font-weight:800;line-height:1.05;letter-spacing:-.02em;margin-bottom:1.2rem}
.port-sub{color:var(--mid);max-width:60ch;line-height:1.9;font-size:1rem;margin-top:1rem;font-weight:300}

/* ── SECTION UTILS ── */
section{padding:4.5rem 3.5rem}
.sec-label{font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;color:var(--acc);margin-bottom:1rem;font-family:var(--f-head);display:flex;align-items:center;gap:.8rem}
.sec-label::before{content:'';display:block;width:20px;height:1px;background:var(--acc)}
.sec-title{font-family:var(--f-head);font-size:clamp(2rem,4vw,3.2rem);font-weight:800;line-height:1.1;letter-spacing:-.02em;margin-bottom:1.2rem}
.sec-title em{font-style:italic;font-weight:400;color:var(--mid)}
.divider{width:100%;height:1px;background:var(--line)}

/* ── SPLIT PREVIEW (home) ── */
.split-preview{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line)}
.split-card{position:relative;overflow:hidden;aspect-ratio:3/2;cursor:pointer;background:var(--bg2);display:block}
.split-card:first-child{border-right:1px solid var(--line)}
.split-card-img{width:100%;height:100%;object-fit:cover;opacity:.55;transition:opacity .4s,transform .6s}
.split-card:hover .split-card-img,.split-card:focus .split-card-img{opacity:.75;transform:scale(1.03)}
.split-card-label{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:2.5rem}
.split-card-cat{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--acc);font-family:var(--f-head);margin-bottom:.5rem}
.split-card-name{font-family:var(--f-head);font-size:clamp(2rem,3.5vw,3rem);font-weight:800;color:#fff;line-height:1;letter-spacing:-.02em}
.split-card-arrow{position:absolute;top:2rem;right:2rem;width:44px;height:44px;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
.split-card:hover .split-card-arrow,.split-card:focus .split-card-arrow{opacity:1;transform:none}

/* ── WHY GRID ── */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:2.5rem}
.why-card{background:var(--bg);padding:1.8rem 1.6rem;transition:background .3s}
.why-card:hover{background:var(--bg2)}
.why-num{font-family:var(--f-head);font-size:.68rem;letter-spacing:.2em;color:var(--acc);margin-bottom:1.4rem;font-weight:600}
.why-title{font-family:var(--f-head);font-size:1.1rem;font-weight:700;margin-bottom:.7rem;line-height:1.25}
.why-desc{font-size:.85rem;color:var(--dim);line-height:1.9}

/* ── GALLERY ── */
.gallery-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3rem}
.gallery-grid{display:grid;gap:1px;background:var(--line)}
.gallery-grid.g3{grid-template-columns:repeat(3,1fr)}
.gallery-grid.g2{grid-template-columns:repeat(2,1fr)}
.gallery-grid.feature{grid-template-columns:2fr 1fr;grid-template-rows:auto auto}
.gallery-item{background:var(--bg2);overflow:hidden;position:relative;cursor:pointer}
.gallery-item.tall{grid-row:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;opacity:.75;transition:opacity .4s,transform .5s}
.gallery-item.tall img{aspect-ratio:auto;height:100%}
/* Feature grid: Fotos in natürlichem 3:2 Seitenverhältnis, kein Crop */
.gallery-grid.feature .gallery-item:not(.tall) img{height:auto;aspect-ratio:unset;object-fit:unset}
.gallery-item:hover img{opacity:.95;transform:scale(1.03)}
.gallery-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 50%);opacity:0;transition:opacity .3s}
.gallery-item:hover .gallery-item-overlay{opacity:1}
.gallery-placeholder{width:100%;aspect-ratio:4/3;background:var(--bg2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;border:1px dashed rgba(255,255,255,.06)}
.gallery-placeholder span{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.gallery-placeholder em{font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(200,169,110,.4);font-style:normal}

/* ── SERVICES LIST ── */
.services-list{margin-top:3rem}
.service-row{display:grid;grid-template-columns:3rem 1fr 1fr auto;align-items:start;gap:1.5rem;padding:1.8rem 0;border-bottom:1px solid var(--line);transition:background .2s;padding-left:1rem;padding-right:1rem}
.service-row:first-child{border-top:1px solid var(--line)}
.service-row:hover{background:var(--bg2)}
.s-num{font-family:var(--f-head);font-size:.68rem;color:var(--acc);font-weight:600;letter-spacing:.12em;margin-top:.2rem}
.s-name{font-family:var(--f-head);font-size:1.1rem;font-weight:700}
.s-desc{font-size:.85rem;color:var(--dim);line-height:1.8}
.s-tag{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mid);border:1px solid var(--line2);padding:.3rem .8rem;white-space:nowrap;font-family:var(--f-head);align-self:start;margin-top:.15rem}

/* ── ABOUT PAGE ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:70vh}
.about-visual{position:relative;background:var(--bg2);border-right:1px solid var(--line);overflow:hidden}
.about-visual img{width:100%;height:100%;object-fit:cover;opacity:.65}
.about-visual-placeholder{width:100%;height:100%;min-height:500px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--bg2)}
.about-monogram{font-family:var(--f-head);font-size:8rem;font-weight:800;color:var(--bg3);letter-spacing:-.05em;-webkit-text-stroke:1px rgba(200,169,110,.2)}
.about-content{padding:4rem 3.5rem;display:flex;flex-direction:column;justify-content:center}
.about-content p{font-size:1rem;color:var(--mid);line-height:2;margin-bottom:1.2rem;font-weight:300}
.about-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--line)}
.fact-n{font-family:var(--f-head);font-size:2.4rem;font-weight:800;color:var(--text);line-height:1}
.fact-n em{color:var(--acc);font-style:normal}
.fact-l{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin-top:.3rem}

/* ── PROCESS ── */
.process-strip{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ps{padding:2rem 1.8rem;border-right:1px solid var(--line);transition:background .3s}
.ps:last-child{border-right:none}
.ps:hover{background:var(--bg2)}
.ps-n{font-family:var(--f-head);font-size:1.8rem;font-weight:800;color:rgba(255,255,255,.04);line-height:1;margin-bottom:.8rem;transition:color .3s}
.ps:hover .ps-n{color:rgba(200,169,110,.15)}
.ps-t{font-family:var(--f-head);font-size:1rem;font-weight:700;margin-bottom:.6rem}
.ps-d{font-size:.83rem;color:var(--dim);line-height:1.85}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line)}
.contact-left{padding:4rem 3.5rem;border-right:1px solid var(--line)}
.contact-right{padding:4rem 3.5rem}
.contact-intro{font-size:1.05rem;color:var(--mid);line-height:1.9;margin-bottom:3rem;font-weight:300}
.c-item{margin-bottom:1.8rem}
.c-label{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:.3rem;font-family:var(--f-head)}
.c-val{font-family:var(--f-head);font-size:1.1rem;font-weight:600;color:var(--text)}
.c-val a:hover,.c-val a:focus{color:var(--acc)}
.form{display:flex;flex-direction:column;gap:1.4rem}
.fg{display:flex;flex-direction:column;gap:.4rem}
.fg label{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);font-family:var(--f-head)}
.fi{background:transparent;border:none;border-bottom:1px solid var(--line2);color:var(--text);font-family:var(--f-body);font-size:.95rem;font-weight:300;padding:.7rem 0;outline:none;width:100%;transition:border-color .25s}
.fi:focus{border-color:var(--acc)}
.fi.fi-error{border-color:#c8553d}
.fi.fi-error::placeholder{color:#c8553d}
.fi::placeholder{color:var(--dim)}
textarea.fi{resize:vertical;min-height:90px}
.form-consent{display:flex;align-items:flex-start;gap:.7rem;font-size:.78rem;color:var(--mid);line-height:1.6}
.form-consent input[type="checkbox"]{margin-top:.25rem;accent-color:var(--acc);width:16px;height:16px;cursor:pointer;flex-shrink:0}
.form-consent a{color:var(--acc);text-decoration:underline}

/* ── CAPTCHA ── */
.form-captcha .captcha-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.captcha-question{
  font-family:var(--f-head);font-size:1rem;font-weight:600;color:var(--text);
  background:rgba(200,169,110,.08);
  border:1px solid rgba(200,169,110,.25);
  padding:.7rem 1rem;letter-spacing:.04em;
  user-select:none;-webkit-user-select:none;
  min-width:7em;text-align:center;
  font-variant-numeric:tabular-nums;
}
.captcha-input{max-width:7em;font-variant-numeric:tabular-nums}
.captcha-refresh{
  background:transparent;border:1px solid var(--line2);
  color:var(--mid);width:38px;height:38px;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;transition:color .25s, border-color .25s, transform .35s ease;
}
.captcha-refresh:hover,.captcha-refresh:focus{color:var(--acc);border-color:rgba(200,169,110,.4)}
.captcha-refresh:hover svg,.captcha-refresh:focus svg{transform:rotate(-180deg);transition:transform .5s ease}
.captcha-refresh svg{transition:transform .5s ease}
.form-hint{font-size:.72rem;color:var(--dim);letter-spacing:.04em;margin-top:.3rem}
@media(max-width:600px){
  .form-captcha .captcha-row{gap:.6rem}
  .captcha-question{padding:.6rem .8rem;font-size:.9rem;min-width:0;flex:1}
}
.form-submit{align-self:flex-start;background:transparent;border:1px solid rgba(200,169,110,.35);color:var(--acc);font-family:var(--f-head);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;padding:.85rem 2.2rem;cursor:pointer;transition:all .25s}
.form-submit:hover,.form-submit:focus{background:var(--acc);color:#000;border-color:var(--acc)}
.form-submit:disabled{opacity:.5;cursor:not-allowed}
.form-honeypot{position:absolute;left:-9999px;opacity:0;pointer-events:none}

/* ── INSTAGRAM ROW ── */
.ig-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line)}
.ig-item{aspect-ratio:1;background:var(--bg2);overflow:hidden;cursor:pointer;display:block}
.ig-item img{width:100%;height:100%;object-fit:cover;opacity:.6;transition:opacity .3s,transform .4s}
.ig-item:hover img,.ig-item:focus img{opacity:.9;transform:scale(1.05)}
.ig-item{position:relative}
.ig-badge{position:absolute;top:.55rem;right:.6rem;font-size:.6rem;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.6);pointer-events:none;opacity:.92}

/* ── FOOTER ── */
footer{border-top:1px solid var(--line);padding:2rem 3.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.2rem}
.f-logo{font-family:var(--f-head);font-size:1.5rem;font-weight:800;color:transparent;-webkit-text-stroke:1px rgba(200,169,110,.5);letter-spacing:-.05em;cursor:pointer;display:inline-block;background:none;border:none;padding:0}
.f-copy{font-size:.72rem;color:var(--dim);letter-spacing:.06em}
.f-links{display:flex;gap:1.8rem;list-style:none;flex-wrap:wrap}
.f-links a{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);font-family:var(--f-head);transition:color .25s}
.f-links a:hover,.f-links a:focus{color:var(--mid)}

/* ── REVEAL ── */
.r{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s}
.r.v{opacity:1;transform:none}
.r[data-d="1"]{transition-delay:.1s}
.r[data-d="2"]{transition-delay:.2s}
.r[data-d="3"]{transition-delay:.3s}
.r[data-d="4"]{transition-delay:.4s}

/* ── LOGO TICKER ── */
.logo-ticker-wrap{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.8rem 0;background:var(--bg);overflow:hidden;position:relative}
.logo-ticker-wrap::before,.logo-ticker-wrap::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.logo-ticker-wrap::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.logo-ticker-wrap::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.logo-ticker-label{font-family:var(--f-head);font-size:.55rem;letter-spacing:.28em;text-transform:uppercase;color:var(--dim);text-align:center;margin-bottom:1.4rem}
.logo-ticker-outer{overflow:hidden}
.logo-ticker{display:flex;width:max-content;animation:logotick 32s linear infinite;align-items:center;gap:0}
.logo-item{padding:0 2.5rem;border-right:1px solid var(--line);display:flex;align-items:center;justify-content:center;height:44px;flex-shrink:0;transition:opacity .3s;cursor:default}
.logo-item:hover{opacity:.85}
.logo-item img{height:32px;width:auto;filter:grayscale(1) brightness(1.3);opacity:.85;object-fit:contain;max-width:170px}
.logo-item:hover img{filter:grayscale(0) brightness(1);opacity:1}
.logo-item svg{height:28px;width:auto}
.logo-item-wide img{max-width:200px}
@keyframes logotick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:900px){
  .logo-ticker-wrap::before,.logo-ticker-wrap::after{width:60px}
  .logo-item{padding:0 1.5rem;height:36px}
  .logo-item img{height:26px;max-width:130px}
  .logo-item-wide img{max-width:170px}
}

/* ── PRICING ── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:2.5rem}
.price-card{background:var(--bg);padding:2rem 1.8rem;position:relative;transition:background .3s;display:flex;flex-direction:column}
.price-card:hover{background:var(--bg2)}
.price-card.featured{background:linear-gradient(155deg,rgba(200,169,110,0.14) 0%,rgba(200,169,110,0.04) 45%,rgba(200,169,110,0) 100%),rgba(17,17,17,0.6);-webkit-backdrop-filter:blur(16px) saturate(135%);backdrop-filter:blur(16px) saturate(135%)}
.price-card.featured:hover{background:linear-gradient(155deg,rgba(200,169,110,0.2) 0%,rgba(200,169,110,0.06) 45%,rgba(200,169,110,0) 100%),rgba(17,17,17,0.6)}
.price-card .featured-badge{position:absolute;top:1.5rem;right:1.5rem;font-family:var(--f-head);font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:#000;background:var(--acc);padding:.25rem .7rem}
.price-tier{font-family:var(--f-head);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mid);margin-bottom:1.2rem}
.price-amount{font-family:var(--f-head);font-size:2.5rem;font-weight:800;line-height:1;color:var(--text)}
.price-amount .unit{font-size:.9rem;font-weight:400;color:var(--dim)}
.price-sub{font-size:.78rem;color:var(--dim);margin-bottom:1.8rem;margin-top:.25rem}
.price-list{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.price-list li{font-size:.83rem;color:var(--mid);display:flex;align-items:start;gap:.6rem}
.price-list li::before{content:'—';color:var(--acc);flex-shrink:0}
.price-cta{font-family:var(--f-head);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--acc);border:1px solid rgba(200,169,110,.3);padding:.65rem 1.5rem;display:inline-block;cursor:pointer;transition:background .25s,color .25s;background:transparent;text-align:center;align-self:flex-start;margin-top:auto}
.price-cta:hover,.price-cta:focus{background:var(--acc);color:#000}
.price-card.featured .price-cta{color:#000;background:var(--acc);border-color:var(--acc)}
.price-card.featured .price-cta:hover{opacity:.85}
.price-footnote{font-size:.75rem;color:var(--dim);margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--line);line-height:1.7}
.addon-rows{display:flex;flex-direction:column;gap:0}
.addon-row{display:flex;align-items:baseline;gap:1rem;padding:.6rem 0;border-bottom:1px solid var(--line);font-size:.83rem;color:var(--mid)}
.addon-row:last-child{border-bottom:none}
.addon-price{font-family:var(--f-head);font-size:.95rem;font-weight:700;color:var(--acc);white-space:nowrap;min-width:5rem;flex-shrink:0}

/* ── ADDON ACCORDION ── */
.addons-accordion-wrap{margin-top:2.5rem;display:flex;flex-direction:column;gap:1px;border:1px solid var(--line);background:var(--line)}
.addon-accordion{background:var(--bg)}
.addon-accordion-trigger{width:100%;background:transparent;border:none;cursor:pointer;padding:1.4rem 1.8rem;display:flex;align-items:center;gap:1rem;color:var(--text);transition:background .3s}
.addon-accordion-trigger:hover{background:var(--bg2)}
.addon-accordion.open .addon-accordion-trigger{background:var(--bg2)}
.addon-acc-hint{font-size:.88rem;color:var(--dim);font-family:var(--f-head);letter-spacing:.06em;margin-left:.4rem;transition:opacity .3s}
.addon-accordion.open .addon-acc-hint{opacity:0}
.addon-acc-arrow{margin-left:auto;color:var(--acc);display:flex;align-items:center;transition:transform .45s cubic-bezier(.4,0,.2,1)}
.addon-accordion.open .addon-acc-arrow{transform:rotate(180deg)}
.addon-accordion-body{height:0;overflow:hidden;transition:height .45s cubic-bezier(.4,0,.2,1)}
.addon-accordion-inner{padding:0 1.8rem;opacity:0;transform:translateY(-6px);transition:opacity .3s ease,transform .35s cubic-bezier(.4,0,.2,1)}
.addon-accordion.open .addon-accordion-inner{opacity:1;transform:translateY(0);padding-bottom:1.4rem}
@keyframes rowIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}
.addon-accordion.open .addon-row{opacity:0;animation:rowIn .3s ease forwards}
.addon-accordion.open .addon-row:nth-child(1){animation-delay:.06s}
.addon-accordion.open .addon-row:nth-child(2){animation-delay:.12s}
.addon-accordion.open .addon-row:nth-child(3){animation-delay:.18s}
.addon-accordion.open .addon-row:nth-child(4){animation-delay:.24s}
.addon-accordion.open .addon-row:nth-child(5){animation-delay:.30s}
.addon-accordion.open .addon-row:nth-child(6){animation-delay:.36s}

/* ── TESTIMONIALS ── */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:2.5rem}
.testimonial{background:var(--bg2);padding:1.8rem;transition:background .3s}
.testimonial::before{content:'';display:block;width:20px;height:1px;background:var(--acc);margin-bottom:.8rem}
.testimonial-quote{font-size:.95rem;color:var(--mid);line-height:1.9;margin-bottom:1.5rem;font-style:italic;font-weight:300}
.testimonial-author{font-family:var(--f-head);font-size:.75rem;font-weight:700;color:var(--text);margin-bottom:.2rem}
.testimonial-role{font-size:.7rem;color:var(--dim);letter-spacing:.08em}

@media(max-width:900px){
  .pricing-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
}

/* ── TICKER (text ticker) ── */
.ticker-wrap{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:.85rem 0}
.ticker{display:flex;width:max-content;animation:tick 25s linear infinite}
.t-item{font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:var(--dim);padding:0 2.5rem;display:flex;align-items:center;gap:2rem;flex-shrink:0}
.t-item::after{content:'◆';color:var(--acc);font-size:.45rem}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── BEFORE / AFTER SLIDER ── */
.ba-slider{position:relative;overflow:hidden;aspect-ratio:4/3;cursor:col-resize;user-select:none;-webkit-user-select:none;background:var(--bg3)}
#slider-home{aspect-ratio:unset !important;height:100% !important;min-height:420px}
.ba-after,.ba-before{position:absolute;inset:0}
.ba-before{clip-path:inset(0 50% 0 0);transition:clip-path 0s}
.ba-slider.dragging .ba-before{transition:none}
.ba-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}
.ba-ph-after{background:var(--bg2)}
.ba-ph-before{background:var(--bg3)}
.ba-ph span{font-family:var(--f-head);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.ba-ph small{font-size:.52rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(200,169,110,.35)}
.ba-after img,.ba-before img{width:100%;height:100%;object-fit:cover;display:block}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0;pointer-events:none;z-index:10}
.ba-line{flex:1;width:1.5px;background:rgba(255,255,255,.7)}
.ba-btn{width:38px;height:38px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 16px rgba(0,0,0,.5);transition:transform .2s}
.ba-slider:hover .ba-btn,.ba-slider:focus .ba-btn{transform:scale(1.1)}
.ba-slider:focus-visible{outline:2px solid var(--acc);outline-offset:4px}
.ba-labels{position:absolute;bottom:1rem;left:0;right:0;display:flex;justify-content:space-between;padding:0 1rem;pointer-events:none}
.ba-lbl{font-family:var(--f-head);font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;background:rgba(0,0,0,.55);color:#fff;padding:.25rem .6rem;backdrop-filter:blur(4px)}

/* ── LEGAL PAGES ── */
.legal-body p{font-size:.95rem;color:var(--mid);line-height:1.95;font-weight:300}
.legal-h2{font-family:var(--f-head);font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.8rem;padding-bottom:.6rem;border-bottom:1px solid var(--line)}
.legal-h3{font-family:var(--f-head);font-size:.85rem;font-weight:600;color:var(--mid);margin-bottom:.4rem;letter-spacing:.04em}

/* ═══════════════════════════════════════════════════════════
   VISUAL POLISH LAYER
═══════════════════════════════════════════════════════════ */

/* ── SCROLL PROGRESS ── */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;
  background:linear-gradient(90deg, var(--acc) 0%, rgba(200,169,110,.4) 100%);
  width:0;z-index:150;transition:width .08s linear;pointer-events:none;
  box-shadow:0 0 8px rgba(200,169,110,.45);
}

/* ── FILM GRAIN OVERLAY ── */
body::after{
  content:'';
  position:fixed;inset:0;z-index:90;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
  opacity:.035;mix-blend-mode:overlay;
}
@media (prefers-reduced-motion: reduce){
  body::after{opacity:.02}
}

/* ── MAGNETIC SHINE on solid buttons ── */
.btn-solid,.btn-main,.form-submit,.nav-contact{
  position:relative;overflow:hidden;isolation:isolate;
}
.btn-solid::before,.btn-main::before,.form-submit::before,.nav-contact::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 0%,transparent 35%,rgba(255,255,255,.35) 50%,transparent 65%,transparent 100%);
  transform:translateX(-110%);
  transition:transform .9s cubic-bezier(.2,.6,.3,1);
  pointer-events:none;z-index:-1;
}
.btn-solid:hover::before,.btn-main:hover::before,.form-submit:hover::before,.nav-contact:hover::before{
  transform:translateX(110%);
}

/* ── PRICING CARD GOLD BORDER GLOW ── */
.price-card{overflow:hidden;isolation:isolate}
.price-card::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg,rgba(200,169,110,0) 0%,rgba(200,169,110,.18) 50%,rgba(200,169,110,0) 100%);
  opacity:0;transition:opacity .5s ease;z-index:0;
}
.price-card:hover::before{opacity:1}
.price-card > *{position:relative;z-index:1}

/* ── TESTIMONIAL — BIG QUOTE MARK ── */
.testimonial-quote{position:relative;z-index:1}
.testimonial-quote::before{
  content:'\201E';
  position:absolute;left:-.18em;top:-.5em;
  font-family:'Syne',serif;font-size:6rem;font-weight:800;
  color:var(--acc);opacity:.1;
  line-height:1;pointer-events:none;z-index:-1;
}

/* ── GALLERY — gold vignette on hover ── */
.gallery-item{isolation:isolate}
.gallery-item::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at center, transparent 40%, rgba(200,169,110,.18) 100%);
  opacity:0;transition:opacity .5s ease;z-index:1;
}
.gallery-item:hover::after{opacity:1}

/* ── SPLIT CARD same vignette ── */
.split-card{isolation:isolate}
.split-card::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at center, transparent 35%, rgba(200,169,110,.16) 100%);
  opacity:0;transition:opacity .5s ease;z-index:0;
}
.split-card:hover::after,.split-card:focus::after{opacity:1}

/* ── SERVICE ROW: gold accent that grows on hover ── */
.service-row{position:relative}
.service-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:0;background:var(--acc);
  transition:width .35s cubic-bezier(.3,.7,.3,1);
  pointer-events:none;
}
.service-row:hover::before{width:3px}

/* ── REGION CARD: gold corner accent on hover ── */
.region-card{position:relative;overflow:hidden}
.region-card::after{
  content:'';position:absolute;top:0;right:0;
  width:0;height:1px;background:var(--acc);
  transition:width .5s cubic-bezier(.3,.7,.3,1);
}
.region-card:hover::after{width:100%}

/* ── ANIMATED NAV LINK UNDERLINE ── */
.nav-links a{position:relative}
.nav-links a:not(.active):not(.nav-drop-trigger)::after{
  content:'';position:absolute;
  bottom:-4px;left:50%;right:50%;height:1px;
  background:var(--acc);
  transition:left .3s ease, right .3s ease;
}
.nav-links a:not(.active):not(.nav-drop-trigger):hover::after{left:0;right:0}
.nav-dropdown:hover .nav-drop-trigger,
.nav-dropdown.open .nav-drop-trigger{color:var(--text)}

/* ── ANIMATED SECTION TITLE underline drawn from .sec-label::before extension ── */
/* (Sec-label already has gold bar via ::before — no extra underline on titles to avoid layout shift) */

/* ── HERO PARALLAX (home only) ── */
.hero-img-wrap{will-change:transform}

/* ── REVEAL ENHANCEMENT — adds subtle scale on featured cards ── */
.why-card,.ps,.region-card,.price-card,.testimonial{
  transition:background .35s ease, transform .5s cubic-bezier(.3,.7,.3,1), box-shadow .5s ease;
}
.why-card:hover,.region-card:hover,.testimonial:hover{
  transform:translateY(-3px);
}
.price-card:not(.featured):hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.price-card.featured:hover{transform:translateY(-6px);box-shadow:0 16px 50px rgba(200,169,110,.12)}

/* ── HORIZONTAL DIVIDER LINE (decorative, in sections) ── */
.gold-rule{display:block;width:60px;height:1px;background:var(--acc);margin:1.5rem 0}

/* ── SUBTLE FLOAT ANIMATION (Weilheim dot, Virtual-Staging "Neu" badge etc.) ── */
@keyframes floatY{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-4px)}
}

/* ── HERO CTA HOVER: gold underline grows ── */
.btn-line{position:relative}
.btn-line::before{
  content:'';position:absolute;left:0;right:100%;bottom:-4px;height:1px;
  background:var(--acc);transition:right .35s cubic-bezier(.3,.7,.3,1);
}
.btn-line:hover::before,.btn-line:focus::before{right:0}

/* ── HERO IMAGE OVERLAY (more dramatic) ── */
.hero-img-wrap::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg, transparent 30%, rgba(9,9,9,.55) 100%);
  pointer-events:none;
}

/* ── HERO OVERLAP (home): image bleeds left under the text and
   dissolves into a frosted-glass gradient toward the copy ── */
.hero-overlap .hero-right{overflow:visible;z-index:0}
.hero-overlap .hero-img-wrap{left:-38%}
/* no centre divider line on the overlap hero */
.hero-overlap .hero-left{border-right:none}
/* show the photo at full brightness (no darkening) and fade it out toward the text */
.hero-overlap .hero-img-wrap img,
.hero-overlap .hero-img-wrap video{
  opacity:1;
  -webkit-mask-image:linear-gradient(100deg, transparent 4%, rgba(0,0,0,.35) 26%, #000 50%);
          mask-image:linear-gradient(100deg, transparent 4%, rgba(0,0,0,.35) 26%, #000 50%);
}
/* no frosted milk-glass — only the gradient remains */
.hero-overlap .hero-img-wrap::before{display:none}
/* black left-edge gradient that hides where the photo ends */
.hero-overlap .hero-img-wrap::after{
  display:block;z-index:3;
  background:linear-gradient(100deg,
    var(--bg) 0%,
    var(--bg) 14%,
    rgba(9,9,9,.82) 30%,
    rgba(9,9,9,.35) 44%,
    transparent 58%);
}
@media (max-width:880px){
  .hero-overlap .hero-img-wrap{left:0}
  .hero-overlap .hero-img-wrap img,
  .hero-overlap .hero-img-wrap video{-webkit-mask-image:none;mask-image:none}
}

/* ── KENBURNS slow zoom for image-band heroes (drone hero on subpage) ── */
.hero-image-band img{
  animation:kenburns 22s ease-in-out infinite alternate;
  will-change:transform;
}
@keyframes kenburns{
  from{transform:scale(1) translate(0,0)}
  to{transform:scale(1.08) translate(-1%, -1%)}
}
@media (prefers-reduced-motion: reduce){
  .hero-image-band img{animation:none}
}

/* ── ASIDE-CARD (Stadt/Leistung-Seiten): gold gradient border on hover ── */
.aside-card{position:relative;overflow:hidden;isolation:isolate;transition:transform .4s ease, border-color .4s ease}
.aside-card:hover{transform:translateY(-2px);border-color:rgba(200,169,110,.35)}
.aside-card::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg, rgba(200,169,110,0) 0%, rgba(200,169,110,.12) 100%);
  opacity:0;transition:opacity .5s ease;z-index:-1;
}
.aside-card:hover::before{opacity:1}

/* ── LOGO TICKER: subtle gold accent on edges (already done via fade) ── */
/* (existing logo-ticker-wrap fade already handles this) */

/* ── DROPDOWN MENU enhanced: gold border slides in on hover items ── */
.nav-dropdown-menu a{position:relative;overflow:hidden}
.nav-dropdown-menu a::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:2px;background:var(--acc);
  transform:scaleY(0);transform-origin:center;
  transition:transform .3s ease;
}
.nav-dropdown-menu a:hover::before,.nav-dropdown-menu a:focus::before{transform:scaleY(1)}

/* ── PROCESS STRIP ── */
.ps{position:relative;overflow:hidden}
.ps::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:2px;background:var(--acc);
  transition:width .5s cubic-bezier(.3,.7,.3,1);
}
.ps:hover::after{width:100%}

/* ── REGION CARD GRID ── */
.region-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:2.5rem}
.region-card{background:var(--bg);padding:1.8rem 1.6rem;transition:background .3s}
.region-card:hover{background:var(--bg2)}
.region-card h3{font-family:var(--f-head);font-size:1rem;font-weight:700;margin-bottom:.8rem}
.region-card .acc{color:var(--acc)}
.region-card p{font-size:.85rem;color:var(--dim);line-height:1.85}
.region-card .more{margin-top:1.2rem;font-family:var(--f-head);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--acc);display:inline-block}

/* ── DEUTSCHLAND-KARTE (über mich) ── */
.de-map{position:relative;width:100%;max-width:340px;aspect-ratio:960/1341;margin:0 auto}
.de-map-silhouette{
  position:absolute;inset:0;
  -webkit-mask:url(img/germany-map.png) center/contain no-repeat;
          mask:url(img/germany-map.png) center/contain no-repeat;
  background:
    radial-gradient(ellipse 22% 12% at 39.6% 78.5%, rgba(200,169,110,0.55), rgba(200,169,110,0.15) 50%, transparent 75%),
    radial-gradient(ellipse 18% 10% at 47.2% 83%, rgba(200,169,110,0.45), transparent 70%),
    radial-gradient(ellipse 22% 13% at 39.7% 91.2%, rgba(200,169,110,0.28), transparent 75%),
    radial-gradient(ellipse 24% 14% at 62.2% 86%, rgba(200,169,110,0.22), transparent 75%),
    rgba(255,255,255,0.06);
}
.de-map-overlay{position:absolute;inset:0;pointer-events:none}
.de-label{
  position:absolute;
  font-family:var(--f-head);
  font-size:.62rem;
  letter-spacing:.04em;
  color:rgba(255,255,255,0.5);
  white-space:nowrap;
  transform:translate(-50%,-50%);
}
.de-label-major{color:rgba(255,255,255,0.78);font-weight:500;font-size:.65rem}
.de-label-home{color:var(--acc);font-weight:600;font-size:.56rem}
.de-pulse{
  position:absolute;
  width:7px;height:7px;border-radius:50%;
  background:var(--acc);
  transform:translate(-50%,-50%);
  box-shadow:0 0 10px rgba(200,169,110,0.8);
}
.de-pulse::after{
  content:'';
  position:absolute;inset:0;border-radius:50%;
  background:var(--acc);
  animation:dePulse 2.8s ease-out infinite;
}
@keyframes dePulse{
  0%{transform:scale(1);opacity:.7}
  100%{transform:scale(5);opacity:0}
}
@media (prefers-reduced-motion: reduce){
  .de-pulse::after{animation:none;opacity:0}
}
.de-map-legend{position:absolute;bottom:1rem;left:1rem;display:flex;flex-direction:column;gap:.5rem}
.de-map-legend > div{display:flex;align-items:center;gap:.5rem}
.de-map-legend .swatch{width:10px;height:10px;border-radius:50%}
.de-map-legend span{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);font-family:var(--f-head)}

/* ═══════════════════════════════════════════════════════════
   FROSTED GLASS (Milchglas) — translucent panels that fade out
═══════════════════════════════════════════════════════════ */
.glass{
  position:relative;
  isolation:isolate;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.012);
  overflow:hidden;
}
/* the milky frost layer — blurs what's behind it, then fades diagonally to clear */
.glass::before{
  content:'';
  position:absolute;inset:0;
  z-index:-1;
  background:linear-gradient(140deg,
    rgba(255,255,255,0.09) 0%,
    rgba(255,255,255,0.035) 42%,
    rgba(255,255,255,0) 100%);
  -webkit-backdrop-filter:blur(18px) saturate(135%);
          backdrop-filter:blur(18px) saturate(135%);
  -webkit-mask-image:linear-gradient(140deg,#000 0%,#000 38%,rgba(0,0,0,0) 96%);
          mask-image:linear-gradient(140deg,#000 0%,#000 38%,rgba(0,0,0,0) 96%);
  transition:opacity .45s ease;
}
/* faint gold catch-light along the top edge */
.glass::after{
  content:'';position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(200,169,110,0.45),transparent);
  opacity:.55;pointer-events:none;
}
.glass > *{position:relative;z-index:1}
.glass:hover::before{opacity:.78}

/* vertical fade variant — frost dense at top, clears toward the bottom */
.glass-fade-down::before{
  background:linear-gradient(to bottom,
    rgba(255,255,255,0.085) 0%,
    rgba(255,255,255,0.03) 50%,
    rgba(255,255,255,0) 100%);
  -webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 45%,rgba(0,0,0,0) 100%);
          mask-image:linear-gradient(to bottom,#000 0%,#000 45%,rgba(0,0,0,0) 100%);
}

/* gold-tinted glass for accent panels */
.glass-gold::before{
  background:linear-gradient(140deg,
    rgba(200,169,110,0.16) 0%,
    rgba(200,169,110,0.05) 45%,
    rgba(200,169,110,0) 100%);
}

@media (prefers-reduced-motion: reduce){
  .glass:hover::before{opacity:1}
}

/* ═══════════════════════════════════════════════════════════
   VIDEO LOOPS — silent, autoplay, atmospheric background clips
   Falls back to the poster image until a video file is dropped in.
═══════════════════════════════════════════════════════════ */
.vloop{width:100%;height:100%;object-fit:cover;display:block;background:var(--bg2)}
.vloop-wrap{position:relative;overflow:hidden;background:var(--bg2)}
/* frosted "drop your clip here" hint — auto-hides once the video plays */
.vloop-hint{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  z-index:4;display:flex;flex-direction:column;align-items:center;gap:.7rem;
  text-align:center;padding:1.25rem 1.6rem;pointer-events:none;
  background:linear-gradient(150deg,rgba(255,255,255,0.07) 0%,rgba(255,255,255,0.015) 60%,rgba(255,255,255,0) 100%);
  -webkit-backdrop-filter:blur(14px) saturate(130%);
          backdrop-filter:blur(14px) saturate(130%);
  border:1px solid rgba(255,255,255,0.10);
  transition:opacity .6s ease;
}
.vloop-hint .vh-play{
  width:46px;height:46px;border-radius:50%;
  border:1px solid rgba(200,169,110,.5);
  display:flex;align-items:center;justify-content:center;
  color:var(--acc);font-size:.8rem;padding-left:3px;
}
.vloop-hint .vh-label{font-family:var(--f-head);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mid)}
.vloop-hint code{font-family:monospace;font-size:.55rem;letter-spacing:.03em;color:rgba(200,169,110,.65);word-break:break-all;max-width:22ch;line-height:1.5}
.vplaying .vloop-hint{opacity:0;visibility:hidden}
/* keep hero video behind the corner stat + canvas grid */
.hero-img-wrap video.vloop{position:absolute;inset:0}
.gallery-item.tall video.vloop{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* video inside a normal gallery tile matches the 4:3 photo tiles */
.gallery-item:not(.tall) video.vloop{aspect-ratio:4/3;height:auto}

/* ── MOSAIC GALLERY (CSS columns — kein Crop, natürliche Bildproportionen) ── */
.gallery-masonry{columns:3;column-gap:1px;background:var(--line);border:1px solid var(--line)}
.gallery-masonry .m-item{break-inside:avoid;position:relative;overflow:hidden;background:var(--bg2);margin-bottom:1px;display:block}
.gallery-masonry .m-item img{width:100%;height:auto;display:block;opacity:.82;transition:opacity .4s ease, transform .6s ease}
.gallery-masonry .m-item:hover img{opacity:1;transform:scale(1.03)}
.gallery-masonry .m-item::after{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at center, transparent 40%, rgba(200,169,110,.18) 100%);opacity:0;transition:opacity .5s ease}
.gallery-masonry .m-item:hover::after{opacity:1}
@media(max-width:900px){
  .gallery-masonry{columns:2}
}
@media(max-width:560px){
  .gallery-masonry{columns:1}
}

/* frosted fact tiles on the about page */
.about-facts.facts-glass{border-top:none;padding-top:0;gap:.8rem}
.about-facts.facts-glass > div{padding:1.6rem 1.4rem}
.about-facts.facts-glass .fact-l{margin-top:.5rem}

/* floating frosted legend chip on the map */
.de-map-legend.glass{padding:.85rem 1rem;border-radius:2px}

/* ── 2-col split (city / service pages) ── */
.split-2col{display:grid;grid-template-columns:3fr 2fr;gap:5rem;align-items:start}
.aside-card{background:linear-gradient(150deg,rgba(255,255,255,0.06) 0%,rgba(255,255,255,0.02) 45%,rgba(255,255,255,0) 100%),rgba(17,17,17,0.55);-webkit-backdrop-filter:blur(16px) saturate(130%);backdrop-filter:blur(16px) saturate(130%);border:1px solid rgba(255,255,255,0.10);padding:2rem}
.aside-card-h{font-family:var(--f-head);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--acc);margin-bottom:1.2rem}
.aside-card-price{font-family:var(--f-head);font-size:1.5rem;font-weight:800;margin-bottom:.5rem}
.aside-card-pricesub{font-size:.82rem;color:var(--dim);margin-bottom:1.5rem}
.aside-card-bullets{font-size:.82rem;color:var(--mid);line-height:1.8;margin-bottom:1.8rem}

.bullets-acc{display:flex;flex-direction:column;gap:.6rem}
.bullets-acc > div{display:flex;gap:.8rem;align-items:start;font-size:.9rem;color:var(--mid)}
.bullets-acc > div > span:first-child{color:var(--acc);flex-shrink:0}

.related-strip{border-top:1px solid var(--line);padding:3rem 3.5rem;display:flex;align-items:center;justify-content:space-between;background:var(--bg2);flex-wrap:wrap;gap:1.2rem}
.related-strip .rel-label{font-family:var(--f-head);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.related-strip .rel-links{display:flex;gap:1.5rem;margin-top:.6rem;flex-wrap:wrap}
.related-strip .rel-links a{font-size:.8rem;color:var(--acc);cursor:pointer}

/* ── DROHNE HERO IMAGE BAND ── */
.hero-image-band{width:100%;height:55vh;min-height:380px;overflow:hidden;position:relative;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.hero-image-band img{width:100%;height:100%;object-fit:cover}
.hero-image-band .overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,8,8,0) 40%,rgba(8,8,8,0.7) 100%)}
.hero-image-band .caption{position:absolute;bottom:2.5rem;left:3.5rem}
.hero-image-band .caption-kicker{font-family:var(--f-head);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:.4rem}
.hero-image-band .caption-title{font-family:var(--f-head);font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:-.01em}

/* ── STAGING INFO TILES (home + staging page) ── */
.staging-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:2.5rem}
.staging-info-tile{padding:.9rem 1rem;border:1px solid rgba(255,255,255,0.09);font-size:.82rem;color:var(--mid);line-height:1.7;background:linear-gradient(150deg,rgba(255,255,255,0.05) 0%,rgba(255,255,255,0.015) 55%,rgba(255,255,255,0) 100%);-webkit-backdrop-filter:blur(12px) saturate(125%);backdrop-filter:blur(12px) saturate(125%)}
.staging-info-tile .kicker{color:var(--acc);display:block;font-family:var(--f-head);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;margin-bottom:.3rem}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  nav{padding:1.2rem 1.5rem}
  nav.solid{padding:.9rem 1.5rem}
  .nav-links,.nav-contact{display:none}
  .hamburger{display:flex}
  section{padding:4rem 1.5rem}
  .port-hero{padding:4rem 1.5rem 2.5rem}
  .hero{grid-template-columns:1fr;grid-template-rows:auto 75vw}
  .hero-left{padding:2.5rem 1.5rem;border-right:none;border-bottom:1px solid var(--line)}
  .hero-right{border-top:1px solid var(--line)}
  .hero-number{font-size:6rem}
  /* Stat-Box: oben links damit das Gesicht frei bleibt */
  .hero-corner{top:1.2rem;bottom:auto;right:auto;left:1.2rem;text-align:left;padding:.8rem 1.1rem}
  .hero-stat-n{font-size:2rem}
  /* Portrait: Maurice + Bike mittig zentrieren */
  .hero-img-wrap img,.hero-img-wrap video{object-position:center 30%}
  .split-preview{grid-template-columns:1fr}
  .split-card:first-child{border-right:none;border-bottom:1px solid var(--line)}
  .why-grid{grid-template-columns:1fr 1fr}
  .gallery-grid.g3{grid-template-columns:1fr 1fr}
@media(max-width:900px){
  nav{padding:1.2rem 1.5rem}
  nav.solid{padding:.9rem 1.5rem}
  .nav-links,.nav-contact{display:none}
  .hamburger{display:flex}
  section{padding:4rem 1.5rem}
  .port-hero{padding:4rem 1.5rem 2.5rem}
  .hero{grid-template-columns:1fr;grid-template-rows:auto 75vw}
  .hero-left{padding:2.5rem 1.5rem;border-right:none;border-bottom:1px solid var(--line)}
  .hero-right{border-top:1px solid var(--line)}
  .hero-number{font-size:6rem}
  .hero-corner{top:1.2rem;bottom:auto;right:auto;left:1.2rem;text-align:left;padding:.8rem 1.1rem}
  .hero-stat-n{font-size:2rem}
  .hero-img-wrap img,.hero-img-wrap video{object-position:center 30%}
  .split-preview{grid-template-columns:1fr}
  .split-card:first-child{border-right:none;border-bottom:1px solid var(--line)}
  .why-grid{grid-template-columns:1fr 1fr}
  .gallery-grid.g3{grid-template-columns:1fr 1fr}
  .gallery-grid.feature{grid-template-columns:1fr}
  .gallery-item.tall{grid-row:span 1}
  .about-grid{grid-template-columns:1fr}
  .about-visual{min-height:55vw}
  .about-content{padding:2.5rem 1.5rem}
  .process-strip{grid-template-columns:1fr 1fr}
  .ps{border-bottom:1px solid var(--line)}
  .contact-grid{grid-template-columns:1fr}
  .contact-left{border-right:none;border-bottom:1px solid var(--line);padding:2.5rem 1.5rem}
  .contact-right{padding:2.5rem 1.5rem}
  .service-row{grid-template-columns:2rem 1fr;gap:1rem}
  .s-desc,.s-tag{grid-column:2}
  .ig-strip{grid-template-columns:repeat(3,1fr)}
  footer{flex-direction:column;gap:1rem;text-align:center;padding:2rem 1.5rem}
  .gallery-header{flex-direction:column;align-items:flex-start;gap:1.5rem}
  .region-grid{grid-template-columns:1fr}
  .split-2col{grid-template-columns:1fr;gap:2.5rem}
  .ba-slider{aspect-ratio:3/2}
  #slider-home{min-height:55vw!important}
  .related-strip{padding:2.5rem 1.5rem;flex-direction:column;align-items:flex-start}
  /* Virtual Staging Sektion: untereinander stapeln */
  .staging-row{grid-template-columns:1fr!important}
  .staging-row > div:first-child{border-right:none;border-bottom:1px solid var(--line)}
  .staging-text{padding:2.5rem 1.5rem!important}
  .staging-info-grid{grid-template-columns:1fr}
  .hero-image-band .caption{left:1.5rem;bottom:1.5rem}
}

/* ═══════════════════════════════════════════════════════════
   LIGHTBOX — Referenzbilder freigestellt & vergrößert
═══════════════════════════════════════════════════════════ */
.gallery-item img,.gallery-masonry .m-item img{cursor:zoom-in}

.lb-overlay{
  position:fixed;inset:0;z-index:1000;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(1rem,5vw,4.5rem);
  background:rgba(6,6,6,0);
  backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);
  opacity:0;visibility:hidden;
  transition:opacity .5s ease,visibility .5s,background .5s ease,backdrop-filter .5s ease;
}
.lb-overlay.open{
  opacity:1;visibility:visible;
  background:rgba(6,6,6,.93);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}

.lb-stage{
  position:relative;display:flex;flex-direction:column;align-items:center;gap:1.1rem;
  max-width:100%;max-height:100%;
}
.lb-img{
  display:block;width:auto;height:auto;
  max-width:92vw;max-height:82vh;
  object-fit:contain;
  border:1px solid var(--line2);
  box-shadow:0 50px 130px rgba(0,0,0,.75),0 0 0 1px rgba(0,0,0,.4);
  background:var(--bg2);
  will-change:transform,opacity;
}
.lb-cap{
  font-family:var(--f-head);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--mid);text-align:center;max-width:80vw;line-height:1.6;
  opacity:0;transform:translateY(8px);transition:opacity .5s ease .15s,transform .5s ease .15s;
}
.lb-overlay.open .lb-cap{opacity:1;transform:none}

/* ── Close button ── */
.lb-close{
  position:fixed;top:clamp(1rem,2.4vw,2rem);right:clamp(1rem,2.4vw,2.2rem);z-index:1002;
  width:52px;height:52px;border-radius:50%;
  border:1px solid var(--line2);background:rgba(255,255,255,.04);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  opacity:0;transform:scale(.4) rotate(-90deg);
  transition:opacity .45s cubic-bezier(.16,1,.3,1) .12s,transform .55s cubic-bezier(.34,1.56,.64,1) .12s,border-color .3s ease,background .3s ease;
}
.lb-overlay.open .lb-close{opacity:1;transform:scale(1) rotate(0)}
.lb-close::before,.lb-close::after{
  content:'';position:absolute;width:19px;height:1.5px;background:var(--text);
  transition:background .3s ease;
}
.lb-close::before{transform:rotate(45deg)}
.lb-close::after{transform:rotate(-45deg)}
.lb-close:hover,.lb-close:focus-visible{border-color:var(--acc);background:var(--acc2);transform:scale(1) rotate(90deg)}
.lb-close:hover::before,.lb-close:hover::after,.lb-close:focus-visible::before,.lb-close:focus-visible::after{background:var(--acc)}

/* ── Prev / Next ── */
.lb-nav{
  position:fixed;top:50%;z-index:1001;transform:translateY(-50%) scale(.6);
  width:56px;height:56px;border-radius:50%;
  border:1px solid var(--line2);background:rgba(255,255,255,.03);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  color:var(--text);font-family:var(--f-head);font-size:1.5rem;line-height:1;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .45s ease .18s,transform .5s cubic-bezier(.16,1,.3,1) .18s,border-color .3s ease,background .3s ease,color .3s ease;
}
.lb-overlay.open .lb-nav{opacity:1;transform:translateY(-50%) scale(1)}
.lb-prev{left:clamp(.6rem,2vw,2rem)}
.lb-next{right:clamp(.6rem,2vw,2rem)}
.lb-nav span{display:block;margin-top:-3px}
.lb-nav:hover,.lb-nav:focus-visible{border-color:var(--acc);background:var(--acc2);color:var(--acc)}
.lb-nav[hidden]{display:none}

@media (max-width:640px){
  .lb-img{max-width:94vw;max-height:74vh}
  .lb-nav{width:46px;height:46px;font-size:1.25rem}
  .lb-close{width:46px;height:46px}
}

/* ── 2026: Mobile-Fixes für neue Elemente ── */
@media(max-width:900px){
  /* "Für wen ich arbeite" Grid (Homepage) */
  .target-grid{grid-template-columns:1fr!important}
  /* Logo-Ticker: kein padding-Clash */
  .logo-ticker-wrap{padding:2rem 1.5rem!important}
  .logo-ticker-label{padding-left:0}
  /* Neue why-grid Spalten mit inline-Überschreibung */
  .why-grid{grid-template-columns:1fr 1fr!important}
}
@media(max-width:700px){
  /* Erfahrungs-Strips (Homepage Expertise-Sektion) */
  .exp-strip{grid-template-columns:1fr!important;gap:.5rem 0!important;padding:1.4rem 0}
  .exp-strip-vline{display:none!important}
  /* Process-Strip: 1 Spalte auf kleinen Screens */
  .process-strip{grid-template-columns:1fr!important}
  /* Why-Grid: 1 Spalte auf kleinen Screens */
  .why-grid{grid-template-columns:1fr!important}
  /* Hero CTAs: untereinander */
  .hero-ctas{flex-direction:column;align-items:flex-start;gap:1rem}
  /* Port-Hero: weniger Padding */
  .port-hero{padding:3rem 1.5rem 2rem}
  /* Hero H1: nicht über den Viewport-Rand */
  .hero-h1{font-size:clamp(1.65rem,6.5vw,2.2rem)!important;overflow-wrap:break-word;word-break:break-word}
  /* Portrait: besser sichtbar und richtig positioniert */
  .hero-img-wrap img,.hero-img-wrap video{opacity:.88!important;object-position:center 45%!important}
}
@media(max-width:560px){.ref-mini-grid{grid-template-columns:1fr!important}}
/* ── ÜBER MICH — Mobile fixes ── */
@media(max-width:900px){
  .about-grid-main{
    grid-template-columns:1fr !important;
    min-height:unset;
  }
  .about-grid-main .about-visual{
    min-height:80vw;
    border-right:none;
    border-bottom:1px solid var(--line);
  }
  .about-grid-main .about-content{
    padding:2.5rem 1.5rem;
  }
  .about-facts{
    grid-template-columns:repeat(3,1fr);
    gap:.6rem;
    margin-top:2rem;
  }
  .about-facts.facts-glass > div{
    padding:.9rem .7rem !important;
  }
  .about-facts .fact-n{
    font-size:1.55rem;
  }
  .about-facts .fact-l{
    font-size:.5rem;
    letter-spacing:.12em;
  }
  .about-region-grid-main{
    grid-template-columns:1fr !important;
  }
  .about-region-grid-main > div:first-child{
    border-right:none !important;
    border-bottom:1px solid var(--line);
    min-height:260px !important;
    padding:2rem 1.5rem !important;
  }
  .about-region-grid-main > div:last-child{
    padding:1.5rem 1.5rem !important;
  }
}

/* ── AUTOMOBIL VIDEO: Vollbild auf Mobile ── */
@media(max-width:900px){
  .auto-gallery-wrap{padding:0 !important}
  .auto-feature-grid{grid-template-columns:1fr !important}
  .auto-video-item{
    height:100svh !important;
    min-height:100svh !important;
    grid-row:span 1 !important;
  }
  .auto-video-item video{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  }
  /* Restliche Galerie-Items unter dem Video normal darstellen */
  .auto-feature-grid .gallery-item:not(.auto-video-item){
    min-height:56vw;
  }
  .auto-feature-grid .gallery-item:not(.auto-video-item) img{
    width:100%;height:100%;object-fit:cover;aspect-ratio:unset;
  }
}
@media (prefers-reduced-motion: reduce){
  .lb-overlay,.lb-close,.lb-nav,.lb-cap{transition:opacity .2s ease!important}
  .lb-close{transform:none!important}
  .lb-nav{transform:translateY(-50%)!important}
}
