@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400;1,700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}

:root{
  --a1:#00B4D8;
  --a2:#0096C7;
  --a3:#0077B6;
  --a4:#023E8A;
  --a5:#03045E;
  --al:#90E0EF;
  --ap:#CAF0F8;
  --ab:#E8F8FD;
  --w:#FFFFFF;
  --c:#F7FBFF;
  --g1:#F0F4F8;
  --g2:#E2EAF0;
  --g3:#C8D8E4;
  --g5:#7A9BB0;
  --g7:#2C4A5E;
  --g9:#0A1929;
  --ff-h:'Playfair Display',Georgia,serif;
  --ff-b:'Plus Jakarta Sans',system-ui,sans-serif;
  --sy:100px;
  --ease:cubic-bezier(.16,1,.3,1);
  --bounce:cubic-bezier(.34,1.56,.64,1);
}

body{font-family:var(--ff-b);color:var(--g9);background:var(--w);overflow-x:hidden;-webkit-font-smoothing:antialiased;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
::selection{background:var(--ap);color:var(--a4);}
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-thumb{background:var(--a2);border-radius:2px;}

.container{max-width:1180px;margin:0 auto;padding:0 28px;}
.section{padding:var(--sy) 0;}
.bg-light{background:var(--ab);}
.bg-cream{background:var(--c);}
.bg-dark{background:var(--a5);}
.bg-grad{background:linear-gradient(135deg,var(--a4),var(--a2));}

/* ── LOADER ── */
.loader{position:fixed;inset:0;background:var(--a4);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .7s var(--ease),visibility .7s;}
.loader.out{opacity:0;visibility:hidden;pointer-events:none;}
.loader-inner{text-align:center;}
.loader-tooth{font-size:48px;animation:tooth-spin 1s ease infinite alternate;}
@keyframes tooth-spin{from{transform:rotate(-15deg) scale(.9);}to{transform:rotate(15deg) scale(1.1);}}
.loader-text{font-family:var(--ff-h);font-size:24px;color:var(--w);margin-top:16px;opacity:.7;letter-spacing:2px;}
.loader-dots{display:flex;gap:8px;justify-content:center;margin-top:12px;}
.loader-dots span{width:8px;height:8px;border-radius:50%;background:var(--al);animation:dot-bounce .8s ease infinite;}
.loader-dots span:nth-child(2){animation-delay:.15s;}
.loader-dots span:nth-child(3){animation-delay:.3s;}
@keyframes dot-bounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}

/* ── NAV ── */
.nav{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:1000;width:calc(100% - 48px);max-width:1140px;background:rgba(255,255,255,.9);backdrop-filter:blur(24px);border:1px solid rgba(0,119,182,.12);border-radius:16px;padding:0 24px;height:64px;display:flex;align-items:center;box-shadow:0 4px 32px rgba(0,60,100,.1);transition:all .3s var(--ease);}
.nav.scrolled{background:rgba(255,255,255,.98);box-shadow:0 8px 40px rgba(0,60,100,.15);}
.nav-brand{display:flex;align-items:center;gap:10px;margin-right:auto;}
.nav-brand-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--a2),var(--a4));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;}
.nav-brand-text{font-family:var(--ff-h);font-size:18px;color:var(--a4);font-style:italic;}
.nav-links{display:flex;align-items:center;gap:4px;}
.nav-links a{font-size:13.5px;font-weight:500;color:var(--g7);padding:7px 14px;border-radius:8px;transition:all .2s;}
.nav-links a:hover,.nav-links a.active{color:var(--a2);background:var(--ab);}
.nav-book{margin-left:16px;background:var(--a2);color:var(--w);padding:9px 22px;border-radius:10px;font-size:13.5px;font-weight:700;transition:all .25s;border:none;cursor:pointer;flex-shrink:0;}
.nav-book:hover{background:var(--a3);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,150,199,.3);}
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;background:none;border:none;margin-left:12px;cursor:pointer;}
.hamburger span{display:block;width:22px;height:2px;background:var(--g9);border-radius:2px;transition:all .3s;}
.mobile-menu{display:none;position:fixed;top:96px;left:24px;right:24px;background:var(--w);border-radius:16px;padding:16px;box-shadow:0 20px 60px rgba(0,60,100,.2);border:1px solid var(--g2);z-index:999;}
.mobile-menu.open{display:block;}
.mobile-menu a{display:block;padding:12px 16px;font-size:15px;font-weight:500;color:var(--g7);border-radius:10px;transition:all .2s;}
.mobile-menu a:hover{background:var(--ab);color:var(--a2);}

