/* ===== FITNISA v4 — BRIGHT & BOLD ===== */
@font-face{font-family:'a Auto Signature';src:url('https://fonts.cdnfonts.com/s/25469/aAutoSignature.woff') format('woff');font-weight:400;font-style:normal;font-display:swap}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --pink:#FF1493;--pink2:#FF69B4;--pink3:#FF00FF;--pink-g:rgba(255,20,147,.4);
  --bg:#0c0c18;--bg2:#12122a;--bg3:#1a1a35;--bg4:#222245;
  --txt:#f0f0ff;--txt2:#a0a0c0;--gold:#FFD700;
  --grad:linear-gradient(135deg,#FF1493,#FF69B4,#FF00FF);
  --sp:clamp(4rem,10vw,7rem);
}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--txt);line-height:1.65;overflow-x:hidden}
body.no-scroll{overflow:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}ul{list-style:none}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.pink{color:var(--pink)}
.glow-word{color:var(--pink);text-shadow:0 0 20px var(--pink-g),0 0 60px rgba(255,20,147,.15);animation:glowPulse 3s ease-in-out infinite}
@keyframes glowPulse{0%,100%{text-shadow:0 0 20px var(--pink-g),0 0 60px rgba(255,20,147,.15)}50%{text-shadow:0 0 30px var(--pink-g),0 0 80px rgba(255,20,147,.25)}}
h1,h2,h3,h4{font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.03em;line-height:1.1}

