*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --white: #f0f8ff; --dark: #051428; --navy: #0a2d5e;
  --navy-lt: #1a4d8a; --cyan: #3b8ce8; --cyan-lt: #7eb3f5; --warm: #f0f4fa;
  --font-d: 'Bebas Neue', sans-serif;
  --font-b: 'DM Sans', sans-serif;
  --font-i: 'Playfair Display', Georgia, serif;
}
html { scroll-behavior: smooth; overflow-x: clip; }
body { background: var(--dark); color: var(--white); font-family: var(--font-b); overflow-x: clip; cursor: none; }

/* CURSOR */
.cursor { position:fixed; width:10px; height:10px; background:var(--cyan); border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); mix-blend-mode:difference; transition:width .3s,height .3s; }
.cursor-ring { position:fixed; width:36px; height:36px; border:1px solid rgba(59,140,232,.5); border-radius:50%; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:width .4s,height .4s; }

/* GRAIN */
.grain { position:fixed; inset:0; pointer-events:none; z-index:500; opacity:.03; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); background-size:180px; }

/* HERO */
#hero { height:100vh; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; background: radial-gradient(ellipse 80% 70% at 78% 18%, rgba(59,140,232,.25) 0%, transparent 62%), radial-gradient(ellipse 55% 65% at 8% 82%, rgba(10,45,94,.6) 0%, transparent 58%), radial-gradient(ellipse 60% 50% at 45% 45%, rgba(13,58,110,.4) 0%, transparent 70%), #0c2e60; }

.hero-parallax { position:relative; z-index:10; will-change:transform; }
.hero-content { text-align:center; padding:2rem; }
.hero-eyebrow { font-family:var(--font-b); font-size:.65rem; letter-spacing:.45em; text-transform:uppercase; color:rgba(240,248,255,.55); margin-bottom:2.5rem; opacity:0; animation:blurIn .6s .05s cubic-bezier(.16,1,.3,1) forwards; }
.hero-logo { width:min(620px,82vw); height:auto; display:block; margin:0 auto; opacity:0; filter:drop-shadow(0 0 40px rgba(59,140,232,.35)) drop-shadow(0 4px 20px rgba(0,0,0,.4)); animation:logoReveal 1s .1s cubic-bezier(.16,1,.3,1) forwards; }
@keyframes logoReveal { 0%{opacity:0;transform:scale(.88) translateY(20px)} 100%{opacity:1;transform:scale(1) translateY(0)} }
.hero-sub { margin-top:2.2rem; font-size:.9rem; font-weight:300; color:rgba(240,248,255,.45); letter-spacing:.12em; opacity:0; animation:blurIn .6s .5s cubic-bezier(.16,1,.3,1) forwards; }
.hero-cta { margin-top:3rem; display:inline-flex; align-items:center; gap:1rem; background:transparent; border:1px solid var(--cyan); color:var(--cyan); font-family:var(--font-b); font-size:.8rem; font-weight:500; letter-spacing:.15em; text-transform:uppercase; padding:1rem 2.5rem; text-decoration:none; opacity:0; animation:blurIn .6s .7s cubic-bezier(.16,1,.3,1) forwards; transition:all .4s; cursor:none; backdrop-filter:blur(4px); }
.hero-cta:hover { background:var(--cyan); color:var(--dark); transform:translateY(-2px); box-shadow:0 0 40px rgba(59,140,232,.3); }
.scroll-indicator { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.5rem; font-family:var(--font-b); font-size:.6rem; letter-spacing:.3em; text-transform:uppercase; color:rgba(240,248,255,.3); animation:blurIn 1s 1.6s both; }
.scroll-line { width:1px; height:50px; background:linear-gradient(to bottom,var(--cyan),transparent); animation:scrollPulse 2s infinite; }

/* STACK SECTIONS */
.stack-section {}
/* SCRUB */
#scrub-wrapper { height:300vh; position:relative; }
#scrub-sticky { position:sticky; top:0; height:100vh; overflow:hidden; display:flex; align-items:center; justify-content:center; }
#scrub-video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; pointer-events:none; }
.scrub-overlay { position:absolute; inset:0; background:linear-gradient(to bottom,rgba(12,12,10,.3) 0%,transparent 30%,transparent 70%,rgba(12,12,10,.5) 100%); pointer-events:none; z-index:2; }
.scrub-text { position:absolute; z-index:10; text-align:center; padding:2rem; opacity:0; transform:translateY(30px); transition:opacity .6s,transform .6s; pointer-events:none; top:32%; left:0; right:0; }
.scrub-text.visible { opacity:1; transform:translateY(0); }
.scrub-text h2 { font-family:var(--font-d); font-size:clamp(3rem,8vw,7rem); line-height:1; color:var(--white); text-shadow:0 0 40px rgba(0,0,0,.8); }
.scrub-text h2 em { color:var(--cyan); font-family:var(--font-i); font-size:.6em; }
.scrub-text p { margin-top:1rem; font-size:1rem; font-weight:300; color:rgba(250,250,248,.85); text-shadow:0 0 20px rgba(0,0,0,.9); letter-spacing:.05em; }
.scrub-progress { position:absolute; bottom:3rem; left:50%; transform:translateX(-50%); z-index:10; display:flex; flex-direction:column; align-items:center; gap:.8rem; }
.phase-labels { display:flex; gap:3rem; margin-bottom:.5rem; }
.phase-label { font-family:var(--font-b); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(250,250,248,.25); transition:color .4s; white-space:nowrap; }
.phase-label.active { color:var(--cyan); }
.progress-track { width:200px; height:2px; background:rgba(250,250,248,.2); overflow:hidden; }
.progress-fill { height:100%; background:var(--cyan); width:0%; transition:width .1s linear; }
.progress-label { font-family:var(--font-b); font-size:.6rem; letter-spacing:.3em; text-transform:uppercase; color:rgba(250,250,248,.4); }

