/* Offtrack Camper — shared model-page styles */
:root{
  --bg:#fff;--bg2:#f7f5f1;--bg3:#efeae2;
  --txt:#1a1a1a;--muted:#777;--muted-2:#a8a39b;
  --accent:#a58656;--accent-l:#c8a96e;
  --border:#e5e2dc;--border-soft:rgba(0,0,0,.06);
  --nav-h:64px;--ff:'Montserrat',-apple-system,BlinkMacSystemFont,sans-serif;
  --dark:#0f0f0f;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth;overflow-x:clip;width:100%;max-width:100%}
body{font-family:var(--ff);background:var(--bg);color:var(--txt);overflow-x:clip;-webkit-tap-highlight-color:transparent;line-height:1.5}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:var(--ff);color:inherit}

/* ═══ NAV ═══ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,4vw,60px);background:rgba(0,0,0,.65);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);transition:all .4s}
.nav.nav-hidden{transform:translateY(-100%)}
.nav-logo img{height:20px;filter:brightness(0) invert(1)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:12px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;color:rgba(255,255,255,.6);transition:color .3s}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-cta,.nav-links a.nav-cta{padding:10px 22px;background:#fff;border:1.5px solid #fff;border-radius:100px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#0a0a0a;transition:all .3s}
.nav-cta:hover,.nav-links a.nav-cta:hover{background:transparent;border-color:#fff;color:#fff}
.burger{display:none;flex-direction:column;gap:4px;cursor:pointer;padding:6px}
.burger span{width:22px;height:2px;background:#fff;transition:background .3s}
/* ── Mobile menu ── */
.mob-menu{display:none;position:fixed;inset:0;z-index:1001;background:#fff;flex-direction:column;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}
.mob-menu.open{opacity:1;visibility:visible}
.mob-menu-top{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid #f0f0f0}
.mob-logo img{height:16px;filter:none}
.mob-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f4f4f4}
.mob-close svg{width:18px;height:18px;fill:#1a1a1a}
.mob-nav{flex:1;display:flex;flex-direction:column;justify-content:center;padding:0 28px;gap:0}
.mob-nav a{font-size:15px;font-weight:500;letter-spacing:0.02em;color:#1a1a1a;text-transform:none;padding:13px 0;border-bottom:1px solid #f0f0f0;transition:color .2s}
.mob-nav a:last-child{border-bottom:none}
.mob-nav a:hover{color:var(--accent)}
.mob-care{display:flex;align-items:center;gap:10px}
.mob-care-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
.mob-menu-bottom{padding:20px 24px;display:flex;flex-direction:column;gap:8px;border-top:1px solid #f0f0f0}
.mob-cfg-btn{display:block;text-align:center;padding:13px;background:#1a1a1a;color:#fff;border-radius:8px;font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;transition:background .2s}
.mob-cfg-btn:hover{background:var(--accent)}
.mob-termin-btn{display:block;text-align:center;padding:12px;border:1.5px solid #d8d8d8;color:#444;border-radius:8px;font-size:12px;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;transition:all .2s}
.mob-termin-btn:hover{border-color:#1a1a1a;color:#1a1a1a}
@media(max-width:1100px){.nav-links{display:none}.burger{display:flex}.mob-menu{display:flex}.nav-logo img{height:16px}}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;font-size:11px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;border-radius:100px;transition:all .25s;white-space:nowrap;cursor:pointer}
.btn-fill{background:#fff;color:#1a1a1a}
.btn-fill:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}
.btn-fill-dark{background:var(--txt);color:#fff}
.btn-fill-dark:hover{background:var(--accent);transform:translateY(-1px)}
.btn-ghost-light{border:1.5px solid rgba(255,255,255,.38);color:#fff}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.1);transform:translateY(-1px)}
.btn-ghost{border:1.5px solid var(--border);color:var(--txt)}
.btn-ghost:hover{border-color:var(--txt);transform:translateY(-1px)}

/* ═══ HERO ═══ */
.hero{position:relative;height:100svh;min-height:640px;overflow:hidden;background:#111;color:#fff}
.hero-media{position:absolute;inset:0;width:100%;height:100%}
.hero-media video,.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 50%}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.1) 30%,rgba(0,0,0,.45) 70%,rgba(0,0,0,.75) 100%);z-index:1}

/* Variant pill at top of hero */
.variant-pill{position:absolute;top:calc(var(--nav-h) + 20px);left:50%;transform:translateX(-50%);z-index:3;display:inline-flex;background:rgba(0,0,0,.4);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.14);border-radius:100px;padding:4px;gap:2px;white-space:nowrap}
.variant-pill-item{padding:8px 22px;font-size:10.5px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:rgba(255,255,255,.58);border-radius:100px;transition:all .25s;display:inline-flex;align-items:center;white-space:nowrap;cursor:pointer}
.variant-pill-item.active{background:#fff;color:var(--txt)}
.variant-pill-item:not(.active):hover{color:#fff}
.variant-pill-item small{display:none}

/* Hero content — split left/right layout */
.hero-content{position:absolute;bottom:clamp(48px,7vh,80px);left:0;right:0;z-index:3;padding:0 clamp(20px,5vw,72px);max-width:1760px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-end;gap:clamp(24px,4vw,64px);flex-wrap:wrap}
.hero-headline{display:flex;flex-direction:column;flex:1;min-width:min(100%,280px)}
.hero-eyebrow{font-size:10.5px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:14px;display:inline-flex;align-items:center;gap:10px}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--accent-l)}
.hero-badge{display:inline-flex;align-items:center;padding:9px 22px;background:var(--accent,#a58656);color:#fff;font-size:.9rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;border-radius:100px;margin-bottom:18px;width:fit-content}
.hero-title{font-size:clamp(3rem,7.2vw,5.6rem);font-weight:800;letter-spacing:-3px;line-height:.92;color:#fff}
.hero-model{font-size:clamp(.95rem,1.4vw,1.2rem);font-weight:500;letter-spacing:3.5px;color:rgba(255,255,255,.82);text-transform:uppercase;margin-top:10px}
.hero-side{display:flex;flex-direction:column;align-items:flex-end;gap:16px}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.hero-price{display:flex;flex-direction:column;align-items:flex-end;color:#fff;line-height:1.15}
.hero-price-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:6px;font-weight:600}
.hero-price-value{font-size:clamp(1.6rem,2.4vw,2.1rem);font-weight:800;letter-spacing:-.5px}
.hero-price-note{font-size:11.5px;color:rgba(255,255,255,.55);margin-top:6px;letter-spacing:.3px;font-weight:400}

/* Scroll indicator */
.scroll-hint{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.55);font-size:9.5px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;animation:bounce 2.8s ease-in-out infinite}
.scroll-hint svg{width:14px;height:14px;fill:currentColor}
@keyframes bounce{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

@media(max-width:760px){
  .hero{min-height:560px}
  .hero-content{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:16px;bottom:clamp(54px,7vh,72px);padding:0 18px}
  .hero-headline{min-width:0}
  .hero-title{font-size:clamp(2.1rem,11vw,3.25rem);letter-spacing:-1.4px}
  .hero-model{font-size:clamp(.72rem,3.6vw,.95rem);letter-spacing:2.8px;margin-top:6px}
  .hero-badge{font-size:.65rem;padding:6px 14px;margin-bottom:12px}
  .hero-side{display:contents}
  .hero-price{align-items:flex-end;text-align:right}
  .hero-price-label{font-size:8.5px;letter-spacing:1.8px;margin-bottom:4px}
  .hero-price-value{font-size:clamp(1.05rem,5.2vw,1.45rem);letter-spacing:-.4px}
  .hero-price-note{font-size:9.5px;max-width:128px;line-height:1.25}
  .hero-actions{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;width:100%;gap:10px}
  .hero-side .btn{width:100%;justify-content:center;max-width:none;padding:12px 10px;font-size:9.5px;letter-spacing:1.1px}
  .scroll-hint{display:none}
}
@media(max-width:600px){
  .variant-pill{top:calc(var(--nav-h) + 10px);left:14px;right:14px;transform:none;width:auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));background:rgba(10,10,10,.52);border-color:rgba(255,255,255,.1);border-radius:16px;padding:5px;gap:4px}
  .variant-pill-item{justify-content:center;padding:9px 6px;font-size:9px;letter-spacing:1px;border-radius:12px;color:rgba(255,255,255,.72);overflow:hidden;text-overflow:ellipsis}
  .variant-pill-item.active{background:#fff;color:#111;box-shadow:none}
}

/* ═══ STATS STRIP ═══ */
.stats{background:var(--bg);padding:clamp(28px,4vh,44px) clamp(20px,3vw,56px);border-bottom:1px solid var(--border)}
.stats-inner{max-width:1760px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.5vw,36px);align-items:center}
.stat{display:flex;flex-direction:column;gap:4px;padding:8px 0;position:relative}
.stat+.stat::before{content:'';position:absolute;left:calc(clamp(-18px,-1.25vw,-8px));top:10%;bottom:10%;width:1px;background:var(--border)}
.stat-value{font-size:clamp(1.4rem,2.4vw,2rem);font-weight:800;letter-spacing:-1px;line-height:1;color:var(--txt)}
.stat-value span{font-size:.55em;font-weight:500;color:var(--muted);margin-left:4px;letter-spacing:-.3px}
.stat-label{font-size:10.5px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted)}

@media(max-width:700px){
  .stats-inner{grid-template-columns:repeat(2,1fr);gap:28px 20px}
  .stat+.stat::before{display:none}
  .stat-value{font-size:1.5rem}
}

/* ═══ SECTION GENERIC ═══ */
.section{padding:clamp(48px,7vh,80px) clamp(20px,3vw,56px) clamp(32px,4vh,52px)}
@media(max-width:640px){.section{padding:36px 20px 28px}}
.section-inner{max-width:1760px;margin:0 auto}
.section-header{margin-bottom:clamp(32px,4vh,52px);display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.section-header.centered{text-align:center;align-items:center}
.section-tag{font-size:10.5px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--accent);margin-bottom:14px;display:inline-flex;align-items:center;gap:10px}
.section-tag::before{content:'';width:20px;height:1px;background:var(--accent)}
.section-title{font-size:clamp(2rem,4.5vw,3.6rem);font-weight:700;letter-spacing:-2px;line-height:1.04;margin-bottom:14px;color:var(--txt)}
.section-sub{font-size:clamp(.95rem,1.15vw,1.08rem);font-weight:300;color:var(--muted);line-height:1.7;max-width:640px}

/* ═══ HIGHLIGHTS (compact 4-up feature cards) ═══ */
.highlights-section{background:var(--bg2)}
.highlights-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.5vw,22px)}
.h-card{background:var(--bg);border-radius:16px;overflow:hidden;border:1px solid var(--border);transition:transform .35s ease,box-shadow .35s ease;display:flex;flex-direction:column}
.h-card:hover{transform:translateY(-4px);box-shadow:0 24px 60px -24px rgba(0,0,0,.18)}
.h-card-media{aspect-ratio:4/3;overflow:hidden;background:#eee}
.h-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.h-card:hover .h-card-media img{transform:scale(1.05)}
.h-card-body{padding:clamp(18px,1.5vw,24px) clamp(18px,1.5vw,24px) clamp(22px,2vw,28px);display:flex;flex-direction:column;gap:6px;flex:1}
.h-card-title{font-size:clamp(1.05rem,1.3vw,1.18rem);font-weight:700;letter-spacing:-.3px;color:var(--txt);line-height:1.25}
.h-card-meta{font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--accent)}
.h-card-text{font-size:13.5px;font-weight:400;color:var(--muted);line-height:1.55;margin-top:4px}

@media(max-width:1080px){.highlights-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.highlights-grid{grid-template-columns:1fr}}

/* ═══ FEATURE SHOWCASE ═══ */
.feat-showcase{background:var(--bg)}
.feat-showcase-header{max-width:1760px;margin:0 auto;padding:clamp(40px,5vh,64px) clamp(20px,3vw,56px) clamp(28px,4vh,48px)}
@media(max-width:640px){.feat-showcase-header{padding:28px 20px 20px}}
.feat-showcase-header .section-tag{margin-bottom:12px}
.feat-showcase-header h2{font-size:clamp(1.8rem,3.4vw,2.8rem);font-weight:800;letter-spacing:-1.2px;line-height:1.1;color:var(--txt);max-width:600px}
.feat-row{display:grid;grid-template-columns:3fr 2fr;min-height:520px}
.feat-row.feat-row--flip{grid-template-columns:2fr 3fr}
.feat-row--flip .feat-media{order:2}
.feat-row--flip .feat-body{order:1}
.feat-media{position:relative;overflow:hidden;background:var(--bg2)}
.feat-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s ease}
.feat-row:hover .feat-media img{transform:scale(1.03)}
.feat-ph{width:100%;height:100%;min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px;background:var(--bg2);border:2px dashed var(--border);text-align:center}
.feat-ph svg{width:36px;height:36px;fill:var(--muted-2);flex-shrink:0}
.feat-ph-note{font-size:11.5px;font-weight:400;color:var(--muted);line-height:1.6;max-width:280px}
.feat-body{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,5vw,80px)}
.feat-body-inner{max-width:400px}
.feat-eyebrow{font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.feat-title{font-size:clamp(1.5rem,2.4vw,2rem);font-weight:800;letter-spacing:-0.6px;line-height:1.12;color:var(--txt);margin-bottom:18px}
.feat-text{font-size:13.5px;font-weight:300;line-height:1.85;color:var(--muted)}
@media(max-width:900px){
  .feat-row,.feat-row.feat-row--flip{grid-template-columns:1fr;min-height:auto}
  .feat-row--flip .feat-media{order:1}
  .feat-row--flip .feat-body{order:2}
  .feat-ph{min-height:280px}
  .feat-body{padding:clamp(32px,5vw,48px)}
  .feat-body-inner{max-width:100%}
}

/* ═══ VIDEO SECTION ═══ */
.video-section{background:#0a0a0a}
.video-row{display:grid;grid-template-columns:2fr 3fr;border-top:1px solid rgba(255,255,255,.08)}
.video-section .section-tag{color:var(--accent-l);margin-bottom:18px}
.video-section .section-tag::before{background:var(--accent-l)}
.video-body{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,6vw,96px) clamp(32px,4vw,72px);color:#fff}
.video-title{font-size:clamp(1.8rem,3vw,2.8rem);font-weight:800;letter-spacing:-1.2px;line-height:1.1;color:#fff;margin-bottom:18px}
.video-sub{font-size:clamp(.9rem,1.1vw,1rem);font-weight:300;color:rgba(255,255,255,.58);line-height:1.7;max-width:420px}
.video-frame{position:relative;overflow:hidden;background:#111;cursor:pointer;aspect-ratio:16/9;width:100%}
.video-frame img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;display:block}
.video-frame:hover img{transform:scale(1.03)}
.video-frame::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.15),rgba(0,0,0,.4));transition:opacity .3s;pointer-events:none}
.video-frame:hover::after{opacity:.65}
.video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:clamp(64px,7vw,88px);height:clamp(64px,7vw,88px);border-radius:50%;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 20px 50px rgba(0,0,0,.4)}
.video-frame:hover .video-play{transform:translate(-50%,-50%) scale(1.08);background:#fff}
.video-play svg{width:28%;height:28%;fill:var(--txt);margin-left:3px}
.video-play::before{content:'';position:absolute;inset:-10px;border-radius:50%;border:1px solid rgba(255,255,255,.3);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.3}}
.video-iframe{position:absolute;inset:0;width:100%;height:100%;border:none;display:none}
.video-frame.playing .video-iframe{display:block}
.video-frame.playing .video-play,.video-frame.playing img,.video-frame.playing::after{display:none}
@media(max-width:760px){
  .video-row{grid-template-columns:1fr}
  .video-body{padding:32px 22px 40px}
  .video-sub{max-width:100%}
}