/* ===== PRELOADER — Animated Dumbbell + Heartbeat ===== */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .8s ease,visibility .8s}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{text-align:center}
.preloader-dumbbell{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:2rem;animation:liftDumbbell 1.2s ease-in-out infinite}
.db-plate{width:18px;height:50px;background:var(--grad);border-radius:4px}
.db-plate.left{animation:plateGrow 1.2s ease-in-out infinite}
.db-plate.right{animation:plateGrow 1.2s ease-in-out infinite .1s}
.db-bar{width:80px;height:8px;background:linear-gradient(90deg,#aaa,#fff,#aaa);border-radius:4px}
@keyframes liftDumbbell{0%,100%{transform:translateY(0) rotate(0deg)}25%{transform:translateY(-15px) rotate(-3deg)}50%{transform:translateY(-25px) rotate(0deg)}75%{transform:translateY(-15px) rotate(3deg)}}
@keyframes plateGrow{0%,100%{height:50px}50%{height:60px}}
.preloader-brand{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}
.preloader-logo{width:60px;height:60px;border-radius:50%;box-shadow:0 0 30px var(--pink-g)}
.preloader-name{font-family:'a Auto Signature',cursive!important;font-size:3rem;font-weight:400!important;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.preloader-heartbeat{width:200px;margin:0 auto 1rem;overflow:hidden}
.heartbeat-svg{width:100%}
.heartbeat-line{stroke-dasharray:300;stroke-dashoffset:300;animation:drawHeartbeat 2s ease forwards infinite}
@keyframes drawHeartbeat{to{stroke-dashoffset:0}}
.preloader-status{font-size:.8rem;color:var(--txt2);letter-spacing:.1em;animation:blink 1.5s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:.4}50%{opacity:1}}

/* ===== CUSTOM CURSOR — Dumbbell ===== */
.custom-cursor{position:fixed;pointer-events:none;z-index:9998;transition:transform .08s ease-out;display:none}
@media(min-width:768px){.custom-cursor{display:block}body{cursor:none}a,button,.btn{cursor:none}}
.custom-cursor.clicking{transform:scale(1.4) rotate(15deg)!important}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:'Oswald',sans-serif;font-weight:700;font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;padding:.85rem 2rem;border-radius:8px;border:2px solid transparent;transition:all .35s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.12) 50%,transparent 70%);transform:translateX(-100%);transition:transform .6s}
.btn:hover::after{transform:translateX(100%)}
.btn-pink{background:var(--pink);color:#fff;border-color:var(--pink);box-shadow:0 4px 20px rgba(255,20,147,.3)}
.btn-pink:hover{background:var(--pink3);border-color:var(--pink3);box-shadow:0 8px 40px var(--pink-g);transform:translateY(-3px)}
.btn-glass{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.2);backdrop-filter:blur(10px)}
.btn-glass:hover{background:rgba(255,255,255,.12);border-color:var(--pink);color:var(--pink)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.2)}
.btn-outline:hover{border-color:var(--pink);color:var(--pink)}
.btn-whatsapp{background:#25D366;color:#fff;border-color:#25D366;box-shadow:0 4px 20px rgba(37,211,102,.3)}
.btn-whatsapp:hover{background:#1eba57;transform:translateY(-3px);box-shadow:0 8px 30px rgba(37,211,102,.4)}
.btn-lg{padding:1.1rem 2.8rem;font-size:1rem}
.btn-sm{padding:.65rem 1.4rem;font-size:.8rem}

/* ===== SECTIONS ===== */
.section{padding:var(--sp) 0;position:relative;overflow:hidden}
.section-label{display:block;font-family:'Oswald',sans-serif;font-size:.85rem;font-weight:700;letter-spacing:.2em;color:var(--pink2);margin-bottom:.5rem}
.section-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:900;margin-bottom:1rem}
.section-subtitle{font-size:1.1rem;color:var(--txt2);max-width:600px;margin-bottom:3rem}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(35px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.active{opacity:1;transform:translateY(0)}

/* ===== NAVBAR ===== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 0;transition:all .4s}
.navbar.scrolled{background:rgba(12,12,24,.88);backdrop-filter:blur(16px);padding:.6rem 0;box-shadow:0 4px 30px rgba(0,0,0,.4),inset 0 -1px 0 rgba(255,20,147,.1)}
.nav-container{display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:.6rem}
.nav-logo-img{height:42px;width:42px;border-radius:50%;object-fit:cover;box-shadow:0 0 20px rgba(255,20,147,.25);transition:transform .3s}
.nav-logo:hover .nav-logo-img{transform:rotate(12deg) scale(1.08)}
.logo-script{font-family:'a Auto Signature',cursive!important;font-size:2rem;font-weight:400!important;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-links{display:flex;gap:2rem}
.nav-links a{font-family:'Oswald',sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--txt2);transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--grad);transition:width .3s}
.nav-links a:hover{color:var(--pink2)}.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--pink2)}
.nav-cta{padding:.6rem 1.4rem;font-size:.78rem}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;z-index:1001}
.hamburger span{width:26px;height:2px;background:#fff;transition:all .3s;transform-origin:center}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{position:fixed;inset:0;background:rgba(12,12,24,.97);backdrop-filter:blur(20px);z-index:999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu ul{text-align:center;display:flex;flex-direction:column;gap:2rem}
.mobile-menu a{font-family:'Oswald',sans-serif;font-size:2rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:color .3s}
.mobile-menu a:hover{color:var(--pink)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:url('../images/fitnisa-gym-banner.jpeg') center/cover no-repeat,var(--bg)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(12,12,24,.82),rgba(12,12,24,.55)),linear-gradient(to bottom,rgba(12,12,24,.3),rgba(12,12,24,.7));z-index:1}
.hero-particles{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hero-particles span{position:absolute;border-radius:50%;opacity:0;animation:pFloat 8s ease-in-out infinite}
.hero-particles span:nth-child(odd){width:4px;height:4px;background:var(--pink2)}
.hero-particles span:nth-child(even){width:3px;height:3px;background:var(--gold)}
.hero-particles span:nth-child(1){left:8%;animation-delay:0s;animation-duration:7s}
.hero-particles span:nth-child(2){left:18%;animation-delay:1.2s;animation-duration:9s}
.hero-particles span:nth-child(3){left:32%;animation-delay:2.4s;animation-duration:6.5s}
.hero-particles span:nth-child(4){left:44%;animation-delay:.6s;animation-duration:8s}
.hero-particles span:nth-child(5){left:56%;animation-delay:3s;animation-duration:7.5s}
.hero-particles span:nth-child(6){left:68%;animation-delay:1.8s;animation-duration:9.5s}
.hero-particles span:nth-child(7){left:78%;animation-delay:4s;animation-duration:6s}
.hero-particles span:nth-child(8){left:88%;animation-delay:2s;animation-duration:8.5s}
.hero-particles span:nth-child(9){left:15%;animation-delay:3.5s;animation-duration:7s}
.hero-particles span:nth-child(10){left:50%;animation-delay:.5s;animation-duration:10s}
.hero-particles span:nth-child(11){left:72%;animation-delay:1s;animation-duration:6s;width:6px;height:6px;background:var(--pink)}
.hero-particles span:nth-child(12){left:92%;animation-delay:2.8s;animation-duration:8s;background:var(--pink3)}
@keyframes pFloat{0%{bottom:-5%;opacity:0;transform:translateX(0)}10%{opacity:.8}90%{opacity:.8}100%{bottom:110%;opacity:0;transform:translateX(25px)}}
.hero-watermark{position:absolute;right:2%;top:50%;transform:translateY(-50%);z-index:1;pointer-events:none;opacity:0;animation:fadeUp 1.5s ease .5s forwards}
.hero-watermark img{width:clamp(180px,28vw,400px);opacity:.15}
.hero-content{position:relative;z-index:2;padding:8rem 0 4rem}
.hero-badge{display:inline-block;font-family:'Oswald',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.25em;color:var(--pink2);padding:.5rem 1.2rem;border:1px solid rgba(255,105,180,.35);border-radius:50px;background:rgba(255,20,147,.08);backdrop-filter:blur(8px)}
.hero-title{font-size:clamp(3.5rem,13vw,8rem);font-weight:900;line-height:.88;margin:1.5rem 0}
.hero-line{display:block;opacity:0;transform:translateY(40px)}
.hero-line-pink{color:var(--pink);filter:drop-shadow(0 0 30px rgba(255,20,147,.3))}
.malkias-wrap{position:relative;display:inline-block;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-crown{-webkit-text-fill-color:initial;font-size:.45em;position:absolute;top:-.6em;left:.08em;animation:crownBounce 2.5s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(255,215,0,.5));line-height:1}
@keyframes crownBounce{0%,100%{transform:translateY(0) rotate(0)}30%{transform:translateY(-8px) rotate(-5deg)}60%{transform:translateY(-4px) rotate(3deg)}}
.hero-tagline{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(1rem,2.5vw,1.35rem);color:var(--txt2);max-width:520px;margin-bottom:2.5rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.scroll-indicator{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);width:24px;height:40px;border:2px solid rgba(255,255,255,.25);border-radius:12px;display:flex;justify-content:center;padding-top:6px}
.scroll-dot{width:4px;height:8px;background:var(--pink);border-radius:4px;animation:scrollBob 2s ease-in-out infinite}
@keyframes scrollBob{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(12px);opacity:.3}}
/* Hero anims */
.anim-fade,.anim-slide{opacity:0;transform:translateY(30px)}
body.loaded .anim-fade,body.loaded .anim-slide{animation:fadeUp .8s cubic-bezier(.16,1,.3,1) forwards}
body.loaded [data-d="0"]{animation-delay:.3s}
body.loaded [data-d="1"]{animation-delay:.5s}
body.loaded [data-d="2"]{animation-delay:.8s}
body.loaded [data-d="3"]{animation-delay:1.1s}
body.loaded [data-d="4"]{animation-delay:1.4s}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* ===== ABOUT ===== */
.about{background:linear-gradient(180deg,var(--bg),var(--bg2))}
.about::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--pink2),transparent);opacity:.3}
.about-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
.about-image{max-width:380px;margin:0 auto}
.image-frame{position:relative;border-radius:16px;overflow:hidden}
.image-frame::after{content:'';position:absolute;top:10px;left:10px;right:-10px;bottom:-10px;border:2px solid var(--pink);border-radius:16px;z-index:-1;opacity:.4;transition:all .4s}
.image-frame:hover::after{top:6px;left:6px;opacity:.7}
.image-frame img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:16px;transition:transform .8s cubic-bezier(.16,1,.3,1),filter .5s;filter:brightness(1.05) saturate(1.15) contrast(1.05)}
.image-frame:hover img{transform:scale(1.06)}
.image-shine{position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.08) 50%,transparent 70%);transition:left .8s ease;pointer-events:none}
.image-frame:hover .image-shine{left:130%}
.about-credentials{font-size:.9rem;color:var(--pink2);font-weight:600;margin-bottom:1.5rem}
.about-bio{color:var(--txt2);font-size:1.05rem;line-height:1.8;margin-bottom:2.5rem}
.stats-row{display:flex;gap:2.5rem;flex-wrap:wrap}
.stat{text-align:center}
.stat-number{font-family:'Oswald',sans-serif;font-size:3rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.stat-suffix{font-family:'Oswald',sans-serif;font-size:1.6rem;font-weight:700;color:var(--pink)}
.stat-label{display:block;font-size:.75rem;color:var(--txt2);letter-spacing:.08em;text-transform:uppercase;margin-top:.3rem}

/* ===== MOTIVATION ===== */
.motivation-banner{padding:var(--sp) 0;text-align:center;position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(12,12,24,.75),rgba(12,12,24,.6)),url('../images/arwa-kettlebell.jpeg') center/cover no-repeat,var(--bg2)}
.motivation-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,20,147,.12),transparent 60%);animation:glowPulse 4s ease-in-out infinite;pointer-events:none}
.motivation-text{font-size:clamp(2.2rem,7vw,5rem);font-weight:900;line-height:1.12;position:relative;z-index:1}

