/* ============================================
   BESPOQ — Campaign Landing Page
   Fullscreen slider only, short form popup
   ============================================ */
:root{--w:#fff;--b:#000;--f:'Montserrat',sans-serif;--ease:cubic-bezier(.77,0,.175,1)}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--f);font-weight:300;background:var(--b);color:var(--w);overflow-x:hidden;cursor:none}
a{text-decoration:none;color:inherit;cursor:none}
button{background:none;border:none;cursor:none;font-family:var(--f);outline:none}
img{display:block;max-width:100%}

/* ─── LOADER ─── */
.page-loader{position:fixed;inset:0;background:linear-gradient(135deg,#fff,#f8f8f8);z-index:99999;display:flex;align-items:center;justify-content:center;transition:transform 1.2s cubic-bezier(.65,0,.35,1)}
.page-loader.done{transform:translateY(-100%)}
.loader-inner{text-align:center}
.loader-logo{width:180px;filter:invert(1);margin:0 auto 24px;animation:fadeUp .7s ease both}
.loader-bar{width:160px;height:3px;background:rgba(0,0,0,.1);border-radius:8px;overflow:hidden;margin:0 auto}
.loader-fill{width:0;height:100%;background:linear-gradient(90deg,#000,#333);border-radius:8px;transition:width .25s ease}
@keyframes fadeUp{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ─── CURSOR ─── */
.cur-dot{position:fixed;width:6px;height:6px;background:rgba(180,180,180,.8);border-radius:50%;pointer-events:none;z-index:100001;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s;box-shadow:0 0 10px rgba(180,180,180,.5)}
.cur-circle{position:fixed;width:24px;height:24px;border:1px solid rgba(180,180,180,.4);border-radius:50%;pointer-events:none;z-index:100000;transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s}
.cur-glow{position:fixed;width:260px;height:260px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:screen}
.cur-dot.hover{width:10px;height:10px;background:rgba(180,180,180,.95)}
.cur-circle.hover{width:36px;height:36px;border-color:rgba(180,180,180,.6)}

/* ─── LOGO & TAGLINE ─── */
.logo-fixed{position:fixed;top:15px;left:15px;z-index:10001;pointer-events:auto}
.logo-fixed img{width:260px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));opacity:.95;transition:opacity .3s}
.logo-fixed:hover img{opacity:1}
.tagline-fixed{position:fixed;top:25px;left:50%;transform:translateX(-50%);z-index:10001;color:rgba(255,255,255,.9);font-size:20px;font-weight:300;letter-spacing:6px;text-transform:uppercase;text-shadow:0 2px 6px rgba(0,0,0,.6);white-space:nowrap;pointer-events:none}

/* ─── PREMIUM QUOTE ─── */
.quote-fixed{position:absolute;bottom:110px;left:56px;z-index:15;max-width:320px;text-align:left;pointer-events:none}
.quote-line{width:36px;height:1px;background:linear-gradient(to right,rgba(255,255,255,.25),transparent);margin-bottom:10px}
.quote-text{font-size:15px;font-weight:200;font-style:italic;color:rgba(255,255,255,.6);line-height:1.6;letter-spacing:.5px;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.quote-author{font-size:10px;font-weight:400;color:rgba(255,255,255,.4);letter-spacing:2px;text-transform:uppercase;margin-top:8px;text-shadow:0 1px 6px rgba(0,0,0,.5)}

/* ─── SLIDER ─── */
.slider{position:relative;width:100%;height:100vh;height:100dvh;overflow:hidden;background:#000}
.slider::before{content:'';position:absolute;top:0;left:0;right:0;height:280px;background:linear-gradient(180deg,rgba(0,0,0,.65) 0%,transparent 100%);z-index:5;pointer-events:none}
.slider-track{width:100%;height:100%;position:relative}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;z-index:1}
.slide.active{opacity:1;z-index:2}
.slide>img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.2);transition:transform 10s cubic-bezier(.16,1,.3,1)}
.slide.active>img{transform:scale(1)}

/* ─── FIRST LOAD — mega zoom reveal ─── */
.slide.hero-reveal>img{transform:scale(1.45)!important;filter:brightness(.5)!important;transition:none!important}
.slide.hero-reveal.hero-animate>img{transform:scale(1)!important;filter:brightness(1)!important;transition:transform 3.5s cubic-bezier(.16,1,.3,1),filter 2.5s ease!important}
.slide-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,.05) 40%,rgba(0,0,0,.05) 60%,rgba(0,0,0,.45) 100%);z-index:1}
.slide-grad::before,.slide-grad::after{content:'';position:absolute;border-radius:50%;filter:blur(100px);opacity:.35;pointer-events:none;z-index:2}
.slide-grad::before{width:450px;height:450px;background:radial-gradient(circle,rgba(255,255,255,.4),rgba(200,215,230,.2) 50%,transparent 70%);bottom:0;left:-5%;animation:orbFloat1 20s ease-in-out infinite}
.slide-grad::after{width:350px;height:350px;background:radial-gradient(circle,rgba(220,225,240,.35),rgba(180,195,210,.15) 50%,transparent 70%);top:5%;right:5%;animation:orbFloat3 18s ease-in-out infinite}