/* ── HERO ── */
.hero{min-height:100vh;background:var(--w);display:flex;align-items:center;padding-top:96px;position:relative;overflow:hidden;}
.hero-blob-1{position:absolute;top:-20%;right:-10%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(0,180,216,.12) 0%,transparent 70%);pointer-events:none;}
.hero-blob-2{position:absolute;bottom:-20%;left:-10%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(0,150,199,.08) 0%,transparent 70%);pointer-events:none;animation:blob-move 8s ease-in-out infinite alternate;}
@keyframes blob-move{from{transform:translate(0,0);}to{transform:translate(20px,-20px);}}
.hero-inner{max-width:1180px;margin:0 auto;padding:60px 28px 80px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2;}
.hero-label{display:inline-flex;align-items:center;gap:8px;background:var(--ab);border:1px solid var(--ap);border-radius:100px;padding:7px 16px;font-size:12px;font-weight:600;color:var(--a3);letter-spacing:.5px;margin-bottom:20px;}
.hero-label-dot{width:7px;height:7px;border-radius:50%;background:var(--a1);animation:pulse 2s ease infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}
.hero-h1{font-family:var(--ff-h);font-size:clamp(42px,5.5vw,72px);line-height:1.05;color:var(--g9);margin-bottom:20px;letter-spacing:-.5px;}
.hero-h1 span{color:var(--a2);font-style:italic;display:block;}
.hero-p{font-size:17px;color:var(--g5);line-height:1.75;margin-bottom:36px;max-width:460px;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px;}
.btn-fill{background:var(--a2);color:var(--w);padding:14px 30px;border-radius:12px;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:8px;}
.btn-fill:hover{background:var(--a3);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,150,199,.35);}
.btn-line{background:transparent;color:var(--a2);padding:14px 30px;border-radius:12px;font-size:14px;font-weight:700;border:2px solid var(--ap);cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:8px;}
.btn-line:hover{border-color:var(--a2);background:var(--ab);}
.btn-white-fill{background:var(--w);color:var(--a3);padding:14px 30px;border-radius:12px;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:8px;}
.btn-white-fill:hover{background:var(--ap);transform:translateY(-2px);}
.btn-white-line{background:transparent;color:var(--w);padding:14px 30px;border-radius:12px;font-size:14px;font-weight:700;border:2px solid rgba(255,255,255,.3);cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:8px;}
.btn-white-line:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.1);}
.hero-trust{display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.hero-trust-item{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--g5);}
.hero-trust-item span{color:var(--a2);}