/* ===== FITNESS ===== */
.fitness{background:linear-gradient(180deg,var(--bg2),var(--bg))}
.services-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:3rem}
.service-card{background:var(--bg3);border:1px solid rgba(255,105,180,.1);border-radius:20px;overflow:hidden;transition:all .45s cubic-bezier(.16,1,.3,1)}
.service-card:hover{border-color:var(--pink);box-shadow:0 10px 50px rgba(255,20,147,.15),0 20px 60px rgba(0,0,0,.3);transform:translateY(-8px)}
.service-img{height:220px;overflow:hidden}
.service-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.16,1,.3,1);filter:brightness(1.1) saturate(1.2)}
.service-card:hover .service-img img{transform:scale(1.1)}
.service-body{padding:1.5rem 1.8rem 2rem}
.service-body h3{font-size:1.3rem;color:var(--pink2);margin-bottom:.6rem}
.service-body p{color:var(--txt2);font-size:.92rem;line-height:1.7;margin-bottom:1rem}
.service-price{font-family:'Oswald',sans-serif;font-size:1.1rem;font-weight:700;margin-bottom:1.2rem}
.marquee-wrapper{overflow:hidden;padding:1.5rem 0;mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.marquee-track{display:flex;width:max-content;animation:marquee 20s linear infinite}
.marquee-content{display:flex;gap:.8rem;padding-right:.8rem}
.marquee-tag{font-family:'Oswald',sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.45rem 1.1rem;border:1px solid var(--pink);border-radius:50px;color:var(--pink2);white-space:nowrap;transition:all .3s}
.marquee-tag:hover{background:var(--pink);color:#fff;box-shadow:0 0 20px var(--pink-g)}
@keyframes marquee{100%{transform:translateX(-50%)}}

/* ===== SWIMMING ===== */
.swimming{background:var(--bg);padding-top:0}
.swimming-hero{padding:var(--sp) 0;text-align:center;background:linear-gradient(180deg,rgba(0,25,50,.85),rgba(0,15,35,.8)),url('../images/swimming-poster.jpeg') center 30%/cover no-repeat,#0a1e2e;position:relative}
.swimming-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(to bottom,transparent,var(--bg))}
.timeline-heading{font-size:1.3rem;text-align:center;margin:3rem 0 2rem}
.timeline{max-width:650px;margin:0 auto 3rem;position:relative;padding-left:50px}
.timeline::before{content:'';position:absolute;left:18px;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--pink),var(--pink3),var(--pink2));border-radius:2px}
.tl-item{position:relative;margin-bottom:1.5rem}
.tl-dot{position:absolute;left:-50px;top:4px;width:24px;height:24px;background:var(--grad);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px var(--pink-g);z-index:1}
.tl-dot::after{content:'';width:8px;height:8px;background:#fff;border-radius:50%}
.tl-card{background:var(--bg3);border:1px solid rgba(255,105,180,.08);border-radius:14px;padding:1.2rem 1.5rem;transition:all .3s}
.tl-card:hover{border-color:var(--pink);box-shadow:0 0 25px rgba(255,20,147,.1);transform:translateX(5px)}
.tl-day{font-family:'Oswald',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.15em;color:var(--pink2);display:block;margin-bottom:.2rem}
.tl-card h4{font-family:'Oswald',sans-serif;font-size:1.05rem;color:#fff;margin-bottom:.3rem}
.tl-card p{color:var(--txt2);font-size:.88rem;line-height:1.5}
.swim-row{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem;align-items:start}
.swim-side{display:flex;flex-direction:column;gap:1.5rem}
.swim-cards{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem}
.swim-card{background:var(--bg3);border:1px solid rgba(255,105,180,.1);border-radius:20px;padding:2.5rem;transition:all .4s cubic-bezier(.16,1,.3,1)}
.swim-card.featured{border-color:var(--pink);box-shadow:0 0 35px rgba(255,20,147,.12)}
.swim-card:hover{transform:translateY(-6px);box-shadow:0 15px 50px rgba(255,20,147,.12),0 20px 60px rgba(0,0,0,.25)}
.swim-badge{display:inline-block;font-family:'Oswald',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.15em;background:var(--grad);color:#fff;padding:.3rem 1rem;border-radius:50px;margin-bottom:1rem}
.swim-card h3{font-family:'Oswald',sans-serif;font-size:1.5rem;color:var(--pink2);margin-bottom:.6rem}
.swim-price{font-family:'Oswald',sans-serif;color:var(--txt2);margin-bottom:1.5rem}
.big-num{font-size:2.5rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.swim-card ul{margin-bottom:1.5rem}
.swim-card li{padding:.35rem 0 .35rem 1.5rem;position:relative;color:var(--txt2);font-size:.92rem}
.swim-card li::before{content:'\2713';position:absolute;left:0;color:var(--pink2);font-weight:700}
.swim-info{display:grid;grid-template-columns:1fr;gap:1.5rem}
.info-box{background:var(--bg3);border:1px solid rgba(255,105,180,.08);border-radius:14px;padding:1.8rem}
.info-box h4{font-family:'Oswald',sans-serif;font-size:1rem;color:var(--pink2);margin-bottom:1rem;letter-spacing:.12em}
.info-box li{padding:.3rem 0 .3rem 1rem;position:relative;color:var(--txt2);font-size:.88rem}
.info-box li::before{content:'\2022';position:absolute;left:0;color:var(--pink)}
.steps{display:flex;flex-direction:column;gap:.5rem}
.steps span{color:var(--txt2);font-size:.88rem}.steps b{color:var(--pink);font-family:'Oswald',sans-serif;font-size:1.1rem;margin-right:.5rem}

/* ===== EFFECT ===== */
.effect{background:linear-gradient(180deg,var(--bg),var(--bg2))}
.effect-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
.effect-card{background:var(--bg3);border:1px solid rgba(255,255,255,.05);border-radius:18px;padding:2rem;text-align:center;transition:all .4s cubic-bezier(.16,1,.3,1)}
.effect-card:hover{border-color:var(--pink);transform:translateY(-8px);box-shadow:0 15px 50px rgba(0,0,0,.3),0 0 30px rgba(255,20,147,.1)}
.effect-icon{font-size:2.5rem;margin-bottom:1rem}
.effect-card h3{font-size:1.05rem;color:var(--pink2);margin-bottom:.6rem}
.effect-card p{color:var(--txt2);font-size:.9rem;line-height:1.7}

/* ===== WHY ===== */
.why-section{background:linear-gradient(180deg,var(--bg2),var(--bg))}
.why-grid{display:grid;grid-template-columns:1fr;gap:1.2rem;margin-top:2rem}
.why-item{display:flex;gap:1rem;padding:1.3rem;background:var(--bg3);border-radius:14px;border:1px solid rgba(255,255,255,.04);transition:all .35s cubic-bezier(.16,1,.3,1)}
.why-item:hover{border-color:var(--pink);transform:translateX(6px);box-shadow:0 0 25px rgba(255,20,147,.08)}
.why-icon{font-size:1.6rem;flex-shrink:0;width:42px;height:42px;background:rgba(255,20,147,.1);border-radius:12px;display:flex;align-items:center;justify-content:center}
.why-item h4{font-family:'Oswald',sans-serif;font-size:.95rem;color:var(--pink2);margin-bottom:.2rem}
.why-item p{color:var(--txt2);font-size:.85rem}

/* ===== TESTIMONIALS ===== */
.testimonials{background:linear-gradient(180deg,var(--bg),var(--bg2))}
.testimonial-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:2rem}
.testimonial-card{background:var(--bg3);border:1px solid rgba(255,105,180,.08);border-radius:18px;padding:2rem;position:relative;transition:all .4s cubic-bezier(.16,1,.3,1);overflow:hidden}
.testimonial-card::before{content:'\\201C';position:absolute;top:10px;right:20px;font-size:5rem;font-family:Georgia,serif;color:rgba(255,20,147,.08);line-height:1}
.testimonial-card:hover{border-color:var(--pink);transform:translateY(-4px);box-shadow:0 10px 40px rgba(255,20,147,.08),0 15px 50px rgba(0,0,0,.2)}
.testi-stars{color:var(--gold);font-size:1.1rem;letter-spacing:.1em;margin-bottom:.8rem}
.testi-quote{color:var(--txt2);font-size:.92rem;line-height:1.75;font-style:italic;margin-bottom:1.2rem;position:relative;z-index:1}
.testi-author{display:flex;align-items:center;gap:.8rem}
.testi-avatar{width:42px;height:42px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-weight:700;font-size:1.1rem;color:#fff;flex-shrink:0}
.testi-author strong{font-family:'Oswald',sans-serif;font-size:.9rem;color:var(--pink2);display:block;letter-spacing:.03em}
.testi-author span{font-size:.75rem;color:var(--txt2);display:block;margin-top:1px}
@media(min-width:768px){.testimonial-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.testimonial-grid{grid-template-columns:1fr 1fr 1fr}}

/* ===== GALLERY ===== */
.gallery{background:var(--bg2)}
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:200px;gap:1rem;margin-top:2rem}
.g-item{position:relative;border-radius:14px;overflow:hidden;background:var(--bg3)}
.g-tall{grid-row:span 2}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.16,1,.3,1),filter .4s;filter:brightness(1.1) saturate(1.2)}
.g-item:hover img{transform:scale(1.12);filter:brightness(1.2) saturate(1.3)}
.g-label{position:absolute;bottom:0;left:0;right:0;padding:1rem 1.2rem;background:linear-gradient(transparent,rgba(0,0,0,.7));font-family:'Oswald',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.08em;color:var(--pink2);opacity:0;transform:translateY(10px);transition:all .4s}
.g-item:hover .g-label{opacity:1;transform:translateY(0)}

/* ===== PRICING ===== */
.pricing{background:linear-gradient(180deg,var(--bg),var(--bg2))}
.pricing-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem}
.p-card{background:var(--bg3);border-radius:18px;padding:2rem 1.8rem;border-top:4px solid var(--pink);text-align:center;position:relative;transition:all .4s cubic-bezier(.16,1,.3,1)}
.p-card:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,0,0,.4),0 0 30px rgba(255,20,147,.1)}
.p-card.popular{border-image:var(--grad) 1;box-shadow:0 0 30px rgba(255,20,147,.1);background:linear-gradient(180deg,rgba(255,20,147,.06),var(--bg3) 40%)}
.pop-badge{position:absolute;top:-1px;right:1.2rem;background:var(--grad);color:#fff;font-family:'Oswald',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.1em;padding:.35rem .8rem;border-radius:0 0 8px 8px}
.p-card h4{font-family:'Oswald',sans-serif;font-size:1.1rem;color:var(--pink2);margin-bottom:.2rem}
.p-sub{font-size:.82rem;color:var(--txt2);margin-bottom:1.2rem}
.p-price{font-family:'Oswald',sans-serif;margin-bottom:1.2rem;color:var(--txt2)}
.p-price span{font-size:2.5rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.p-card ul{text-align:left;margin-bottom:1.5rem}
.p-card li{padding:.35rem 0 .35rem 1.3rem;position:relative;color:var(--txt2);font-size:.85rem}
.p-card li::before{content:'\2713';position:absolute;left:0;color:var(--pink2);font-weight:700}
.pricing-note{text-align:center;color:var(--txt2);font-size:.82rem;font-style:italic}

/* ===== CONTACT ===== */
.contact{text-align:center;background:linear-gradient(135deg,rgba(12,12,24,.85),rgba(12,12,24,.75)),url('../images/graduation-stage.jpeg') center/cover no-repeat,var(--bg);position:relative}
.contact::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,20,147,.08),transparent 50%);animation:glowPulse 5s ease-in-out infinite;pointer-events:none}
.contact-inner{position:relative;z-index:2}
.contact-sub{font-size:1.1rem;color:var(--txt2);margin-bottom:2.5rem}
.contact-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ===== FOOTER ===== */
.footer{background:#060610;padding:2.5rem 0;text-align:center}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--pink2),transparent);opacity:.25}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:.8rem}
.footer-brand{display:flex;align-items:center;gap:.5rem}
.footer-logo-img{height:40px;width:40px;border-radius:50%;object-fit:cover}
.footer-tag{font-family:'Playfair Display',serif;font-style:italic;color:var(--txt2);font-size:.9rem}
.footer-links{display:flex;gap:1rem}
.footer-links a{color:var(--txt2);transition:all .3s;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.1)}
.footer-links a:hover{color:var(--pink);border-color:var(--pink);box-shadow:0 0 15px rgba(255,20,147,.15);transform:translateY(-2px)}
.footer-copy{font-size:.75rem;color:rgba(255,255,255,.25)}