/* Slide content — centered */
.slide-body{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;width:90%;max-width:700px;padding:32px 16px;background:radial-gradient(ellipse at center,rgba(0,0,0,.2) 0%,transparent 70%);opacity:0;transition:opacity .5s ease}
.slide.active .slide-body{opacity:1}
.slide-credit{font-size:11px;font-weight:400;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.55);text-shadow:0 1px 8px rgba(0,0,0,.5)}
.slide-name{font-size:60px;font-weight:300;letter-spacing:-1px;line-height:1.1;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.slide-sub{font-size:18px;font-weight:300;letter-spacing:2px;color:rgba(255,255,255,.8);text-shadow:0 1px 6px rgba(0,0,0,.3)}
.slide-btns{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap;justify-content:center}

.btn-ghost,.btn-solid{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;font-size:11px;font-weight:400;letter-spacing:2.5px;text-transform:uppercase;transition:all .35s ease}
.btn-ghost{background:transparent;color:var(--w);border:1px solid rgba(255,255,255,.3)}
.btn-ghost:hover{background:var(--w);color:var(--b);border-color:var(--w);transform:translateY(-2px)}

/* ─── PREMIUM CTA — animated glow border ─── */
.btn-solid{position:relative;background:transparent;color:var(--w);border:1px solid rgba(255,255,255,.25);overflow:hidden;z-index:1}
.btn-solid::before{content:'';position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:conic-gradient(from var(--glow-angle,0deg),transparent 0%,rgba(255,255,255,.5) 10%,transparent 20%);z-index:-2;animation:glowSpin 4s linear infinite}
.btn-solid::after{content:'';position:absolute;inset:1px;background:rgba(0,0,0,.92);z-index:-1}
.btn-solid:hover{border-color:rgba(255,255,255,.4);transform:translateY(-2px)}
.btn-solid:hover::before{background:conic-gradient(from var(--glow-angle,0deg),transparent 0%,rgba(255,255,255,.8) 10%,transparent 20%)}
@property --glow-angle{syntax:'<angle>';initial-value:0deg;inherits:false}
@keyframes glowSpin{to{--glow-angle:360deg}}

/* Fallback for browsers without @property */
@supports not (background: conic-gradient(from 0deg, red, blue)){
    .btn-solid{background:var(--w);color:var(--b);border:1px solid var(--w)}
    .btn-solid::before,.btn-solid::after{display:none}
    .btn-solid:hover{background:rgba(255,255,255,.85)}
}

/* Partners slide */
.slide--partners{background:var(--b)}
.partners-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:3;width:80%}
.partners-label{font-size:16px;font-weight:500;letter-spacing:4px;text-transform:uppercase;margin-bottom:48px;color:rgba(255,255,255,.7)}
.partners-logos{display:flex;align-items:center;justify-content:center;gap:60px;flex-wrap:wrap;margin-bottom:48px}
.partners-logos img{max-height:80px;max-width:300px;opacity:.8;filter:brightness(0) invert(1);transition:opacity .3s}
.partners-logos img:hover{opacity:1}
.btn-solid--partners{margin-top:8px}