/* ═══ SPECS — PROGRESSIVE DISCLOSURE ═══ */
.specs-section{background:var(--bg)}
.specs-grid{display:flex;flex-direction:column;gap:clamp(12px,1.5vw,16px);margin-top:clamp(32px,4vh,48px)}
.spec-acc{border:1.5px solid var(--border);border-radius:16px;overflow:hidden;transition:border-color .3s,box-shadow .35s ease,transform .25s}
.spec-acc:hover{border-color:#bab5ac}
.spec-acc.open{border-color:var(--txt);box-shadow:0 12px 36px rgba(0,0,0,.06)}
.spec-head{width:100%;display:flex;align-items:center;gap:16px;padding:22px 24px;background:var(--bg);cursor:pointer;text-align:left;transition:background .2s}
.spec-head:hover{background:var(--bg2)}
.spec-acc.open .spec-head{background:var(--bg2)}
.spec-icon{width:46px;height:46px;border-radius:12px;background:var(--txt);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s}
.spec-acc.open .spec-icon{background:var(--accent)}
.spec-icon svg{width:22px;height:22px;fill:#fff}
.spec-head-text{flex:1;min-width:0}
.spec-head-title{font-size:15px;font-weight:700;letter-spacing:-.3px;margin-bottom:2px;color:var(--txt)}
.spec-head-sub{font-size:12px;color:var(--muted);font-weight:400}
.spec-head-count{font-size:11px;font-weight:600;letter-spacing:1.5px;color:var(--muted);background:var(--bg2);padding:5px 11px;border-radius:100px;white-space:nowrap;transition:background .3s,color .3s}
.spec-acc.open .spec-head-count{background:var(--txt);color:#fff}
.spec-head-chev{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}
.spec-head-chev svg{width:12px;height:12px;fill:var(--muted);transition:transform .3s}
.spec-acc.open .spec-head-chev{background:var(--txt);border-color:var(--txt)}
.spec-acc.open .spec-head-chev svg{fill:#fff;transform:rotate(180deg)}

.spec-body{max-height:0;overflow:hidden;transition:max-height .45s ease,padding .35s ease;padding:0 24px;background:var(--bg)}
.spec-acc.open .spec-body{max-height:1800px;padding:4px 24px 22px}
.spec-list{display:grid;grid-template-columns:1fr 1fr;gap:0 32px;padding-top:10px}
.spec-item{display:flex;align-items:flex-start;gap:10px;padding:9px 0;font-size:13.5px;line-height:1.5;color:var(--txt);border-bottom:1px solid rgba(0,0,0,.05)}
.spec-item:last-child{border-bottom:none}
.spec-item svg{width:14px;height:14px;fill:var(--accent);flex-shrink:0;margin-top:3px}

@media(max-width:600px){
  .spec-list{grid-template-columns:1fr}
}

/* ═══ GALLERY ═══ */
.gallery-section{background:var(--bg2)}
.gallery-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:clamp(24px,3vh,36px)}
.gallery-tabs{display:inline-flex;background:#fff;border-radius:100px;padding:4px;border:1px solid var(--border);gap:2px;box-shadow:0 4px 14px rgba(0,0,0,.03)}
.gallery-tab{padding:9px 22px;font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted);border-radius:100px;transition:all .25s;display:inline-flex;align-items:center;gap:8px}
.gallery-tab.active{background:var(--txt);color:#fff}
.gallery-tab:hover:not(.active){color:var(--txt)}
.gallery-tab svg{width:14px;height:14px;fill:currentColor}

.gallery-pane{display:none}
.gallery-pane.active{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1vw,16px)}
.gallery-item{border-radius:14px;overflow:hidden;position:relative;cursor:pointer;background:#ddd;aspect-ratio:4/3}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.3),transparent 50%);opacity:0;transition:opacity .3s}
.gallery-item:hover::after{opacity:1}
.gallery-item-zoom{position:absolute;top:12px;right:12px;z-index:2;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.85);transition:all .3s}
.gallery-item:hover .gallery-item-zoom{opacity:1;transform:scale(1)}
.gallery-item-zoom svg{width:14px;height:14px;fill:var(--txt)}

@media(max-width:900px){
  .gallery-pane.active{grid-template-columns:repeat(2,1fr)}
}
.gallery-panes{position:relative}

/* Prev/next control bar — sits BELOW the carousel on mobile */
.gallery-controls{
  display:none;
  align-items:center;justify-content:space-between;
  gap:14px;margin-top:14px;
}
.gallery-nav{
  width:44px;height:44px;border-radius:50%;
  background:#fff;border:1px solid var(--border);
  box-shadow:0 4px 12px rgba(0,0,0,.06);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .25s ease,transform .15s ease,background .2s ease;
  cursor:pointer;flex-shrink:0;
}
.gallery-nav:active{transform:scale(.92)}
.gallery-nav:hover{background:var(--bg2)}
.gallery-nav[aria-disabled="true"]{opacity:.35;pointer-events:none}
.gallery-nav svg{width:14px;height:14px;fill:var(--txt)}
.gallery-progress{
  flex:1;height:3px;border-radius:100px;background:var(--border);
  overflow:hidden;position:relative;
}
.gallery-progress-bar{
  position:absolute;top:0;left:0;height:100%;
  background:var(--txt);border-radius:100px;
  width:30%;transition:width .25s ease,transform .25s ease;
  transform:translateX(0);
}

/* Phones: swap the grid for a horizontal swipe carousel so the section
   stays compact even with many interior images. Next image peeks in
   from the right edge as a swipe affordance. */
@media(max-width:700px){
  .gallery-panes{
    margin-left:calc(-1 * clamp(20px,3vw,56px));
    margin-right:calc(-1 * clamp(20px,3vw,56px));
  }
  .gallery-pane.active{
    display:flex;
    grid-template-columns:none;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    gap:12px;
    padding:4px clamp(20px,3vw,56px) 16px;
    scroll-padding-left:clamp(20px,3vw,56px);
    scroll-padding-right:clamp(20px,3vw,56px);
  }
  .gallery-pane.active::-webkit-scrollbar{display:none}
  .gallery-pane.active .gallery-item{
    flex:0 0 min(82%,320px);
    aspect-ratio:1/1;
    scroll-snap-align:start;
  }
  .gallery-item-zoom{opacity:1;transform:scale(1)}
  .gallery-controls{display:flex}
  .gallery-section{padding-bottom:clamp(32px,5vh,56px)}
}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.9);display:none;align-items:center;justify-content:center;padding:clamp(16px,4vw,48px);backdrop-filter:blur(8px)}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox-close{position:absolute;top:22px;right:22px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;transition:background .25s}
.lightbox-close:hover{background:rgba(255,255,255,.25)}
.lightbox-close svg{width:16px;height:16px;fill:#fff}
.lightbox-bar{position:absolute;inset:0;pointer-events:none}
.lightbox-nav{pointer-events:auto;position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:background .25s}
.lightbox-nav:hover{background:rgba(255,255,255,.2)}
.lightbox-nav svg{width:18px;height:18px;fill:#fff}
.lightbox-prev{left:22px}
.lightbox-next{right:22px}
.lightbox-counter{pointer-events:none;position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:#fff;font-size:12px;font-weight:500;letter-spacing:1px;opacity:.7}

@media(max-width:600px){
  .lightbox{flex-direction:column;justify-content:center;align-items:center;padding:56px 16px 16px;gap:0}
  .lightbox img{max-height:65vh;max-width:100%;object-fit:contain;border-radius:8px;flex-shrink:0}
  .lightbox-bar{position:static;inset:auto;display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;width:100%;pointer-events:auto;flex-shrink:0}
  .lightbox-nav{position:static;top:auto;transform:none;width:48px;height:48px;background:rgba(255,255,255,.15);flex-shrink:0;pointer-events:auto}
  .lightbox-prev,.lightbox-next{position:static}
  .lightbox-counter{position:static;transform:none;bottom:auto;left:auto;color:#fff;font-size:12px;opacity:.7;flex:1;text-align:center}
}

/* ═══ CTA ═══ */
/* ═══ CLOSING SECTION ═══ */
.closing-section{background:#0a0a0a;padding:clamp(56px,8vh,96px) clamp(20px,3vw,56px)}
.closing-inner{max-width:1760px;margin:0 auto}
.closing-cta{display:flex;justify-content:space-between;align-items:center;gap:clamp(24px,4vw,64px);flex-wrap:wrap;padding-bottom:clamp(40px,6vh,64px)}
.closing-cta .section-tag{color:var(--accent-l);margin-bottom:14px}
.closing-cta .section-tag::before{background:var(--accent-l)}
.closing-cta-left{flex:1;min-width:min(100%,280px)}
.closing-cta-title{font-size:clamp(1.8rem,3.2vw,2.8rem);font-weight:800;letter-spacing:-1.2px;line-height:1.08;color:#fff;margin-bottom:12px}
.closing-cta-sub{font-size:clamp(.9rem,1.1vw,1rem);font-weight:300;color:rgba(255,255,255,.55);line-height:1.7;max-width:520px}
.closing-cta-actions{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0}
.closing-divider{height:1px;background:rgba(255,255,255,.08);margin-bottom:clamp(40px,6vh,64px)}
.closing-models-head{display:flex;justify-content:space-between;align-items:end;gap:28px;margin-bottom:clamp(24px,3vh,36px)}
.closing-models-title{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:800;letter-spacing:-1px;line-height:1.05;color:#fff}
.closing-models-sub{font-size:14px;color:rgba(255,255,255,.45);line-height:1.7;max-width:400px}
.closing-models-head .section-tag{color:var(--accent-l);margin-bottom:10px}
.closing-models-head .section-tag::before{background:var(--accent-l)}
.btn-light{background:#fff;color:#0a0a0a;border-radius:100px;padding:13px 26px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;transition:background .25s,color .25s}
.btn-light:hover{background:var(--accent-l);color:#fff}
.btn-outline-light{border:1.5px solid rgba(255,255,255,.28);color:#fff;border-radius:100px;padding:13px 26px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;transition:border-color .25s,background .25s}
.btn-outline-light:hover{border-color:#fff;background:rgba(255,255,255,.07)}
.other-interiors-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(14px,2vw,24px)}
.other-card{position:relative;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(260px,.9fr);min-height:280px;background:var(--bg2);border:1px solid var(--border);border-radius:24px;overflow:hidden;transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease}
.other-card:hover{transform:translateY(-3px);border-color:rgba(165,134,86,.6);box-shadow:0 28px 70px -44px rgba(0,0,0,.28)}
.other-card-media{background:var(--bg2);min-height:240px;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:clamp(18px,3vw,36px)}
.other-card-media img{width:100%;height:100%;object-fit:contain;transition:transform .8s ease}
.other-card:hover .other-card-media img{transform:scale(1.02)}
.other-card-body{padding:clamp(22px,2.5vw,34px);display:flex;flex-direction:column;justify-content:center;gap:12px}
.other-card-family{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent)}
.other-card-title{font-size:clamp(1.25rem,2vw,1.7rem);font-weight:800;letter-spacing:-.7px;line-height:1.08;color:var(--txt)}
.other-card-copy{font-size:13.5px;color:var(--muted);line-height:1.65;max-width:360px}
.other-card .btn{align-self:flex-start;margin-top:6px}
/* Dark variant */
.other-card--dark{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1)}
.other-card--dark:hover{border-color:rgba(165,134,86,.7);box-shadow:0 28px 70px -44px rgba(0,0,0,.6)}
.other-card--dark .other-card-media{background:#fff}
.other-card--dark .other-card-family{color:var(--accent-l)}
.other-card--dark .other-card-title{color:#fff}
.other-card--dark .other-card-copy{color:rgba(255,255,255,.5)}
@media(max-width:980px){
  .closing-models-head{flex-direction:column;align-items:flex-start}
  .other-interiors-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .closing-care{flex-direction:column;align-items:flex-start;gap:20px}
  .closing-care-left{flex-direction:column;align-items:flex-start;gap:12px}
  .closing-care .btn-outline-light{width:100%;justify-content:center;text-align:center}
  .closing-cta{flex-direction:column;align-items:flex-start}
  .closing-cta-actions{width:100%;flex-direction:column}
  .closing-cta-actions .btn-light,.closing-cta-actions .btn-outline-light{width:100%;justify-content:center;text-align:center}
  .closing-models-head{gap:12px}
}
@media(max-width:640px){
  .other-card{grid-template-columns:1fr;min-height:auto;border-radius:18px}
  .other-card-media{min-height:210px;aspect-ratio:16/10;padding:22px}
  .other-card-body{padding:20px}
  .other-card .btn,.other-card .btn-light{width:100%;justify-content:center}
}


@media(max-width:720px){
  .cta-inner{flex-direction:column;align-items:flex-start}
  .cta-actions{width:100%;flex-direction:column}
  .cta-actions .btn{width:100%;justify-content:center;text-align:center}
}

/* ═══ STICKY CTA ═══ */
.sticky-cta{display:flex;position:fixed;bottom:0;left:50%;right:auto;width:min(720px,calc(100% - 40px));z-index:90;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(0,0,0,.08);border-bottom:none;border-radius:26px 26px 0 0;padding:10px 12px 10px 20px;gap:10px;align-items:center;box-shadow:0 -10px 50px rgba(0,0,0,.14);transform:translate(-50%,100%);transition:transform .4s ease}
.sticky-cta.visible{transform:translate(-50%,0)}
.sticky-cta-price{flex:1;display:flex;flex-direction:column;line-height:1.2}
.sticky-cta-price-label{font-size:9.5px;font-weight:600;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase}
.sticky-cta-price-value{font-size:16px;font-weight:800;color:var(--txt);letter-spacing:-.3px}
.sticky-cta .btn{height:44px;padding:0 18px;font-size:10.5px;letter-spacing:1.3px;display:inline-flex;align-items:center;justify-content:center}
.sticky-cta .btn-ghost .sticky-cta-icon{display:none}
.sticky-cta .btn-ghost::after{content:'Termin buchen'}
@media(max-width:700px){
  .sticky-cta{bottom:0;left:0;right:0;width:auto;border-radius:0;border-left:none;border-right:none;border-bottom:none;padding:10px 12px;gap:8px;transform:translateY(100%)}
  .sticky-cta.visible{transform:translateY(0)}
  body{padding-bottom:68px}
  .sticky-cta .btn-ghost{width:46px;min-width:46px;padding:0;font-size:0;letter-spacing:0;border-color:var(--border)}
  .sticky-cta .btn-ghost::after{content:none}
  .sticky-cta-icon{width:20px;height:20px;fill:var(--txt);display:block}
  .sticky-cta .btn-ghost .sticky-cta-icon{display:block}
  .sticky-cta .btn-fill-dark{flex:0 0 auto;min-width:138px;padding-inline:16px}
}

/* ═══ FOOTER ═══ */
.footer{background:#0a0a0a;color:#fff;padding:clamp(56px,8vh,96px) clamp(20px,4vw,60px) 28px}
.footer-top{max-width:1400px;margin:0 auto;padding-bottom:clamp(32px,5vh,56px);border-bottom:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
.footer-brand{display:flex;flex-direction:column;gap:16px;max-width:400px}
.footer-logo img{height:26px;filter:brightness(0) invert(1);display:block}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.5);line-height:1.7;font-weight:300}
.footer-newsletter{flex:0 0 auto;min-width:min(400px,100%);width:min(440px,100%)}
.footer-newsletter-heading{font-size:10.5px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:12px}
.footer-form{display:flex;gap:10px;align-items:stretch}
.footer-form input{flex:1;padding:13px 18px;background:transparent;border:1px solid rgba(255,255,255,.18);border-radius:100px;color:#fff;font-family:var(--ff);font-size:14px;outline:none;transition:border-color .3s;min-width:0}
.footer-form input::placeholder{color:rgba(255,255,255,.38)}
.footer-form input:focus{border-color:rgba(255,255,255,.7)}
.footer-form button{width:48px;min-width:48px;padding:0;background:#fff;color:#0a0a0a;border-radius:100px;font-family:var(--ff);font-weight:800;font-size:18px;line-height:1;letter-spacing:0;text-transform:none;transition:opacity .25s;white-space:nowrap;cursor:pointer}
.footer-form button:hover{opacity:.82}
.footer-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(28px,3.5vw,48px);padding:clamp(32px,5vh,48px) 0}
.footer-col-heading{font-size:10px;font-weight:600;letter-spacing:2.8px;text-transform:uppercase;color:rgba(255,255,255,.42);margin-bottom:18px}
.footer-links{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.footer-links a,.footer-links button{font-size:14px;font-weight:300;color:rgba(255,255,255,.78);text-align:left;padding:0;background:none;border:none;cursor:pointer;font-family:var(--ff);transition:color .25s}
.footer-links a:hover,.footer-links button:hover{color:#fff}
.footer-socials{display:flex;gap:10px}
.footer-socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;transition:all .25s}
.footer-socials a:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.footer-socials img{width:16px;height:16px;filter:brightness(0) invert(1);opacity:.75;transition:opacity .25s}
.footer-socials a:hover img{opacity:1}
.footer-bottom{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:24px;border-top:1px solid rgba(255,255,255,.06);font-size:12px;color:rgba(255,255,255,.4)}
.footer-bottom-links{display:flex;gap:22px}
.footer-bottom-links a{color:rgba(255,255,255,.5);transition:color .25s}
.footer-bottom-links a:hover{color:#fff}

@media(max-width:900px){
  .footer-top{flex-direction:column;align-items:stretch;gap:32px}
  .footer-newsletter{width:100%;min-width:0}
  .footer-grid{grid-template-columns:repeat(2,1fr);gap:32px 24px}
}
@media(max-width:480px){
  .footer-logo img{height:18px}
  .footer-form{flex-direction:row;gap:8px}
  .footer-form button{width:46px;min-width:46px}
  .footer-bottom{flex-direction:column;text-align:center;gap:14px}
}

/* ═══ NAV CARE LINK ═══ */
.nav-care{display:inline-flex;align-items:center;gap:6px}
.nav-care::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(165,134,86,.55);animation:carePulse 2.4s ease-out infinite}
.nav.nav-transparent .nav-care::before{background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.55)}
@keyframes carePulse{
  0%{box-shadow:0 0 0 0 rgba(165,134,86,.55)}
  70%{box-shadow:0 0 0 8px rgba(165,134,86,0)}
  100%{box-shadow:0 0 0 0 rgba(165,134,86,0)}
}

/* ═══ OFFTRACK CARE SECTION ═══ */
/* Care strip inside closing section */
.closing-care{display:flex;align-items:center;justify-content:space-between;gap:clamp(20px,3vw,48px);flex-wrap:wrap;padding-bottom:clamp(40px,6vh,64px)}
.closing-care-left{display:flex;align-items:center;gap:clamp(18px,2.5vw,36px);flex:1;min-width:0}
.closing-care-logo{display:flex;align-items:center;align-self:flex-start;flex-shrink:0;transition:opacity .25s}
.closing-care-logo:hover{opacity:.7}
.closing-care-logo img{height:clamp(36px,4.5vw,52px);width:auto;object-fit:contain;display:block;filter:brightness(0) invert(1)}
.closing-care-text{min-width:0}
.closing-care-eyebrow{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent-l);margin-bottom:6px}
.closing-care-desc{font-size:14px;font-weight:300;color:rgba(255,255,255,.5);line-height:1.6;max-width:480px}

@media(max-width:900px){
  .care-inner{grid-template-columns:1fr;text-align:center;gap:24px;padding:32px 22px;border-radius:22px}
  .care-logo-wrap{margin:0 auto}
  .care-text{margin:0 auto}
  .care-features{justify-content:center}
  .care-actions{align-items:center}
}

/* ═══ CLOSER LOOK (interactive showcase — light, image-free) ═══ */
.cl-section{padding:clamp(48px,7vh,80px) clamp(20px,3vw,56px) clamp(32px,4vh,52px)}
.cl-inner{max-width:1760px;margin:0 auto}
.cl-title{font-size:clamp(2rem,4.5vw,3.6rem);font-weight:700;letter-spacing:-2px;line-height:1.04;margin-bottom:clamp(24px,3.4vh,40px);color:var(--txt)}
.cl-stage{position:relative;background:var(--bg2);border:1px solid var(--border);border-radius:clamp(20px,2vw,30px);overflow:hidden;display:grid;grid-template-columns:minmax(280px,340px) 1fr;align-items:stretch}
.cl-list-col{padding:clamp(22px,2.4vw,34px);display:flex;gap:14px;align-items:flex-start;border-right:1px solid var(--border)}
.cl-nav{display:flex;flex-direction:column;gap:10px;flex-shrink:0}
.cl-arrow{width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--border);color:var(--txt);display:flex;align-items:center;justify-content:center;transition:border-color .25s,opacity .25s,color .25s;box-shadow:0 2px 10px rgba(0,0,0,.04)}
.cl-arrow svg{width:16px;height:16px;fill:currentColor}
.cl-arrow:hover{border-color:var(--accent);color:var(--accent)}
.cl-arrow:disabled{opacity:.35;cursor:default}
.cl-arrow:disabled:hover{border-color:var(--border);color:var(--txt)}
.cl-list{list-style:none;display:flex;flex-direction:column;gap:4px;flex:1;min-width:0;margin:0;padding:0}
.cl-item-btn{display:flex;align-items:center;gap:11px;width:100%;padding:12px 16px;border-radius:11px;color:var(--muted);font-size:14px;font-weight:600;letter-spacing:-.2px;text-align:left;transition:background .25s,color .25s}
.cl-item-btn:hover{background:rgba(0,0,0,.035);color:var(--txt)}
.cl-item-btn.active{background:#fff;color:var(--txt);box-shadow:0 10px 26px -20px rgba(0,0,0,.45)}
.cl-dot{width:7px;height:7px;border-radius:50%;background:#cfc7ba;flex-shrink:0;transition:background .25s,transform .25s}
.cl-item-btn:hover .cl-dot{background:var(--accent-l)}
.cl-item-btn.active .cl-dot{background:var(--accent);transform:scale(1.25)}
.cl-display{position:relative;padding:clamp(28px,3.8vw,60px);display:flex;flex-direction:column;justify-content:center;min-width:0}
.cl-display-inner{transition:opacity .35s ease,transform .35s ease}
.cl-display-inner.out{opacity:0;transform:translateY(10px)}
.cl-display-num{font-size:11px;font-weight:700;letter-spacing:3px;color:var(--accent);margin-bottom:16px}
.cl-display-title{font-size:clamp(1.5rem,2.7vw,2.3rem);font-weight:700;letter-spacing:-1.2px;line-height:1.08;margin-bottom:16px;color:var(--txt)}
.cl-display-text{font-size:clamp(.98rem,1.15vw,1.12rem);line-height:1.7;color:var(--muted);max-width:540px;font-weight:300}
@media(max-width:860px){
  .cl-stage{grid-template-columns:1fr;min-height:0}
  .cl-list-col{border-right:none;border-bottom:1px solid var(--border);padding:18px 16px}
  .cl-display{padding:26px 18px}
  .cl-display-text{max-width:none}
}

/* ═══ SCROLL REVEAL ═══ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in-view{opacity:1;transform:none}