/* ===== WHATSAPP ===== */
.wa-float{position:fixed;bottom:2rem;right:2rem;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);z-index:900;transition:transform .3s;animation:waPulse 2.5s ease-in-out infinite}
.wa-float:hover{transform:scale(1.12)}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 30px rgba(37,211,102,.7),0 0 0 12px rgba(37,211,102,.08)}}

/* ===== RESPONSIVE ===== */
@media(min-width:768px){
  .about-grid{grid-template-columns:1fr 1.2fr}
  .services-grid{grid-template-columns:1fr 1fr}
  .swim-row{grid-template-columns:1.2fr 1fr}
  .effect-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:230px}
}
@media(min-width:1024px){
  .nav-links{display:flex}
  .effect-grid{grid-template-columns:repeat(4,1fr)}
  .why-grid{grid-template-columns:repeat(3,1fr)}
  .pricing-grid{grid-template-columns:repeat(4,1fr)}
  .hero-content{max-width:62%}
  .gallery-grid{grid-auto-rows:260px;gap:1.5rem}
}
@media(max-width:767px){
  .nav-links,.nav-cta{display:none}.hamburger{display:flex}
  .hero-title{font-size:clamp(3rem,16vw,5rem)}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .scroll-indicator,.hero-watermark{display:none}
  .stats-row{justify-content:center}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .contact-btns{flex-direction:column;align-items:center}
  .custom-cursor{display:none!important}
  .timeline{padding-left:42px}.tl-dot{left:-42px;width:20px;height:20px}
  .music-player{bottom:1rem;left:1rem}
  .mp-panel{width:250px}
  .mp-main-btn{width:40px;height:40px}
  .mp-main-btn svg{width:15px;height:15px}
  .mp-now{display:none!important}
  .mp-expand{width:28px;height:28px}
}