/* Dots */
.dots{position:absolute;bottom:56px;left:50%;transform:translateX(-50%);display:flex;gap:14px;z-index:20}
.dot{width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,.45);box-shadow:0 2px 8px rgba(0,0,0,.3);transition:all .4s cubic-bezier(.4,0,.2,1)}
.dot:hover{background:rgba(255,255,255,.7);transform:scale(1.15)}
.dot.on{width:38px;border-radius:6px;background:var(--w);box-shadow:0 2px 12px rgba(0,0,0,.4)}

/* Arrows */
.arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:20;color:var(--w);padding:12px;transition:opacity .3s}
.arrow svg{opacity:.6;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3));transition:opacity .3s,transform .3s}
.arrow:hover svg{opacity:1;transform:scale(1.1)}
.arrow--prev{left:48px}
.arrow--next{right:48px}

/* ─── SWIPE HINT ─── */
.swipe-hint{position:absolute;bottom:100px;left:50%;transform:translateX(-50%);z-index:20;display:flex;align-items:center;gap:10px;opacity:.5;animation:swipeHintFade 6s ease forwards;pointer-events:none}
.swipe-hint-line{width:40px;height:1px;background:var(--w);animation:swipeSlide 2s ease-in-out infinite}
.swipe-hint-text{font-size:9px;font-weight:400;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.6)}
@keyframes swipeSlide{0%,100%{transform:translateX(0);opacity:.4}50%{transform:translateX(12px);opacity:.8}}
@keyframes swipeHintFade{0%,70%{opacity:.5}100%{opacity:0;visibility:hidden}}

/* Social */
.social-fixed{position:absolute;bottom:56px;left:56px;display:flex;gap:20px;z-index:15}
.social-fixed a{color:var(--w);display:flex}
.social-fixed a svg{opacity:.6;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3));transition:opacity .3s,transform .3s}
.social-fixed a:hover svg{opacity:1;transform:scale(1.12) translateY(-2px)}

/* ─── LIGHTBOX — premium gallery ─── */
.lightbox{position:fixed;inset:0;z-index:5000;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}
.lightbox.on{opacity:1;visibility:visible}
.lb-bg{position:absolute;inset:0;background:rgba(0,0,0,.97)}
.lb-close{position:absolute;top:20px;right:20px;z-index:10;width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);border:1px solid rgba(255,255,255,.1);transition:color .3s,border-color .3s,transform .3s}
.lb-close:hover{color:var(--w);border-color:rgba(255,255,255,.25);transform:rotate(90deg)}
.lb-stage{position:absolute;inset:0 0 86px;display:flex;align-items:center;justify-content:center;padding:52px 72px 14px}
.lb-img-wrap{max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center;perspective:800px}
.lb-img{max-width:100%;max-height:74vh;object-fit:contain;opacity:0;transform:scale(1.06) translateZ(-30px);transition:opacity .7s ease,transform 1.2s cubic-bezier(.16,1,.3,1);transform-origin:center center}
.lb-img.show{opacity:1;transform:scale(1) translateZ(0)}
/* Gallery arrows — premium square border */
.lb-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:56px;height:56px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.12);transition:all .35s ease}
.lb-arrow:hover{color:var(--w);border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.04)}
.lb-prev{left:16px}
.lb-next{right:16px}
.lb-count{position:absolute;bottom:88px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.3);font-size:12px;letter-spacing:3px;z-index:10}
.lb-thumbs{position:absolute;bottom:0;left:0;right:0;height:74px;display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 56px;overflow-x:auto;scrollbar-width:none}
.lb-thumbs::-webkit-scrollbar{display:none}
.lb-thumb{flex-shrink:0;width:56px;height:56px;overflow:hidden;opacity:.25;transition:opacity .3s;border:1px solid transparent}
.lb-thumb:hover{opacity:.55}
.lb-thumb.on{opacity:1;border-color:rgba(255,255,255,.4)}
.lb-thumb img{width:100%;height:100%;object-fit:cover}