/* HERO RIGHT — floating cards */
.hero-right{position:relative;height:500px;}
.hero-main-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:280px;background:linear-gradient(160deg,var(--a4),var(--a2));border-radius:24px;padding:36px 28px;color:var(--w);text-align:center;box-shadow:0 32px 80px rgba(0,60,100,.3);animation:float 4s ease-in-out infinite alternate;}
@keyframes float{from{transform:translate(-50%,-50%) translateY(0);}to{transform:translate(-50%,-50%) translateY(-12px);}}
.hero-main-card-icon{font-size:52px;margin-bottom:12px;}
.hero-main-card h3{font-family:var(--ff-h);font-size:22px;font-style:italic;margin-bottom:6px;}
.hero-main-card p{font-size:13px;opacity:.65;line-height:1.5;}
.hero-float-card{position:absolute;background:var(--w);border-radius:16px;padding:14px 18px;box-shadow:0 8px 32px rgba(0,60,100,.12);border:1px solid var(--g2);display:flex;align-items:center;gap:10px;animation:float2 5s ease-in-out infinite alternate;}
@keyframes float2{from{transform:translateY(0);}to{transform:translateY(-8px);}}
.hero-float-card:nth-child(3){top:8%;left:0;animation-delay:.5s;}
.hero-float-card:nth-child(4){top:15%;right:0;animation-delay:1s;}
.hero-float-card:nth-child(5){bottom:15%;left:0;animation-delay:1.5s;}
.hero-float-card:nth-child(6){bottom:8%;right:0;animation-delay:2s;}
.fc-icon{width:36px;height:36px;border-radius:10px;background:var(--ab);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.fc-text h5{font-size:13px;font-weight:700;color:var(--g9);}
.fc-text p{font-size:11px;color:var(--g5);}

/* ── MARQUEE ── */
.marquee-wrap{background:var(--a4);padding:14px 0;overflow:hidden;}
.marquee-track{display:flex;gap:48px;animation:marquee 20s linear infinite;width:max-content;}
.marquee-item{display:flex;align-items:center;gap:10px;font-size:12px;font-weight:600;color:rgba(255,255,255,.5);letter-spacing:1.5px;text-transform:uppercase;white-space:nowrap;}
.marquee-item span{color:var(--al);}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ── SERVICES ── */
.services-tabs{display:flex;gap:8px;margin-bottom:40px;flex-wrap:wrap;}
.stab{padding:10px 22px;border-radius:100px;font-size:13.5px;font-weight:600;cursor:pointer;border:1.5px solid var(--g2);background:var(--w);color:var(--g7);transition:all .25s;}
.stab.active,.stab:hover{background:var(--a2);color:var(--w);border-color:var(--a2);}
.services-list{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
.service-row{background:var(--w);border:1.5px solid var(--g2);border-radius:16px;padding:24px 28px;display:flex;align-items:flex-start;gap:20px;transition:all .3s var(--ease);cursor:default;}
.service-row:hover{border-color:var(--ap);box-shadow:0 12px 40px rgba(0,119,182,.1);transform:translateY(-4px);}
.sr-num{font-family:var(--ff-h);font-size:32px;color:var(--ap);line-height:1;flex-shrink:0;font-style:italic;margin-top:-4px;}
.sr-body h3{font-size:16px;font-weight:700;color:var(--g9);margin-bottom:6px;}
.sr-body p{font-size:13.5px;color:var(--g5);line-height:1.6;}
.sr-book{margin-top:12px;font-size:12.5px;font-weight:700;color:var(--a2);display:inline-flex;align-items:center;gap:4px;}

/* ── SPLIT SECTION ── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.split-visual{position:relative;}
.split-card-main{background:linear-gradient(160deg,var(--a4),var(--a3));border-radius:24px;padding:48px 40px;color:var(--w);}
.split-card-main h2{font-family:var(--ff-h);font-size:32px;font-style:italic;margin-bottom:12px;}
.split-card-main p{font-size:14px;opacity:.65;line-height:1.75;margin-bottom:28px;}
.qual-badges{display:flex;gap:8px;flex-wrap:wrap;}
.qual-badge{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.85);font-size:12px;font-weight:600;padding:6px 14px;border-radius:100px;}
.split-floating{position:absolute;bottom:-24px;right:-24px;background:var(--w);border-radius:16px;padding:20px 24px;box-shadow:0 16px 48px rgba(0,60,100,.15);border:1px solid var(--g2);}
.sf-num{font-family:var(--ff-h);font-size:40px;color:var(--a2);line-height:1;font-style:italic;}
.sf-label{font-size:12px;color:var(--g5);font-weight:500;}

/* ── USP STRIP ── */
.usp-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--g2);border-radius:20px;overflow:hidden;}
.usp-card{background:var(--w);padding:36px 32px;transition:all .3s;}
.usp-card:hover{background:var(--ab);}
.usp-icon{font-size:36px;margin-bottom:16px;}
.usp-card h3{font-size:17px;font-weight:700;color:var(--g9);margin-bottom:8px;}
.usp-card p{font-size:13.5px;color:var(--g5);line-height:1.7;}