/* ===== FOOTER CREDIT ===== */
.footer-credit{font-size:.82rem;color:var(--txt2);display:flex;align-items:center;gap:.3rem;justify-content:center;flex-wrap:wrap}
.heart{color:#FF1493;font-size:1rem;animation:heartBeat 1.2s ease-in-out infinite}
@keyframes heartBeat{0%,100%{transform:scale(1)}15%{transform:scale(1.25)}30%{transform:scale(1)}45%{transform:scale(1.15)}}
.twinfusion-link{color:var(--pink2);font-weight:600;transition:color .3s;text-decoration:underline;text-underline-offset:2px}
.twinfusion-link:hover{color:var(--pink)}

/* ===== MUSIC PLAYER ===== */
.music-player{position:fixed;bottom:1.5rem;left:1.5rem;z-index:800;display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}
.mp-panel{display:none;width:280px;background:rgba(12,12,24,.95);backdrop-filter:blur(20px);border:1px solid rgba(255,105,180,.15);border-radius:18px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5);animation:mpSlideUp .3s ease}
.mp-panel.open{display:block}
@keyframes mpSlideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.mp-header{padding:.8rem 1rem .5rem;border-bottom:1px solid rgba(255,105,180,.08);display:flex;align-items:center;gap:.5rem;color:var(--pink2);font-family:'Oswald',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.2em}
.mp-tracks{max-height:240px;overflow-y:auto}
.mp-tracks::-webkit-scrollbar{width:3px}.mp-tracks::-webkit-scrollbar-thumb{background:var(--pink);border-radius:3px}
.mp-track{width:100%;display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;background:none;border:none;color:var(--txt2);font-size:.88rem;text-align:left;transition:background .2s;cursor:pointer}
.mp-track:hover{background:rgba(255,20,147,.05)}
.mp-track.active{background:rgba(255,20,147,.1);color:var(--pink2)}
.mp-num{font-family:'Oswald',sans-serif;font-size:.75rem;color:rgba(255,255,255,.25);width:18px;text-align:center;flex-shrink:0}
.mp-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mp-dur{font-size:.72rem;color:rgba(255,255,255,.2);flex-shrink:0}
/* Equalizer bars */
.mp-eq{display:flex;align-items:flex-end;gap:2px;height:14px;width:18px;flex-shrink:0}
.mp-eq i{width:3px;background:var(--pink);border-radius:1px;display:block}
.mp-eq i:nth-child(1){animation:eq1 .8s ease-in-out infinite;height:40%}
.mp-eq i:nth-child(2){animation:eq2 .6s ease-in-out infinite .15s;height:70%}
.mp-eq i:nth-child(3){animation:eq3 .7s ease-in-out infinite .1s;height:50%}
.mp-eq.paused i{animation:none;height:30%}
@keyframes eq1{0%,100%{height:30%}50%{height:80%}}
@keyframes eq2{0%,100%{height:60%}50%{height:30%}}
@keyframes eq3{0%,100%{height:50%}50%{height:100%}}
.mp-controls{padding:.6rem 1rem .5rem;border-top:1px solid rgba(255,105,180,.08)}
.mp-progress{width:100%;height:3px;background:rgba(255,255,255,.08);border-radius:3px;margin-bottom:.6rem;overflow:hidden;cursor:pointer}
.mp-bar{height:100%;width:0;background:var(--grad);border-radius:3px;transition:width .2s}
.mp-btns{display:flex;align-items:center;justify-content:center;gap:1.2rem}
.mp-btns button{background:none;border:none;color:rgba(255,255,255,.4);transition:color .2s;cursor:pointer;display:flex;align-items:center;justify-content:center}
.mp-btns button:hover{color:var(--pink)}
.mp-play-btn{width:38px;height:38px;border-radius:50%;background:rgba(255,20,147,.15)!important;color:var(--pink)!important;display:flex;align-items:center;justify-content:center}
.mp-play-btn:hover{background:rgba(255,20,147,.25)!important}
.mp-tagline{padding:.5rem 1rem .8rem;font-size:.72rem;color:var(--txt2);font-style:italic;text-align:center;border-top:1px solid rgba(255,105,180,.05);cursor:pointer;transition:color .2s}
.mp-tagline:hover{color:var(--pink2)}
/* Mini bar */
.mp-mini{display:flex;align-items:center;gap:.5rem}
.mp-now{display:none;background:rgba(12,12,24,.9);backdrop-filter:blur(10px);border:1px solid rgba(255,105,180,.12);border-radius:50px;padding:.35rem .8rem;display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--pink2);max-width:160px}
.mp-now.hidden{display:none}
#mpNowName{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mini-eq{transform:scale(.8)}
.mp-expand{width:32px;height:32px;border-radius:50%;background:rgba(12,12,24,.8);backdrop-filter:blur(10px);border:1px solid rgba(255,105,180,.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);cursor:pointer;transition:all .2s}
.mp-expand:hover{color:var(--pink);border-color:var(--pink)}
.mp-expand.flipped svg{transform:rotate(180deg)}
.mp-main-btn{width:48px;height:48px;border-radius:50%;background:var(--grad);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px var(--pink-g);transition:all .3s}
.mp-main-btn:hover{transform:scale(1.08);box-shadow:0 6px 30px var(--pink-g)}
.mp-main-btn.playing{animation:btnPulse 2s ease-in-out infinite}
@keyframes btnPulse{0%,100%{box-shadow:0 4px 20px var(--pink-g)}50%{box-shadow:0 4px 30px var(--pink-g),0 0 0 8px rgba(255,20,147,.08)}}