/* ─── POPUP ─── */
.popup{position:fixed;inset:0;z-index:6000;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}
.popup.on{opacity:1;visibility:visible}
.popup-bg{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.popup-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) translateY(8px);width:420px;max-width:92vw;max-height:90vh;overflow-y:auto;background:#111;border:1px solid rgba(255,255,255,.06);padding:44px 36px;transition:transform .5s var(--ease);scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
.popup.on .popup-card{transform:translate(-50%,-50%) translateY(0)}
.popup-x{position:absolute;top:14px;right:14px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.3);transition:color .3s,transform .3s}
.popup-x:hover{color:var(--w);transform:rotate(90deg)}
.popup-logo{width:120px;margin:0 auto 20px;opacity:.7}
.popup-h{text-align:center;font-size:20px;font-weight:500;letter-spacing:1px;margin-bottom:4px}
.popup-sub{text-align:center;color:rgba(255,255,255,.35);font-size:12px;font-weight:300;margin-bottom:28px}

.popup-form input[type="text"],.popup-form input[type="tel"]{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:var(--w);font-family:var(--f);font-size:14px;font-weight:300;padding:14px 16px;margin-bottom:12px;outline:none;border-radius:0;transition:border-color .3s}
.popup-form input:focus{border-color:rgba(255,255,255,.3)}
.popup-form input::placeholder{color:rgba(255,255,255,.18)}

.area-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.area-opt{cursor:none}
.area-opt input{display:none}
.area-opt span{display:block;text-align:center;padding:14px 4px;font-size:13px;font-weight:400;letter-spacing:.5px;color:rgba(255,255,255,.45);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);transition:all .3s}
.area-opt:hover span{border-color:rgba(255,255,255,.2)}
.area-opt input:checked+span{color:var(--w);border-color:var(--w);background:rgba(255,255,255,.08)}

.popup-submit{width:100%;padding:16px;background:var(--w);color:var(--b);font-family:var(--f);font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;border:none;transition:background .3s}
.popup-submit:hover{background:rgba(255,255,255,.88)}

.popup-priv{text-align:center;color:rgba(255,255,255,.2);font-size:10px;font-weight:300;line-height:1.5;margin-top:14px}
.popup-priv a{color:rgba(255,255,255,.35);text-decoration:underline}

.popup-ok{display:none;text-align:center;padding:40px 0}
.popup-ok.show{display:block;animation:fadeUp .5s ease both}
.popup-ok svg{margin:0 auto 16px;color:rgba(255,255,255,.6)}
.popup-ok h3{font-size:24px;font-weight:500;margin-bottom:8px}
.popup-ok p{color:rgba(255,255,255,.4);font-size:13px;font-weight:300}