/* SIDE NAV */
#side-nav { position:fixed; right:2rem; top:50%; transform:translateY(-50%); z-index:1000; display:flex; flex-direction:column; align-items:flex-end; gap:1.8rem; }
.nav-dot-wrap { display:flex; align-items:center; gap:.8rem; cursor:none; text-decoration:none; }
.nav-dot-label { font-family:var(--font-b); font-size:.55rem; letter-spacing:.25em; text-transform:uppercase; color:rgba(240,248,255,.3); opacity:0; transform:translateX(8px); transition:all .3s; white-space:nowrap; }
.nav-dot-wrap:hover .nav-dot-label, .nav-dot-wrap.active .nav-dot-label { opacity:1; transform:translateX(0); color:var(--cyan); }
.nav-dot { width:5px; height:5px; border-radius:50%; background:rgba(240,248,255,.25); transition:all .3s; flex-shrink:0; }
.nav-dot-wrap.active .nav-dot { background:var(--cyan); box-shadow:0 0 12px rgba(59,140,232,.6); width:7px; height:7px; }
@media(max-width:768px){#side-nav{display:none;}}

/* SERVICES */
#services-section { background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(19,68,160,.14) 0%,transparent 100%),#0d3a6e; position:relative; }
.services-header, .cs-outer, .extras-row { position:relative; z-index:2; }
.services-header { padding:14vh 8vw 4vh; }
.section-tag { font-family:var(--font-b); font-size:.65rem; letter-spacing:.4em; text-transform:uppercase; color:var(--cyan-lt); margin-bottom:1rem; display:block; }
.section-title { font-family:var(--font-d); font-size:clamp(3rem,7vw,6rem); line-height:.95; color:var(--white); }
.section-title em { font-family:var(--font-i); color:var(--cyan-lt); font-size:.7em; }
/* CAROUSEL */
.cs-outer { padding:6vh 0 12vh; }
.cs-stage { position:relative; }
.cs-wrap { overflow:hidden; }
.cs-track { display:flex; gap:clamp(14px,1.6vw,22px); will-change:transform; transition:transform .65s cubic-bezier(.25,.46,.45,.94); user-select:none; }
.cs-card { flex-shrink:0; width:min(540px,78vw); height:min(340px,52vh); border-radius:18px; border:1px solid rgba(255,255,255,.06); padding:clamp(1.5rem,2.4vw,2rem); position:relative; overflow:hidden; transition:opacity .5s,transform .5s,box-shadow .5s; opacity:.2; transform:scale(.87); cursor:pointer; display:flex; flex-direction:column; gap:.6rem; }
.cs-card.cs-active { opacity:1; transform:scale(1); cursor:default; border-color:rgba(255,255,255,.13); }
.cs-card::before { content:''; position:absolute; inset:0; border-radius:18px; border:1px solid rgba(255,255,255,.07); pointer-events:none; z-index:3; }
.cs-card::after { content:''; position:absolute; top:0; left:clamp(1.5rem,2.4vw,2rem); width:40px; height:2px; background:var(--accent,rgba(59,140,232,.65)); pointer-events:none; z-index:3; }
.cs-bg-icon { position:absolute; right:-4%; bottom:-8%; width:38%; opacity:.07; pointer-events:none; z-index:0; color:#fff; transform:rotate(-8deg); transition:opacity .6s; }
.cs-bg-icon svg { width:100%; height:auto; display:block; }
.cs-card.cs-active .cs-bg-icon { opacity:.14; }
.cs-bg-icon-fill { position:absolute; right:-4%; bottom:-8%; width:38%; pointer-events:none; z-index:1; color:var(--accent); transform:rotate(-8deg); clip-path:inset(100% 0 0% 0); transition:clip-path 1.1s cubic-bezier(.4,0,.2,1); }
.cs-bg-icon-fill svg { width:100%; height:auto; display:block; }
.cs-card.cs-active .cs-bg-icon-fill { clip-path:inset(0% 0 0% 0); }
.cs-top { position:relative; z-index:2; }
.cs-tag { font-family:var(--font-b); font-size:.46rem; letter-spacing:.3em; text-transform:uppercase; color:var(--accent,rgba(59,140,232,.9)); background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09); padding:.22rem .65rem; border-radius:3px; display:inline-block; }
.cs-icon { display:none; }
.cs-num { position:absolute; top:clamp(1.3rem,2.2vw,1.8rem); right:clamp(1.3rem,2.2vw,1.8rem); font-family:var(--font-d); font-size:clamp(2rem,3.5vw,2.8rem); line-height:1; color:var(--accent,rgba(255,255,255,.5)); opacity:.3; pointer-events:none; user-select:none; z-index:2; }
.cs-main { flex:1; display:flex; flex-direction:column; justify-content:center; gap:.4rem; position:relative; z-index:2; }
.cs-title { font-family:var(--font-d); font-size:clamp(2rem,3.4vw,2.9rem); color:#fff; line-height:.92; letter-spacing:.01em; }
.cs-desc { font-family:var(--font-b); font-size:.78rem; letter-spacing:.03em; color:rgba(255,255,255,.38); line-height:1.65; }
.cs-feats { display:flex; flex-wrap:wrap; gap:.38rem; position:relative; z-index:2; }
.cs-feat { font-family:var(--font-b); font-size:.44rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.4); background:rgba(255,255,255,.045); border:1px solid rgba(255,255,255,.08); padding:.22rem .58rem; border-radius:3px; white-space:nowrap; }
.cs-cta { font-family:var(--font-b); font-size:.52rem; letter-spacing:.2em; text-transform:uppercase; color:var(--accent,var(--cyan)); text-decoration:none; opacity:0; transform:translateY(6px); transition:opacity .4s,transform .4s; display:flex; align-items:center; gap:.5rem; position:relative; z-index:2; }
.cs-card.cs-active .cs-cta { opacity:.8; transform:none; }
.cs-cta:hover { opacity:1 !important; }
.cs-popular { background:rgba(59,140,232,.12); color:var(--cyan); font-size:.4rem; letter-spacing:.12em; padding:.15rem .45rem; border:1px solid rgba(59,140,232,.28); margin-left:.4rem; vertical-align:middle; white-space:nowrap; }
/* arrows */
.cs-arr { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:50%; width:40px; height:40px; display:flex; align-items:center; justify-content:center; cursor:pointer; color:rgba(255,255,255,.55); font-size:.85rem; transition:all .25s; flex-shrink:0; }
.cs-arr:hover { background:rgba(59,140,232,.18); border-color:rgba(59,140,232,.5); color:#fff; }
/* footer */
.cs-footer { display:flex; align-items:center; justify-content:center; gap:1.4rem; padding:1.6rem 0 0; }
.cs-counter { font-family:var(--font-d); font-size:1.1rem; letter-spacing:.05em; color:rgba(255,255,255,.35); display:flex; align-items:baseline; gap:.35rem; }
.cs-counter em { color:var(--cyan); font-style:normal; font-size:1.6rem; line-height:1; }
.cs-total { font-size:.75rem; }
/* Extras */
.extras-row { padding:4vh 8vw 10vh; display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(59,140,232,.05); }
.extra-item { background:#0d3a6e; padding:2rem 2rem; }
.extra-name { font-family:var(--font-d); font-size:1.4rem; color:var(--white); margin-bottom:.4rem; }
.extra-tag { font-size:.58rem; letter-spacing:.3em; text-transform:uppercase; color:var(--cyan); }
@media(max-width:768px){ .extras-row{grid-template-columns:1fr;} }

/* BEFORE/AFTER */
#ba-section { background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(19,68,160,.14) 0%,transparent 100%),#0d3a6e; padding:8vh 0 10vh; position:relative; }
.ba-header { padding:7vh 8vw 8vh; }
.ba-track { display:flex; gap:clamp(16px,2vw,24px); padding:1rem 0 1.5rem; padding-left:8vw; scroll-padding-left:8vw; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; }
.ba-track::-webkit-scrollbar { display:none; }
.ba-card { flex-shrink:0; width:clamp(260px,30vw,380px); border-radius:18px; overflow:hidden; border:1px solid rgba(255,255,255,.07); background:#0d1a2e; scroll-snap-align:start; position:relative; }
.ba-card:last-child  { margin-right:8vw; }
@media(max-width:768px){ .ba-card{ width:75vw; } }
.ba-footer { display:flex; align-items:center; justify-content:center; gap:1.4rem; padding:2rem 8vw 0; }
.ba-arr { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:50%; width:40px; height:40px; display:flex; align-items:center; justify-content:center; cursor:pointer; color:rgba(255,255,255,.55); font-size:.85rem; transition:all .25s; flex-shrink:0; }
.ba-arr:hover { background:rgba(59,140,232,.18); border-color:rgba(59,140,232,.5); color:#fff; }
.ba-counter { font-family:var(--font-d); font-size:1.1rem; letter-spacing:.05em; color:rgba(255,255,255,.35); display:flex; align-items:baseline; gap:.35rem; }
.ba-counter em { color:var(--cyan); font-style:normal; font-size:1.6rem; line-height:1; }
.ba-slider { position:relative; width:100%; aspect-ratio:4/3; overflow:hidden; user-select:none; }
.ba-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.ba-before-wrap { position:absolute; inset:0; overflow:hidden; width:50%; z-index:6; }
.ba-before-wrap img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ba-handle { position:absolute; top:0; bottom:0; left:50%; transform:translateX(-50%); width:42px; display:flex; flex-direction:column; align-items:center; justify-content:center; cursor:ew-resize; z-index:10; }
.ba-line { position:absolute; top:0; bottom:0; left:50%; width:2px; background:rgba(255,255,255,.9); transform:translateX(-50%); box-shadow:0 0 10px rgba(255,255,255,.65), 0 0 24px rgba(59,140,232,.4); }
.ba-btn { width:36px; height:36px; border-radius:50%; background:#fff; display:flex; align-items:center; justify-content:center; font-size:.85rem; color:#0c1a26; z-index:1; flex-shrink:0; animation:baGlow 2.2s ease-in-out infinite; }
@keyframes baGlow { 0%,100%{box-shadow:0 0 0 3px rgba(255,255,255,.14),0 0 16px rgba(59,140,232,.4),0 2px 12px rgba(0,0,0,.5)} 50%{box-shadow:0 0 0 6px rgba(255,255,255,.22),0 0 32px rgba(59,140,232,.72),0 2px 12px rgba(0,0,0,.5)} }
.ba-tag { position:absolute; top:.8rem; padding:.25rem .7rem; font-family:var(--font-b); font-size:.55rem; letter-spacing:.18em; text-transform:uppercase; font-weight:600; border-radius:4px; z-index:5; white-space:nowrap; }
.ba-tag-before { left:.8rem; background:rgba(0,0,0,.55); color:rgba(255,255,255,.7); }
.ba-tag-after { right:.8rem; background:#22c55e; color:#fff; }
.ba-info { padding:1.2rem 1.4rem; }
.ba-info h3 { font-family:var(--font-d); font-size:1.5rem; color:#fff; line-height:1; }
.ba-info p { font-family:var(--font-b); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-top:.35rem; }
.ba-hint { padding:.8rem 8vw 0; font-family:var(--font-b); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.2); display:flex; align-items:center; gap:.5rem; }

/* REVEAL */
.reveal { opacity:0; transform:translateY(40px); transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1); }
.reveal.visible { opacity:1; transform:translateY(0); }
.rd1{transition-delay:.1s;} .rd2{transition-delay:.2s;} .rd3{transition-delay:.3s;} .rd4{transition-delay:.4s;}

@keyframes blurIn { from{opacity:0;filter:blur(24px)} to{opacity:1;filter:blur(0)} }
@keyframes scrollPulse { 0%,100%{opacity:.3} 50%{opacity:1} }
@media(max-width:768px){ .phase-labels{display:none} }
@media(max-width:768px){ .bubbles-bg{display:none;} #hero .bubbles-bg{display:block;} }

/* BOOKING */
#cta-section { background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(19,68,160,.14) 0%,transparent 100%),#0d3a6e; padding:10vh 5vw 12vh; position:relative; }
.bk-layout { display:grid; grid-template-columns:1fr 1.15fr; gap:5vw; align-items:start; max-width:1120px; margin:0 auto; }
.bk-left { padding-top:1rem; }
.bk-right { padding-top:14rem; }
.bk-sub { color:rgba(240,248,255,.32); font-family:var(--font-b); font-size:.82rem; line-height:1.75; margin:1rem 0 2.5rem; letter-spacing:.03em; }
.tk-wrap { margin-bottom:2rem; }
.tk-hwrap { display:grid; grid-template-columns:repeat(4,1fr); position:relative; padding:.4rem 0; }
.tk-hspine { position:absolute; left:12.5%; right:12.5%; height:2px; background:rgba(255,255,255,.07); border-radius:2px; overflow:hidden; top:calc(56px + .8rem + 5px); z-index:0; }
.tk-hsf { height:100%; width:0%; background:linear-gradient(to right,var(--cyan),#22c55e,#63b3ed,#fbbf24); transition:width .6s cubic-bezier(.4,0,.2,1); }
.tk-hstep { display:flex; flex-direction:column; align-items:center; gap:.5rem; text-align:center; opacity:.18; transition:opacity .5s,transform .5s; transform:translateY(3px); position:relative; z-index:1; padding:.3rem .2rem; }
.tk-hstep.tk-on { opacity:1; transform:translateY(0); }
.tk-hstep.tk-done { opacity:.48; transform:translateY(0); }
.tk-hicon { width:56px; height:56px; border-radius:16px; display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); color:rgba(255,255,255,.2); flex-shrink:0; transition:all .45s cubic-bezier(.34,1.56,.64,1); }
.tk-hstep.tk-on .tk-hicon { background:color-mix(in srgb,var(--rc) 12%,transparent); border-color:color-mix(in srgb,var(--rc) 38%,transparent); color:var(--rc); box-shadow:0 8px 28px color-mix(in srgb,var(--rc) 22%,transparent); transform:scale(1.1) translateY(-2px); }
.tk-hstep.tk-done .tk-hicon { color:rgba(255,255,255,.32); }
.tk-hdot { width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.1); border:1.5px solid rgba(255,255,255,.12); z-index:2; transition:all .45s cubic-bezier(.34,1.56,.64,1); flex-shrink:0; }
.tk-hstep.tk-on .tk-hdot { background:var(--rc); border-color:var(--rc); box-shadow:0 0 0 3px color-mix(in srgb,var(--rc) 18%,transparent),0 0 12px var(--rc); transform:scale(1.4); }
.tk-hstep.tk-done .tk-hdot { background:rgba(255,255,255,.28); border-color:rgba(255,255,255,.28); }
.tk-hnum { font-family:var(--font-d); font-size:1.3rem; color:rgba(255,255,255,.05); line-height:1; transition:color .35s; }
.tk-hstep.tk-on .tk-hnum { color:color-mix(in srgb,var(--rc) 50%,transparent); }
.tk-hlabel { font-family:var(--font-b); font-size:.62rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(240,248,255,.28); transition:color .35s; }
.tk-hstep.tk-on .tk-hlabel { color:#fff; }
.tk-hstep.tk-done .tk-hlabel { color:rgba(240,248,255,.45); }
.tk-hsub { font-size:.55rem; color:rgba(240,248,255,.18); letter-spacing:.03em; line-height:1.4; transition:color .35s; }
.tk-hstep.tk-on .tk-hsub { color:color-mix(in srgb,var(--rc) 65%,transparent); }
.bk-trust { display:flex; flex-direction:column; gap:.65rem; padding:.9rem 1.1rem; background:rgba(255,255,255,.03); border-radius:12px; border:1px solid rgba(255,255,255,.07); }
.bk-trust-top { display:flex; align-items:center; gap:.7rem; }
.bk-trust-stars { color:#f59e0b; font-size:.88rem; letter-spacing:1px; }
.bk-trust-text { font-family:var(--font-b); font-size:.6rem; color:rgba(240,248,255,.45); letter-spacing:.05em; }
.bk-trust-div { height:1px; background:rgba(255,255,255,.06); }
.bk-trust-areas { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.bk-area-pill { display:flex; align-items:center; gap:.45rem; }
.bk-area-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.bk-area-city { font-family:var(--font-b); font-size:.68rem; font-weight:700; color:rgba(240,248,255,.65); }
.bk-area-note { font-family:var(--font-b); font-size:.58rem; color:rgba(240,248,255,.22); margin-left:auto; letter-spacing:.04em; }
.sbar { display:flex; align-items:center; margin-bottom:1.2rem; }
.sdot { width:26px; height:26px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-b); font-size:.68rem; font-weight:700; transition:all .3s; flex-shrink:0; }
.sdot.done { background:var(--cyan-lt); color:var(--dark); }
.sdot.active { background:rgba(160,203,255,.15); color:var(--cyan-lt); border:1.5px solid var(--cyan-lt); box-shadow:0 0 0 3px rgba(160,203,255,.15); }
.sdot.todo { background:rgba(255,255,255,.06); color:rgba(255,255,255,.22); border:1px solid rgba(255,255,255,.09); }
.sline { flex:1; height:1px; background:rgba(255,255,255,.08); transition:background .3s; margin:0 .4rem; }
.sline.done { background:var(--cyan-lt); }
.bk-card { background:rgba(255,255,255,.025); border:1px solid rgba(255,255,255,.07); border-radius:20px; padding:2rem; backdrop-filter:blur(20px); }
.fsec { display:none; }
.fsec.active { display:block; animation:stepIn .38s cubic-bezier(.4,0,.2,1) both; }
.fsec.going-back.active { animation:stepInBack .38s cubic-bezier(.4,0,.2,1) both; }
@keyframes stepIn { from{opacity:0;transform:translateX(22px)} to{opacity:1;transform:translateX(0)} }
@keyframes stepInBack { from{opacity:0;transform:translateX(-22px)} to{opacity:1;transform:translateX(0)} }
.frow { display:grid; grid-template-columns:1fr 1fr; gap:.9rem; margin-bottom:.9rem; }
.frow.full { grid-template-columns:1fr; }
.ff { display:flex; flex-direction:column; gap:.35rem; }
.ff label { font-family:var(--font-b); font-size:.57rem; font-weight:700; color:rgba(240,248,255,.38); letter-spacing:.25em; text-transform:uppercase; }
.ff input,.ff select,.ff textarea { background:rgba(0,0,0,.22); border:1.5px solid rgba(255,255,255,.18); border-radius:8px; padding:.72rem .95rem; font-family:var(--font-b); font-size:.86rem; color:#f0f8ff; outline:none; transition:border-color .2s,background .2s; width:100%; }
.ff input:focus,.ff select:focus,.ff textarea:focus { border-color:rgba(160,203,255,.7); background:rgba(0,0,0,.28); }
.ff input.err,.ff select.err { border-color:#ef4444; }
.ff textarea { resize:vertical; min-height:72px; }
.ff select option { background:#0c1a26; color:#f0f8ff; }
.sg { display:flex; flex-wrap:wrap; gap:.4rem; margin-top:.35rem; }
.slot { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:6px; padding:.35rem .75rem; font-family:var(--font-b); font-size:.68rem; letter-spacing:.1em; color:rgba(240,248,255,.5); cursor:pointer; transition:all .2s; }
.slot:hover { border-color:rgba(59,140,232,.4); color:var(--cyan); background:rgba(59,140,232,.07); }
.slot.sel { background:rgba(160,203,255,.15); border-color:var(--cyan-lt); color:var(--cyan-lt); }
.btn-next { width:100%; margin-top:1.1rem; background:var(--dark); color:var(--white); padding:.88rem; border:none; border-radius:50px; font-family:var(--font-b); font-size:.8rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; cursor:pointer; transition:all .25s; }
.btn-next:hover { background:#0a2458; transform:translateY(-2px); box-shadow:0 8px 32px rgba(5,20,40,.4); }
.btn-next:disabled { opacity:.38; cursor:not-allowed; transform:none!important; box-shadow:none!important; }
.btn-back { background:none; border:none; color:rgba(240,248,255,.28); font-family:var(--font-b); font-size:.7rem; padding:.35rem; cursor:pointer; margin-top:.35rem; display:flex; align-items:center; gap:.35rem; transition:color .2s; letter-spacing:.1em; }
.btn-back:hover { color:rgba(240,248,255,.65); }
.ffoot { display:flex; flex-direction:column; align-items:center; gap:.25rem; }
.bsucc { display:none; text-align:center; padding:2.5rem 1rem; }
.bsucc .sr { margin:0 auto 1.3rem; text-align:center; }
.bsucc .sr-logo { width:140px; height:auto; display:block; margin:0 auto; filter:drop-shadow(0 0 18px rgba(59,140,232,.35)); }
.bsucc h3 { font-family:var(--font-d); font-size:1.9rem; color:#fff; margin-bottom:.5rem; }
.bsucc p { color:rgba(240,248,255,.42); font-size:.82rem; margin-bottom:1.3rem; line-height:1.65; }
.wa-c { display:inline-flex; align-items:center; gap:.6rem; background:#25d366; color:#fff; padding:.9rem 1.8rem; border-radius:50px; font-family:var(--font-b); font-size:.78rem; font-weight:700; letter-spacing:.1em; text-decoration:none; transition:all .25s; }
.wa-c:hover { background:#1db954; transform:translateY(-2px); }
.phone-field-outer { display:flex; flex-direction:column; gap:.35rem; }
.phone-field-outer > label { font-family:var(--font-b); font-size:.57rem; font-weight:700; color:rgba(240,248,255,.38); letter-spacing:.25em; text-transform:uppercase; }
.phone-input-row { display:flex; align-items:stretch; position:relative; }
.ctry-trigger { display:flex; align-items:center; gap:4px; padding:0 .6rem; background:rgba(0,0,0,.22); border:1.5px solid rgba(255,255,255,.18); border-right:none; cursor:pointer; border-radius:8px 0 0 8px; min-width:70px; flex-shrink:0; transition:border-color .2s; }
.ctry-trigger:hover { border-color:rgba(160,203,255,.5); }
.ctry-flag { font-size:.95rem; }
.ctry-code { font-family:var(--font-b); font-size:.7rem; font-weight:700; color:rgba(240,248,255,.55); }
.ctry-chevron { margin-left:auto; display:flex; }
.ctry-chevron svg { width:9px; height:9px; stroke:rgba(240,248,255,.3); }
.ctry-dropdown { position:absolute; top:calc(100% + 4px); left:0; width:250px; background:#0f1e33; border:1px solid rgba(255,255,255,.1); border-radius:12px; box-shadow:0 8px 30px rgba(0,0,0,.45); z-index:400; display:none; max-height:200px; flex-direction:column; }
.ctry-dropdown.open { display:flex; }
.ctry-search-wrap { padding:.5rem .75rem; border-bottom:1px solid rgba(255,255,255,.07); display:flex; align-items:center; gap:.4rem; flex-shrink:0; }
.ctry-search-wrap svg { width:12px; height:12px; stroke:rgba(240,248,255,.3); flex-shrink:0; }
.ctry-search-input { border:none; outline:none; font-family:var(--font-b); font-size:.78rem; width:100%; background:transparent; color:#f0f8ff; }
.ctry-list { overflow-y:auto; flex:1; }
.ctry-opt { display:flex; align-items:center; gap:.5rem; padding:.5rem .75rem; cursor:pointer; transition:background .15s; }
.ctry-opt:hover,.ctry-opt.sel { background:rgba(255,255,255,.07); }
.ctry-opt-flag { font-size:.95rem; width:22px; text-align:center; flex-shrink:0; }
.ctry-opt-name { flex:1; color:rgba(240,248,255,.65); font-family:var(--font-b); font-size:.72rem; }
.ctry-opt-code { color:rgba(59,140,232,.6); font-weight:700; font-family:var(--font-b); font-size:.68rem; }
.phone-number-input { flex:1; background:rgba(0,0,0,.22); border:1.5px solid rgba(255,255,255,.18); border-radius:0 8px 8px 0; padding:.72rem .95rem; font-family:var(--font-b); font-size:.86rem; color:#f0f8ff; outline:none; transition:border-color .2s,background .2s; }
.phone-number-input:focus { border-color:rgba(160,203,255,.7); background:rgba(0,0,0,.28); }
@media(max-width:900px){ .bk-layout{grid-template-columns:1fr;gap:3rem;} }
@media(max-width:640px){ .frow{grid-template-columns:1fr;} .bk-card{padding:1.4rem;} }

/* FAQ */
#faq-section { background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(19,68,160,.14) 0%,transparent 100%),#0d3a6e; padding:12vh 5vw 14vh; position:relative; overflow:hidden; }
.faq-bg-word { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-family:var(--font-d); font-size:clamp(10rem,22vw,20rem); color:transparent; -webkit-text-stroke:1px rgba(255,255,255,.03); white-space:nowrap; user-select:none; pointer-events:none; line-height:1; }
.faq-inner { max-width:1120px; margin:0 auto; position:relative; }
.faq-header { display:flex; flex-direction:column; gap:1rem; margin-bottom:5rem; }
.faq-header-right { color:rgba(240,248,255,.3); font-family:var(--font-b); font-size:.85rem; line-height:1.8; letter-spacing:.03em; max-width:580px; }
.faq-list { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:repeat(3,auto); grid-auto-flow:column; align-items:start; column-gap:3vw; }
.faq-item { border-bottom:1px solid rgba(255,255,255,.06); cursor:pointer; transition:background .3s; border-radius:4px; }
.faq-item:first-child, .faq-item:nth-child(4) { border-top:1px solid rgba(255,255,255,.06); }
.faq-head { display:flex; align-items:center; gap:1.8rem; padding:1.6rem 1rem; transition:padding .3s; }
.faq-num { font-family:var(--font-d); font-size:clamp(2.2rem,4vw,3.2rem); color:rgba(255,255,255,.05); line-height:1; min-width:2.8rem; text-align:right; transition:color .35s,text-shadow .35s; flex-shrink:0; }
.faq-item.open .faq-num { color:var(--c,var(--cyan)); text-shadow:0 0 40px var(--c,var(--cyan)); }
.faq-icon-box { width:56px; height:56px; border-radius:16px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.25); flex-shrink:0; transition:all .35s cubic-bezier(.34,1.56,.64,1); }
.faq-item:hover .faq-icon-box { background:rgba(255,255,255,.07); color:rgba(255,255,255,.5); transform:scale(1.05); }
.faq-item.open .faq-icon-box { background:color-mix(in srgb,var(--c,var(--cyan)) 12%,transparent); border-color:color-mix(in srgb,var(--c,var(--cyan)) 35%,transparent); color:var(--c,var(--cyan)); box-shadow:0 8px 32px color-mix(in srgb,var(--c,var(--cyan)) 20%,transparent); transform:scale(1.08); }
.faq-question { flex:1; font-family:var(--font-b); font-weight:700; font-size:clamp(.9rem,1.6vw,1.08rem); color:rgba(240,248,255,.6); letter-spacing:.01em; line-height:1.35; transition:color .3s; }
.faq-item:hover .faq-question { color:rgba(240,248,255,.8); }
.faq-item.open .faq-question { color:#fff; }
.faq-toggle { width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .35s; color:rgba(255,255,255,.35); }
.faq-toggle svg { width:14px; height:14px; transition:transform .35s; }
.faq-item.open .faq-toggle { background:color-mix(in srgb,var(--c,var(--cyan)) 15%,transparent); border-color:color-mix(in srgb,var(--c,var(--cyan)) 30%,transparent); color:var(--c,var(--cyan)); }
.faq-item.open .faq-toggle svg { transform:rotate(45deg); }
.faq-body { display:grid; grid-template-rows:0fr; transition:grid-template-rows .48s cubic-bezier(.4,0,.2,1); }
.faq-body-inner { overflow:hidden; }
.faq-item.open .faq-body { grid-template-rows:1fr; }
.faq-answer { padding:.2rem 1rem 1.8rem calc(2.8rem + 56px + 3.6rem); color:rgba(240,248,255,.38); font-family:var(--font-b); font-size:.8rem; line-height:1.85; letter-spacing:.02em; opacity:0; transform:translateY(-10px); transition:opacity .35s .12s, transform .35s .12s; }
.faq-item.open .faq-answer { opacity:1; transform:translateY(0); }
@media(max-width:768px){ .faq-header{grid-template-columns:1fr;gap:1rem;} .faq-list{grid-template-columns:1fr;grid-auto-flow:row;} .faq-item:nth-child(4){border-top:none;} .faq-num{font-size:2rem;min-width:2.2rem;} .faq-answer{padding:.2rem 1rem 1.5rem 1rem;} }

/* BLOG */
/* BLOG CAROUSEL */
#blog-section { background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(19,68,160,.14) 0%,transparent 100%),#0d3a6e; padding:12vh 5vw 14vh; position:relative; }
.blog-inner { max-width:1160px; margin:0 auto; display:grid; grid-template-columns:1fr 1.1fr; gap:6vw; align-items:center; }
.blog-text .section-tag { margin-bottom:1.2rem; }
.blog-headline { font-family:var(--font-d); font-size:clamp(2.8rem,5vw,4.8rem); line-height:.96; color:var(--white); margin-bottom:1.2rem; }
.blog-desc { font-family:var(--font-b); font-size:.9rem; font-weight:300; color:rgba(240,248,255,.38); line-height:1.8; max-width:340px; margin-bottom:2.2rem; }
.blog-all-btn { display:inline-flex; align-items:center; gap:.6rem; background:var(--dark); color:var(--white); font-family:var(--font-b); font-size:.78rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:.85rem 2rem; border-radius:50px; text-decoration:none; transition:opacity .25s,gap .25s; }
.blog-all-btn:hover { opacity:.88; gap:.9rem; }
.blog-all-btn svg { transition:transform .25s; }
.blog-all-btn:hover svg { transform:translateX(3px); }
/* Carousel */
.bcar-wrap { position:relative; }
.bcar-track { position:relative; border-radius:20px; overflow:hidden; }
.bcar-slide { position:absolute; inset:0; opacity:0; transition:opacity .55s cubic-bezier(.4,0,.2,1); pointer-events:none; }
.bcar-slide.active { opacity:1; position:relative; pointer-events:auto; }
.bcar-card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:20px; overflow:hidden; }
.bcar-img { width:100%; aspect-ratio:16/9; overflow:hidden; background:#0c1828; position:relative; }
.bcar-img img { width:100%; height:100%; object-fit:cover; display:block; }
.bcar-img-ph { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:rgba(59,140,232,.06); }
.bcar-body { padding:1.4rem 1.6rem 1.6rem; }
.bcar-cat { font-family:var(--font-b); font-size:.58rem; font-weight:700; letter-spacing:.3em; text-transform:uppercase; color:var(--cyan); margin-bottom:.6rem; }
.bcar-title { font-family:var(--font-d); font-size:clamp(1.3rem,2.2vw,1.9rem); line-height:1.05; color:var(--white); margin-bottom:.5rem; }
.bcar-meta { font-family:var(--font-b); font-size:.7rem; color:rgba(240,248,255,.25); }
/* Nav row */
.bcar-nav { display:flex; align-items:center; gap:1rem; margin-top:1.2rem; }
.bcar-btn { width:38px; height:38px; border-radius:50%; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.04); color:rgba(240,248,255,.5); display:flex; align-items:center; justify-content:center; cursor:none; transition:all .22s; flex-shrink:0; }
.bcar-btn:hover { border-color:var(--cyan); color:var(--cyan); background:rgba(59,140,232,.08); }
.bcar-btn svg { width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:2; }
.bcar-dots { display:flex; gap:.45rem; align-items:center; }
.bcar-dot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.18); transition:all .3s; cursor:none; border:none; padding:0; }
.bcar-dot.active { width:20px; border-radius:3px; background:var(--cyan); }
@media(max-width:860px){ .blog-inner{grid-template-columns:1fr;gap:3rem;} .blog-desc{max-width:100%;} }
@media(max-width:480px){ .blog-headline{font-size:2.6rem;} }

/* SOCIAL SECTION */
#social-section { background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(19,68,160,.14) 0%,transparent 100%),#0d3a6e; padding:12vh 5vw 14vh; position:relative; }
.social-inner { max-width:1160px; margin:0 auto; display:grid; grid-template-columns:1fr 1.2fr; gap:6vw; align-items:center; position:relative; z-index:1; }
/* embed side */
.social-embed-col { display:flex; flex-direction:column; gap:1.2rem; }
.soc-tabs { display:flex; gap:.6rem; }
.soc-tab { display:flex; align-items:center; gap:.55rem; padding:.6rem 1.4rem; border-radius:50px; font-family:var(--font-b); font-size:.75rem; font-weight:700; border:1.5px solid rgba(255,255,255,.12); background:rgba(255,255,255,.04); color:rgba(240,248,255,.4); cursor:none; transition:all .22s; }
.soc-tab:hover { color:var(--white); border-color:rgba(255,255,255,.28); background:rgba(255,255,255,.08); }
.soc-tab.active { color:var(--white); border-color:rgba(59,140,232,.6); background:rgba(59,140,232,.08); }
.soc-panel { display:none; }
.soc-panel.active { display:block; }
.soc-embed-wrap { border-radius:20px; overflow:hidden; background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); position:relative; min-height:520px; }
.soc-iframe { width:100%; height:560px; border:none; display:block; position:relative; z-index:2; }
.soc-fallback { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1rem; color:rgba(240,248,255,.25); font-family:var(--font-b); font-size:.85rem; z-index:1; }
.soc-open-btn { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); color:var(--white); padding:.55rem 1.3rem; border-radius:50px; font-size:.75rem; font-weight:700; font-family:var(--font-b); text-decoration:none; transition:background .2s; }
.soc-open-btn:hover { background:rgba(255,255,255,.15); }
/* text side */
.social-title { font-family:var(--font-d); font-size:clamp(2.8rem,4.5vw,4.4rem); line-height:.96; color:var(--white); margin-bottom:1.2rem; }
.social-title em { font-family:var(--font-i); color:var(--cyan); font-size:.9em; }
.social-sub { font-family:var(--font-b); font-size:.9rem; font-weight:300; color:rgba(240,248,255,.38); line-height:1.8; }
@media(max-width:920px){ .social-inner{grid-template-columns:1fr;gap:3.5rem;} .social-title{font-size:2.8rem;} }
@media(max-width:480px){ .soc-iframe{height:400px;} .soc-embed-wrap{min-height:420px;} }

/* FOOTER */
#site-footer { background:#070d16; border-top:1px solid rgba(255,255,255,.06); padding:7vh 5vw 0; }
.ft-inner { max-width:1160px; margin:0 auto; display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:4vw; padding-bottom:6vh; }
.ft-logo { width:160px; height:auto; display:block; margin-bottom:1.1rem; filter:brightness(.9); }
.ft-tagline { font-family:var(--font-b); font-size:.75rem; font-weight:300; color:rgba(240,248,255,.28); line-height:1.8; margin-bottom:1.4rem; }
.ft-social-row { display:flex; gap:.7rem; }
.ft-soc { width:34px; height:34px; border-radius:8px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; color:rgba(240,248,255,.4); text-decoration:none; transition:all .22s; }
.ft-soc:hover { background:rgba(59,140,232,.12); border-color:rgba(59,140,232,.3); color:var(--cyan); }
.ft-col { display:flex; flex-direction:column; gap:.7rem; }
.ft-col-title { font-family:var(--font-b); font-size:.6rem; font-weight:700; letter-spacing:.3em; text-transform:uppercase; color:var(--cyan); margin-bottom:.4rem; }
.ft-col a { font-family:var(--font-b); font-size:.8rem; font-weight:300; color:rgba(240,248,255,.38); text-decoration:none; transition:color .2s; display:flex; align-items:center; gap:.5rem; }
.ft-col a:hover { color:rgba(240,248,255,.85); }
.ft-areas { display:flex; flex-direction:column; gap:.35rem; margin-top:.3rem; }
.ft-areas span { font-family:var(--font-b); font-size:.75rem; font-weight:300; color:rgba(240,248,255,.22); padding-left:1.3rem; position:relative; }
.ft-areas span::before { content:'·'; position:absolute; left:0; color:var(--cyan); opacity:.5; }
.ft-bottom { max-width:1160px; margin:0 auto; border-top:1px solid rgba(255,255,255,.06); padding:1.6rem 0; display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.ft-bottom span { font-family:var(--font-b); font-size:.7rem; font-weight:300; color:rgba(240,248,255,.2); }
@media(max-width:900px){ .ft-inner{grid-template-columns:1fr 1fr;gap:3rem;} }
@media(max-width:560px){ .ft-inner{grid-template-columns:1fr;} .ft-bottom{flex-direction:column;align-items:flex-start;} }

/* BUBBLES */
.bubbles-bg{position:absolute;inset:0;pointer-events:none;z-index:0;}
.bubble{
  position:absolute;bottom:-140px;border-radius:50%;overflow:hidden;
  background:radial-gradient(circle at 30% 25%, rgba(255,255,255,.32) 0%, rgba(255,255,255,.10) 18%, rgba(59,140,232,.07) 40%, rgba(19,68,160,.03) 70%, transparent 100%);
  border:1px solid rgba(255,255,255,.28);
  box-shadow:inset 0 2px 16px rgba(255,255,255,.18), inset 0 -3px 10px rgba(19,68,160,.1), 0 0 32px rgba(59,140,232,.07), 0 0 1px rgba(255,255,255,.1);
  animation:bubbleRise linear infinite;
  will-change:transform,opacity;
  cursor:pointer;
  pointer-events:auto;
}
.bubble::before{content:'';position:absolute;top:12%;left:16%;width:28%;height:28%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(255,255,255,0) 100%);}
.bubble::after{content:'';position:absolute;bottom:16%;right:17%;width:10%;height:10%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.4) 0%,rgba(255,255,255,0) 100%);}
@keyframes bubbleRise{
  0%  {transform:translateY(0) translateX(0);opacity:0;}
  8%  {opacity:var(--bop,.45);}
  25% {transform:translateY(-25vh) translateX(var(--sw,18px));}
  50% {transform:translateY(-55vh) translateX(0);}
  75% {transform:translateY(-80vh) translateX(calc(var(--sw,18px)*-.7));}
  92% {opacity:calc(var(--bop,.45)*.15);}
  100%{transform:translateY(-115vh) translateX(0);opacity:0;}
}
@keyframes bubblePop{
  0%  {transform:scale(1);opacity:var(--bop,.4);}
  25% {transform:scale(1.25);opacity:var(--bop,.4);filter:brightness(2.5);}
  100%{transform:scale(2.8);opacity:0;filter:brightness(1);}
}
.bubble-particle{position:fixed;border-radius:50%;background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.9),rgba(59,140,232,.5));border:1px solid rgba(255,255,255,.6);pointer-events:none;z-index:9997;}
@keyframes particleFly{
  0%  {transform:translate(-50%,-50%) scale(1);opacity:.9;}
  60% {opacity:.45;}
  100%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.08);opacity:0;}
}

/* TITLE FILL */
.title-fill { position:relative; color:transparent !important; -webkit-text-stroke:1px rgba(160,203,255,.25); }
.title-fill em { color:transparent !important; -webkit-text-stroke:1px rgba(160,203,255,.55); }
.title-fill-layer { position:absolute; inset:0; overflow:hidden; display:block; pointer-events:none; clip-path:inset(0 100% 0 0); transition:clip-path 1.8s cubic-bezier(.4,0,.2,1); color:#f0f8ff; -webkit-text-stroke:0px; white-space:normal; font:inherit; }
.title-fill-layer em { color:#a0cbff; -webkit-text-stroke:0px; }

/* STATS COUNTERS */
.bk-stats { display:flex; align-items:center; margin:2.4rem auto 0; max-width:640px; background:rgba(255,255,255,.025); border:1px solid rgba(255,255,255,.07); border-radius:14px; padding:.9rem 0; }
.bk-stat { flex:1; text-align:center; padding:.2rem .6rem; }
.bk-stat-div { width:1px; height:2.2rem; background:rgba(255,255,255,.08); flex-shrink:0; }
.stat-num { font-family:var(--font-d); font-size:2rem; color:var(--white); line-height:1; display:inline; }
.stat-plus { font-family:var(--font-d); font-size:1.4rem; color:var(--cyan); }
.stat-label { display:block; font-family:var(--font-b); font-size:.55rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(240,248,255,.32); margin-top:.25rem; }

/* TEAM SECTION */
#team-section { background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(19,68,160,.14) 0%,transparent 100%),#0d3a6e; padding:10vh 5vw 10vh; position:relative; }
.team-inner { max-width:1100px; margin:0 auto; }
.team-header { text-align:center; margin-bottom:6vh; }
.team-sub { font-family:var(--font-b); font-size:.92rem; font-weight:300; color:rgba(240,248,255,.38); margin-top:1rem; line-height:1.7; }
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; }
.team-card { background:rgba(255,255,255,.025); border:1px solid rgba(255,255,255,.07); border-radius:20px; padding:2rem 1.5rem; text-align:center; transition:border-color .3s,transform .35s; }
.team-card:hover { border-color:rgba(59,140,232,.28); transform:translateY(-5px); }
.team-photo { width:92px; height:92px; margin:0 auto 1.3rem; border-radius:50%; overflow:hidden; border:2px solid rgba(255,255,255,.1); }
.team-avatar { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,var(--c1),var(--c2)); font-family:var(--font-d); font-size:1.5rem; color:rgba(255,255,255,.9); letter-spacing:.05em; }
.team-photo img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.team-name { font-family:var(--font-d); font-size:1.5rem; color:var(--white); margin-bottom:.25rem; }
.team-role { font-family:var(--font-b); font-size:.58rem; letter-spacing:.3em; text-transform:uppercase; color:var(--cyan); display:block; margin-bottom:.8rem; }
.team-bio { font-family:var(--font-b); font-size:.82rem; font-weight:300; color:rgba(240,248,255,.36); line-height:1.75; }
@media(max-width:800px){ .team-grid{grid-template-columns:1fr 1fr;} }
@media(max-width:520px){ .team-grid{grid-template-columns:1fr;} .team-card{padding:1.5rem 1.2rem;} }

/* LANG TOGGLE */
.lang-toggle { display:flex; flex-direction:column; gap:.4rem; margin-top:1rem; padding-top:.8rem; border-top:1px solid rgba(255,255,255,.07); }
.lang-btn { background:none; border:1px solid rgba(255,255,255,.12); color:rgba(240,248,255,.35); font-family:var(--font-b); font-size:.58rem; letter-spacing:.1em; padding:.3rem .5rem; border-radius:6px; cursor:pointer; transition:all .2s; white-space:nowrap; }
.lang-btn.active { background:rgba(59,140,232,.15); border-color:rgba(59,140,232,.4); color:var(--cyan); }
.lang-btn:hover:not(.active) { border-color:rgba(255,255,255,.25); color:rgba(240,248,255,.65); }

/* WA FLOAT */
.wa-float { position:fixed; bottom:28px; right:28px; z-index:9000; display:flex; flex-direction:column; align-items:flex-end; gap:.5rem; }
.wa-bubble { background:#25d366; color:#fff; font-family:var(--font-b); font-size:.75rem; padding:.45rem .85rem; border-radius:20px 20px 4px 20px; box-shadow:0 4px 16px rgba(37,211,102,.35); animation:waBubble 3s ease-in-out 1.5s both; white-space:nowrap; }
@keyframes waBubble { 0%{opacity:0;transform:translateY(6px)} 20%{opacity:1;transform:translateY(0)} 80%{opacity:1} 100%{opacity:0;pointer-events:none} }
.wa-float-btn { width:56px; height:56px; border-radius:50%; background:#25d366; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(37,211,102,.45); transition:transform .22s,box-shadow .22s; text-decoration:none; }
.wa-float-btn:hover { transform:scale(1.1); box-shadow:0 6px 28px rgba(37,211,102,.6); }
@media(max-width:768px){ .wa-float{bottom:20px;right:16px;} .wa-float-btn{width:50px;height:50px;} }

/* ── MOBILE OVERRIDES ─────────────────────────────────── */
@media(max-width:768px){
  /* Section spacing */
  .services-header{padding:7vh 6vw 2vh;}
  .cs-outer{padding:3vh 0 7vh;}
  .extras-row{padding:2vh 6vw 5vh;}
  #ba-section{padding:5vh 0 6vh;}
  .ba-header{padding:3vh 5vw 3vh;}
  #team-section{padding:6vh 5vw 5vh;}
  #cta-section{padding:6vh 5vw 7vh;}
  #faq-section{padding:7vh 5vw 8vh;}
  #blog-section{padding:7vh 5vw 8vh;}
  #social-section{padding:7vh 5vw 8vh;}

  /* Scrub section text bigger */
  .scrub-text h2{font-size:clamp(3.8rem,14vw,5.5rem);}

  /* Team carousel */
  .team-grid{overflow:hidden;display:block;}
  .team-carousel-nav{display:flex;justify-content:center;gap:.55rem;margin-top:1.2rem;}
  .team-car-dot{width:8px;height:8px;border-radius:50%;border:none;cursor:pointer;padding:0;transition:background .25s;}

  /* Booking section: tracker → form → trusted */
  .bk-layout{display:flex;flex-direction:column;}
  .bk-left{order:1;}
  .bk-right{order:2;}
  .bk-trust{order:3;}
  .sbar{display:none;}
}