/* ── STEPS HORIZONTAL ── */
.steps-h{display:flex;gap:0;position:relative;}
.steps-h::before{content:'';position:absolute;top:28px;left:14%;right:14%;height:2px;background:linear-gradient(90deg,var(--a2),var(--al));opacity:.2;}
.step-h{flex:1;text-align:center;padding:0 16px;}
.step-h-num{width:56px;height:56px;border-radius:50%;background:var(--ab);border:2px solid var(--ap);font-family:var(--ff-h);font-size:20px;color:var(--a2);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;transition:all .3s var(--ease);font-style:italic;}
.step-h:hover .step-h-num{background:var(--a2);color:var(--w);border-color:var(--a2);transform:scale(1.1);box-shadow:0 8px 24px rgba(0,150,199,.3);}
.step-h h4{font-size:15px;font-weight:700;color:var(--g9);margin-bottom:6px;}
.step-h p{font-size:13px;color:var(--g5);line-height:1.6;}

/* ── TESTIMONIAL STYLE ── */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.testi-card{background:var(--w);border:1.5px solid var(--g2);border-radius:20px;padding:28px;transition:all .3s;}
.testi-card:hover{box-shadow:0 12px 40px rgba(0,119,182,.1);transform:translateY(-4px);border-color:var(--ap);}
.testi-stars{color:var(--a1);font-size:14px;margin-bottom:12px;letter-spacing:2px;}
.testi-text{font-size:14px;color:var(--g7);line-height:1.75;margin-bottom:16px;font-style:italic;}
.testi-author{font-size:13px;font-weight:700;color:var(--g9);}
.testi-service{font-size:11.5px;color:var(--a2);font-weight:600;margin-top:2px;}

/* ── FORM ── */
.appt-wrap{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start;}
.appt-info h2{font-family:var(--ff-h);font-size:36px;color:var(--w);margin-bottom:12px;line-height:1.2;}
.appt-info p{font-size:15px;color:rgba(255,255,255,.6);line-height:1.75;margin-bottom:32px;}
.appt-detail{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px;}
.appt-detail-icon{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.appt-detail h5{font-size:14px;font-weight:700;color:var(--w);margin-bottom:3px;}
.appt-detail p{font-size:13px;color:rgba(255,255,255,.5);}
.form-box{background:var(--w);border-radius:24px;padding:44px;box-shadow:0 32px 80px rgba(0,0,0,.15);}
.form-box h3{font-family:var(--ff-h);font-size:26px;color:var(--g9);margin-bottom:6px;}
.form-sub{font-size:14px;color:var(--g5);margin-bottom:28px;}
.fg{margin-bottom:18px;}
.fg label{display:block;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--g5);margin-bottom:7px;}
.fg input,.fg select,.fg textarea{width:100%;padding:13px 16px;border:1.5px solid var(--g2);border-radius:10px;font-family:var(--ff-b);font-size:14px;color:var(--g9);background:var(--w);outline:none;transition:all .25s;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--a2);box-shadow:0 0 0 4px rgba(0,150,199,.07);}
.fg textarea{resize:vertical;min-height:100px;}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-btn{width:100%;padding:15px;background:linear-gradient(135deg,var(--a1),var(--a3));color:var(--w);border:none;border-radius:12px;font-family:var(--ff-b);font-size:15px;font-weight:700;cursor:pointer;transition:all .25s;box-shadow:0 4px 16px rgba(0,150,199,.3);}
.form-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,150,199,.45);}