/* ─── FLOATING BTNS ─── */
.float-actions{position:fixed;bottom:100px;right:0;display:flex;flex-direction:column;z-index:100}
.float-btn{width:50px;height:50px;display:flex;align-items:center;justify-content:center;transition:transform .3s}
.float-btn:hover{transform:translateX(-5px)}
.float-phone{background:var(--w);color:var(--b);box-shadow:0 4px 14px rgba(0,0,0,.4)}
.float-msg{background:#222;color:var(--w);box-shadow:0 4px 14px rgba(255,255,255,.2)}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
    .cur-dot,.cur-circle,.cur-glow{display:none!important}
    body,a,button,.btn-ghost,.btn-solid,.float-btn,.lb-close,.lb-arrow,.popup-x,.area-opt,.popup-submit,.dot{cursor:auto}
    .logo-fixed img{width:200px}
    .tagline-fixed{font-size:12px;letter-spacing:3px}
    .quote-fixed{max-width:240px;bottom:80px;left:40px}
    .quote-text{font-size:12px}
    .slide-name{font-size:44px}
    .arrow--prev{left:24px}
    .arrow--next{right:24px}
    .arrow svg{width:36px;height:36px}
    .social-fixed{left:30px;bottom:40px;gap:14px}
    .social-fixed a svg{width:22px;height:22px}
}
@media(max-width:768px){
    .logo-fixed{top:10px;left:10px}
    .logo-fixed img{width:160px}
    .tagline-fixed{font-size:9px;font-weight:400;letter-spacing:2.5px;top:52px;left:14px;transform:none;color:rgba(255,255,255,.65);text-shadow:0 1px 8px rgba(0,0,0,.6)}
    .slide-name{font-size:32px}
    .slide-sub{font-size:13px}
    .slide-credit{font-size:10px;color:rgba(255,255,255,.5)}
    .slide-body{padding:20px 12px;opacity:0!important;transition:opacity .5s ease!important}
    .slide.active .slide-body{opacity:1!important}
    .slide-btns{flex-direction:column;gap:8px;align-items:center}
    .btn-ghost,.btn-solid{padding:12px 24px;font-size:9px}
    .btn-solid::after{background:rgba(0,0,0,.94)}
    .arrow--prev{left:8px}
    .arrow--next{right:8px}
    .arrow svg{width:28px;height:28px}
    .dots{bottom:28px;gap:10px}
    .dot{width:10px;height:10px}
    .dot.on{width:28px}
    .social-fixed{left:20px;bottom:24px;gap:12px}
    .social-fixed a svg{width:18px;height:18px}
    .final-heading{font-size:24px}
    .final-btns{flex-direction:column;align-items:center;gap:10px}
    .final-label{font-size:9px;letter-spacing:4px}
    .swipe-hint{bottom:60px;gap:6px}
    .swipe-hint-text{font-size:8px;letter-spacing:2px}
    .swipe-hint-line{width:28px}
    .quote-fixed{left:20px;bottom:80px;max-width:55%}
    .quote-text{font-size:11px;text-shadow:0 1px 10px rgba(0,0,0,.7)}
    .quote-author{font-size:9px}
    .before-tag,.after-tag{font-size:8px;letter-spacing:3px;padding:5px 10px}
    .before-tag{left:8%}
    .after-tag{right:8%}
    .lb-stage{padding:44px 16px 8px}
    .lb-arrow{width:44px;height:44px}
    .lb-prev{left:8px}
    .lb-next{right:8px}
    .float-actions{bottom:auto;top:10px;right:0}
    .float-btn{width:42px;height:42px}
    .partners-logos{flex-direction:column;gap:24px}
    .partners-logos img{max-height:50px}
    .partners-label{font-size:13px}
}
@media(max-width:480px){
    .logo-fixed img{width:130px}
    .tagline-fixed{font-size:8px;letter-spacing:2px;top:48px}
    .slide-name{font-size:26px}
    .slide-sub{font-size:11px}
    .btn-ghost,.btn-solid{padding:10px 20px;font-size:8px}
    .quote-fixed{max-width:55%;bottom:70px}
    .quote-text{font-size:10px}
    .popup-card{padding:32px 24px}
}