/* ── PAGE HERO ── */
.ph{background:linear-gradient(160deg,var(--a5) 0%,var(--a4) 50%,var(--a3) 100%);padding:140px 0 80px;position:relative;overflow:hidden;}
.ph::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:var(--w);clip-path:ellipse(55% 100% at 50% 100%);}
.ph-inner{position:relative;z-index:2;}
.ph-tag{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:14px;}
.ph h1{font-family:var(--ff-h);font-size:clamp(36px,5vw,62px);color:var(--w);line-height:1.1;margin-bottom:18px;}
.ph h1 em{font-style:italic;color:var(--al);}
.ph p{font-size:17px;color:rgba(255,255,255,.55);max-width:520px;line-height:1.75;}

/* ── CTA ── */
.cta{background:linear-gradient(135deg,var(--a5),var(--a4),var(--a3));padding:80px 0;position:relative;overflow:hidden;}
.cta::before{content:'🦷';position:absolute;right:8%;top:50%;transform:translateY(-50%);font-size:200px;opacity:.04;pointer-events:none;}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.cta-text h2{font-family:var(--ff-h);font-size:clamp(26px,3.5vw,42px);color:var(--w);line-height:1.2;margin-bottom:10px;}
.cta-text h2 em{font-style:italic;color:var(--al);}
.cta-text p{font-size:14px;color:rgba(255,255,255,.5);}
.cta-btns{display:flex;flex-direction:column;gap:12px;flex-shrink:0;}

/* ── CONTACT ── */
.contact-split{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start;}
.contact-info-card{background:var(--ab);border-radius:20px;padding:36px;border:1.5px solid var(--ap);margin-bottom:20px;}
.cic-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--a2);margin-bottom:8px;}
.cic-val{font-size:16px;font-weight:600;color:var(--g9);}
.cic-val a{color:var(--a2);}
.map-wrap{border-radius:20px;overflow:hidden;height:340px;border:1.5px solid var(--g2);box-shadow:0 8px 32px rgba(0,60,100,.08);}
.map-wrap iframe{width:100%;height:100%;border:none;}

/* ── FOOTER ── */
.footer{background:var(--a5);padding:72px 0 32px;}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.07);}
.footer-logo{font-family:var(--ff-h);font-size:24px;font-style:italic;color:var(--w);margin-bottom:6px;}
.footer-tagline{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--al);margin-bottom:14px;display:block;}
.footer-about{font-size:13px;color:rgba(255,255,255,.35);line-height:1.8;}
.footer-col h5{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:18px;}
.footer-col a,.footer-col p{display:block;font-size:13.5px;color:rgba(255,255,255,.45);margin-bottom:10px;transition:color .2s;}
.footer-col a:hover{color:var(--w);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.18);}

/* ── REVEALS ── */
.rv{opacity:0;transform:translateY(32px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.rv.on{opacity:1;transform:translateY(0);}
.rv-l{opacity:0;transform:translateX(-32px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.rv-l.on{opacity:1;transform:translateX(0);}
.rv-r{opacity:0;transform:translateX(32px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.rv-r.on{opacity:1;transform:translateX(0);}
.rv-s{opacity:0;transform:scale(.92);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.rv-s.on{opacity:1;transform:scale(1);}
.d1{transition-delay:.1s;}.d2{transition-delay:.2s;}.d3{transition-delay:.3s;}.d4{transition-delay:.4s;}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.hero-inner{grid-template-columns:1fr;padding-top:80px;}.hero-right{height:320px;}.split{grid-template-columns:1fr;}.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:900px){.nav-links,.nav-book{display:none;}.hamburger{display:flex;}.services-list{grid-template-columns:1fr;}.usp-strip{grid-template-columns:1fr;}.testimonials{grid-template-columns:1fr;}.appt-wrap{grid-template-columns:1fr;}.contact-split{grid-template-columns:1fr;}.steps-h{flex-wrap:wrap;}.steps-h::before{display:none;}.cta-inner{flex-direction:column;}}
@media(max-width:600px){:root{--sy:72px;}.container{padding:0 18px;}.hero-inner{padding:70px 18px 60px;}.hero-right{display:none;}.services-list{grid-template-columns:1fr;}.footer-grid{grid-template-columns:1fr;gap:32px;}.fg-row{grid-template-columns:1fr;}.form-box{padding:28px 24px;}}