/* ─── FINAL CTA SLIDE ─── */
.slide--final{background:#050505}
.orbs-bg{position:absolute;inset:0;overflow:hidden;z-index:0}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3;will-change:transform}
.orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.4),rgba(180,200,220,.2),transparent 70%);top:-10%;left:-8%;animation:orbFloat1 18s ease-in-out infinite}
.orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(200,210,230,.35),rgba(160,180,200,.15),transparent 70%);bottom:-5%;right:-5%;animation:orbFloat2 22s ease-in-out infinite}
.orb-3{width:320px;height:320px;background:radial-gradient(circle,rgba(220,225,235,.3),rgba(190,200,215,.1),transparent 70%);top:40%;left:55%;animation:orbFloat3 16s ease-in-out infinite}
.orb-4{width:250px;height:250px;background:radial-gradient(circle,rgba(240,240,250,.25),transparent 70%);top:60%;left:15%;animation:orbFloat4 20s ease-in-out infinite}
@keyframes orbFloat1{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(60px,40px) scale(1.08)}50%{transform:translate(30px,80px) scale(.95)}75%{transform:translate(-20px,30px) scale(1.05)}}
@keyframes orbFloat2{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(-50px,-30px) scale(1.1)}50%{transform:translate(-80px,20px) scale(.92)}75%{transform:translate(-20px,-50px) scale(1.06)}}
@keyframes orbFloat3{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-40px,50px) scale(1.12)}66%{transform:translate(30px,-30px) scale(.9)}}
@keyframes orbFloat4{0%,100%{transform:translate(0,0) scale(1)}30%{transform:translate(50px,-40px) scale(1.08)}60%{transform:translate(-30px,60px) scale(.94)}}
.final-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:3;width:80%;max-width:700px}
.final-label{font-size:11px;font-weight:500;letter-spacing:6px;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:24px}
.final-heading{font-size:36px;font-weight:300;letter-spacing:1px;line-height:1.3;color:rgba(255,255,255,.9)}
.final-line{width:48px;height:1px;background:linear-gradient(to right,transparent,rgba(255,255,255,.2),transparent);margin:28px auto}
.final-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ─── BEFORE / AFTER — premium split-screen comparison ─── */
.before-img{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;clip-path:inset(0 100% 0 0);transition:clip-path 1.6s cubic-bezier(.16,1,.3,1);pointer-events:none}
.slide.show-before .before-img{clip-path:inset(0 50% 0 0);z-index:4}
/* Center divider — glowing line between before/after */
.before-divider{position:absolute;top:0;bottom:0;left:50%;width:2px;margin-left:-1px;z-index:8;background:linear-gradient(180deg,transparent 5%,rgba(255,255,255,.85) 30%,rgba(255,255,255,.85) 70%,transparent 95%);box-shadow:0 0 20px rgba(255,255,255,.4),0 0 40px rgba(255,255,255,.15);opacity:0;transition:opacity .6s ease .6s;pointer-events:none}
.slide.show-before .before-divider{opacity:1}
/* Labels floating on the comparison */
.before-tag,.after-tag{position:absolute;z-index:9;font-size:9px;font-weight:500;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.85);background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:7px 16px;opacity:0;transition:opacity .6s ease .8s;pointer-events:none}
.before-tag{top:50%;left:12%;transform:translateY(-50%)}
.after-tag{top:50%;right:12%;transform:translateY(-50%)}
.slide.show-before .before-tag,.slide.show-before .after-tag{opacity:1}
/* Slide body fades out during comparison */
.slide.show-before .slide-body{opacity:0!important;pointer-events:none!important;transition:opacity .4s ease!important}
.slide.show-before .slide-grad{opacity:.25;transition:opacity .5s ease}
.btn-before{border-color:rgba(255,255,255,.15)!important}
.btn-before svg{opacity:.6}
.btn-before:hover{border-color:rgba(255,255,255,.35)!important}

/* ─── PREMIUM LINE DETAIL ─── */
.ambient-line{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06) 30%,rgba(255,255,255,.06) 70%,transparent);z-index:20;pointer-events:none}

::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--b)}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}
::selection{background:rgba(255,255,255,.1)}
