*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#0B5ED7;--blue-dark:#094BB0;--blue-light:#E8F0FE;
  --orange:#F97316;--orange-dark:#EA6A0E;--orange-light:#FFF3E8;
  --navy:#0F1B2D;--navy-light:#1A2B42;--navy-dark:#0A1219;
  --gold:#D4A843;--gold-light:#E5C06B;--gold-dark:#B8922F;
  --white:#FFFFFF;--grey:#F5F7FA;--grey-dark:#E2E6EC;
  --text:#1A2332;--text-light:#5A6577;--text-lighter:#8892A0;
  --shadow-sm:0 1px 3px rgba(11,94,215,.08);
  --shadow-md:0 4px 16px rgba(11,94,215,.1);
  --shadow-lg:0 12px 40px rgba(11,94,215,.12);
  --shadow-xl:0 20px 60px rgba(11,94,215,.15);
  --radius:12px;--radius-lg:20px;
  --font-body:'DM Sans',sans-serif;
  --font-display:'Playfair Display',serif;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--text);line-height:1.6;overflow-x:hidden;background:var(--white)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{line-height:1.2}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
section{padding:80px 0}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(-20px,-20px)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
@keyframes gradientShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes typewriter{from{width:0}to{width:100%}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes orbit{from{transform:rotate(0deg) translateX(120px) rotate(0deg)}to{transform:rotate(360deg) translateX(120px) rotate(-360deg)}}
@keyframes countUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes ripple{0%{transform:scale(0);opacity:.6}100%{transform:scale(2.5);opacity:0}}
@keyframes borderDance{0%,100%{border-color:var(--blue)}33%{border-color:var(--orange)}66%{border-color:var(--gold)}}

/* ── Reveal system ── */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.9);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}
.reveal-delay-6{transition-delay:.6s}

/* ── Animated gradient hero heading ── */
.gradient-text{background:linear-gradient(135deg,var(--blue) 0%,#6366F1 40%,var(--orange) 80%,var(--blue) 100%);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 5s ease infinite}

/* ── Shimmer on section labels ── */
.section-label-animated{background:linear-gradient(90deg,var(--blue) 0%,#6366F1 50%,var(--blue) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 3s linear infinite}

/* ── Tilt card effect (applied via JS) ── */
.tilt-card{transform-style:preserve-3d;transition:transform .15s ease,box-shadow .15s ease}

/* ── Magnetic button glow ── */
.btn-primary{background:var(--blue);color:white;box-shadow:0 4px 16px rgba(11,94,215,.3);position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.25) 0%,transparent 60%);opacity:0;transition:opacity .3s}
.btn-primary:hover::after{opacity:1}

/* ── Particle canvas ── */
#particleCanvas{position:absolute;inset:0;pointer-events:none;z-index:0}

/* ── Typing cursor ── */
.typing-cursor::after{content:'|';animation:blink .8s step-end infinite;color:var(--orange);font-weight:300}

/* ── Stagger children ── */
.stagger-children > *{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.stagger-children.visible > *:nth-child(1){opacity:1;transform:none;transition-delay:.05s}
.stagger-children.visible > *:nth-child(2){opacity:1;transform:none;transition-delay:.12s}
.stagger-children.visible > *:nth-child(3){opacity:1;transform:none;transition-delay:.19s}
.stagger-children.visible > *:nth-child(4){opacity:1;transform:none;transition-delay:.26s}
.stagger-children.visible > *:nth-child(5){opacity:1;transform:none;transition-delay:.33s}
.stagger-children.visible > *:nth-child(6){opacity:1;transform:none;transition-delay:.40s}
.stagger-children.visible > *:nth-child(7){opacity:1;transform:none;transition-delay:.47s}
.stagger-children.visible > *:nth-child(8){opacity:1;transform:none;transition-delay:.54s}

/* ── Scroll progress bar ── */
#scrollProgress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--orange));z-index:2000;width:0%;transition:width .1s linear;border-radius:0 2px 2px 0}

/* ── Floating orbs (hero background) ── */
.orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;animation:float 8s ease-in-out infinite}
.orb-1{width:300px;height:300px;background:rgba(11,94,215,.08);top:10%;right:5%;animation-delay:0s}
.orb-2{width:200px;height:200px;background:rgba(249,115,22,.06);bottom:20%;left:5%;animation-delay:2s}
.orb-3{width:150px;height:150px;background:rgba(99,102,241,.07);top:50%;right:20%;animation-delay:4s}

/* ── Number ticker ── */
.ticker-wrap{display:inline-block;overflow:hidden;vertical-align:bottom}

/* ── Hover lift with glow ── */
.hover-glow{transition:transform .25s ease,box-shadow .25s ease}
.hover-glow:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(11,94,215,.18)}

/* ── Ripple on click ── */
.ripple-host{position:relative;overflow:hidden}
.ripple-host .ripple-effect{position:absolute;border-radius:50%;background:rgba(255,255,255,.35);transform:scale(0);animation:ripple .6s linear;pointer-events:none}

/* ── Animated underline links ── */
.anim-link{position:relative;display:inline-block}
.anim-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:currentColor;transition:width .3s ease}
.anim-link:hover::after{width:100%}

/* ── Glowing border card ── */
.glow-card{position:relative}
.glow-card::before{content:'';position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(135deg,var(--blue),var(--orange),var(--gold));opacity:0;transition:opacity .3s;z-index:-1;border-radius:calc(var(--radius) + 1px)}
.glow-card:hover::before{opacity:.6}

/* ── Track button in navbar ── */
.nav-track-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;background:rgba(249,115,22,.1);color:var(--orange);font-weight:600;font-size:.88rem;transition:all .2s;border:1.5px solid rgba(249,115,22,.25)}
.nav-track-btn:hover{background:var(--orange);color:white;border-color:var(--orange)}
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-left,.reveal-right,.reveal-scale,.stagger-children>*{transition:none!important;opacity:1!important;transform:none!important}
  .orb,.hero-floating,.gradient-text,.section-label-animated{animation:none!important}
  #scrollProgress{transition:none}
}
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:all .3s ease}
.navbar.scrolled{border-bottom-color:var(--grey-dark);box-shadow:var(--shadow-sm)}
.navbar .container{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--blue)}
.nav-logo span{color:var(--orange)}
.nav-logo .logo-icon{width:40px;height:40px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center;color:white;font-weight:800;font-size:1.1rem;font-family:var(--font-body)}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{font-size:.88rem;font-weight:500;color:var(--text-light);transition:color .2s;position:relative}
.nav-links a:hover{color:var(--blue)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--blue);transition:width .3s}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--blue);font-weight:600}
.nav-links a.active::after{width:100%}
.nav-cta{background:var(--blue);color:white!important;padding:10px 20px;border-radius:8px;font-weight:600;transition:all .2s}
.nav-cta:hover{background:var(--blue-dark);transform:translateY(-1px)}
.nav-cta::after{display:none!important}
.contact-dropdown{position:relative}
.contact-dropdown-btn{cursor:pointer;display:flex;align-items:center;gap:4px}
.contact-dropdown-btn svg{width:12px;height:12px;transition:transform .3s}
.contact-dropdown:hover .contact-dropdown-btn svg{transform:rotate(180deg)}
.contact-dropdown-menu{position:absolute;top:100%;right:0;background:white;border-radius:10px;box-shadow:var(--shadow-lg);padding:8px;min-width:180px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s;margin-top:8px}
.contact-dropdown:hover .contact-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.contact-dropdown-menu a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:6px;font-size:.88rem;color:var(--text);transition:all .2s}
.contact-dropdown-menu a:hover{background:var(--blue-light);color:var(--blue)}
.contact-dropdown-menu a::after{display:none!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.hamburger span{width:24px;height:2px;background:var(--text);transition:all .3s;border-radius:2px}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.hero{padding:140px 0 80px;background:linear-gradient(165deg,var(--white) 0%,#E8EDF5 50%,var(--white) 100%);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(11,94,215,.06) 0%,transparent 70%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(249,115,22,.05) 0%,transparent 70%);pointer-events:none}
.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative}
.hero-content{animation:fadeUp .8s ease both}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--orange-light);color:var(--orange-dark);padding:8px 16px;border-radius:100px;font-size:.85rem;font-weight:600;margin-bottom:24px}
.hero-badge::before{content:'';width:8px;height:8px;background:var(--orange);border-radius:50%;animation:pulse 2s infinite}
.hero h1{font-family:var(--font-display);font-size:3.2rem;font-weight:800;color:var(--text);line-height:1.15;margin-bottom:20px}
.hero h1 .highlight{color:var(--blue);position:relative}
.hero h1 .highlight::after{content:'';position:absolute;bottom:2px;left:0;right:0;height:8px;background:rgba(11,94,215,.12);border-radius:4px;z-index:-1}
.hero-sub{font-size:1.1rem;color:var(--text-light);line-height:1.7;margin-bottom:32px;max-width:540px}
.hero-trust{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:36px}
.hero-trust .badge{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:500;color:var(--text)}
.hero-trust .badge svg{width:18px;height:18px;color:var(--blue);flex-shrink:0}
.hero-buttons{display:flex;flex-wrap:wrap;gap:12px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:10px;font-weight:600;font-size:.95rem;transition:all .25s;cursor:pointer;border:none;font-family:var(--font-body)}
.btn-primary{background:var(--blue);color:white;box-shadow:0 4px 16px rgba(11,94,215,.3)}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:0 6px 24px rgba(11,94,215,.35)}
.btn-outline{background:transparent;color:var(--blue);border:2px solid var(--blue)}
.btn-outline:hover{background:var(--blue);color:white;transform:translateY(-2px)}
.hero-visual{position:relative;animation:fadeIn 1s ease .3s both}
.hero-card{background:white;border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-xl);position:relative}
.hero-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hero-service-chip{background:var(--grey);border-radius:10px;padding:14px 16px;font-size:.85rem;font-weight:500;color:var(--text);display:flex;align-items:center;gap:10px;transition:all .2s}
.hero-service-chip:hover{background:var(--blue-light);color:var(--blue)}
.hero-service-chip .chip-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.hero-floating{position:absolute;background:white;border-radius:var(--radius);padding:14px 20px;box-shadow:var(--shadow-lg);animation:float 3s ease-in-out infinite;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:8px}
.hero-floating.top-right{top:-20px;right:-20px;animation-delay:.5s}
.hero-floating.bottom-left{bottom:-15px;left:-15px;animation-delay:1s}
.about{background:var(--white)}
.about .container{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-visual{position:relative}
.about-img-box{background:linear-gradient(135deg,var(--navy),var(--navy-light));border-radius:var(--radius-lg);padding:40px;color:white;position:relative;overflow:hidden}
.about-img-box::before{content:'';position:absolute;top:-50px;right:-50px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.08)}
.about-img-box h3{font-family:var(--font-display);font-size:2rem;margin-bottom:12px}
.about-img-box p{opacity:.9;font-size:.95rem;line-height:1.6}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}
.about-stat{background:rgba(255,255,255,.12);border-radius:10px;padding:16px;text-align:center}
.about-stat .num{font-size:1.8rem;font-weight:700;font-family:var(--font-display)}
.about-stat .label{font-size:.8rem;opacity:.8;margin-top:4px}
.section-label{display:inline-flex;align-items:center;gap:8px;color:var(--blue);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px}
.section-label::before{content:'';width:24px;height:2px;background:var(--blue);border-radius:2px}
.section-title{font-family:var(--font-display);font-size:2.4rem;font-weight:700;margin-bottom:20px;color:var(--text)}
.section-title .accent{color:var(--blue)}
.about-text p{color:var(--text-light);margin-bottom:16px;font-size:1rem;line-height:1.7}
.trust{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);color:white;position:relative;overflow:hidden}
.trust::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:rgba(212,168,67,.06)}
.trust::after{content:'';position:absolute;bottom:-80px;left:-80px;width:300px;height:300px;border-radius:50%;background:rgba(212,168,67,.04)}
.trust .section-label{color:rgba(255,255,255,.7)}
.trust .section-label::before{background:var(--gold)}
.trust .section-title{color:white}
.trust .section-title .accent{color:var(--gold)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:48px;position:relative;z-index:1}
.trust-item{text-align:center;padding:32px 20px;background:rgba(255,255,255,.05);border-radius:var(--radius);border:1px solid rgba(255,255,255,.08);transition:all .3s}
.trust-item:hover{background:rgba(255,255,255,.08);border-color:var(--gold);transform:translateY(-4px)}
.trust-item .number{font-family:var(--font-display);font-size:2.8rem;font-weight:800;color:var(--gold);margin-bottom:8px}
.trust-item .label{font-size:.95rem;opacity:.85}
.testimonials{background:var(--grey);padding-top:40px}
.testimonials .section-header{text-align:center;margin-bottom:48px}
.testimonial-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.testimonial-card{background:white;border-radius:var(--radius);padding:32px;position:relative;border:1px solid var(--grey-dark);transition:all .3s}
.testimonial-card:hover{box-shadow:var(--shadow-md);border-color:var(--blue-light)}
.testimonial-stars{color:var(--orange);font-size:1.1rem;margin-bottom:16px;letter-spacing:2px}
.testimonial-card p{color:var(--text-light);font-size:.95rem;line-height:1.7;font-style:italic}
.testimonial-card .quote-mark{position:absolute;top:20px;right:24px;font-size:3rem;color:var(--blue-light);font-family:var(--font-display);line-height:1}
.footer{background:var(--navy);color:white;padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px}
.footer-brand .nav-logo{margin-bottom:16px}
.footer-brand p{color:rgba(255,255,255,.6);font-size:.9rem;line-height:1.7;max-width:360px}
.footer h4{font-size:.95rem;font-weight:700;margin-bottom:20px;position:relative;padding-bottom:12px}
.footer h4::after{content:'';position:absolute;bottom:0;left:0;width:30px;height:2px;background:var(--gold);border-radius:2px}
.footer-links a{display:block;color:rgba(255,255,255,.6);font-size:.88rem;padding:5px 0;transition:all .2s}
.footer-links a:hover{color:var(--gold);padding-left:4px}
.footer-contact-item{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.6);font-size:.88rem;margin-bottom:12px}
.footer-contact-item svg{width:16px;height:16px;color:var(--gold);flex-shrink:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding:24px 0;text-align:center;color:rgba(255,255,255,.4);font-size:.85rem}
.mobile-nav{display:none;position:fixed;top:72px;left:0;right:0;bottom:0;background:white;z-index:999;padding:16px;flex-direction:column;gap:0;overflow-y:auto}
.mobile-nav.active{display:flex}
.mobile-nav a{display:block;padding:18px 8px;font-size:1.05rem;font-weight:500;color:var(--text);border-bottom:1px solid var(--grey);transition:color .2s;min-height:56px;display:flex;align-items:center}
.mobile-nav a:hover{color:var(--blue)}
.call-float{position:fixed;bottom:24px;right:84px;width:50px;height:50px;background:#0B5ED7;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(11,94,215,.4);z-index:999;transition:all .3s;cursor:pointer}
.call-float:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(11,94,215,.5)}
.call-float::before{content:"";position:absolute;width:100%;height:100%;border-radius:50%;background:#0B5ED7;animation:call-pulse 2s infinite;opacity:.6;z-index:-1}
@keyframes call-pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.4);opacity:0}}
.call-float svg{width:24px;height:24px;fill:white}
.call-tooltip{position:absolute;right:60px;background:white;color:var(--text);padding:10px 16px;border-radius:8px;font-size:.85rem;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity .3s}
.call-float:hover .call-tooltip{opacity:1}
.whatsapp-float{position:fixed;bottom:24px;right:24px;width:50px;height:50px;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:999;transition:all .3s;cursor:pointer}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.5)}
.whatsapp-float::before{content:'';position:absolute;width:100%;height:100%;border-radius:50%;background:#25D366;animation:whatsapp-pulse 2s infinite;opacity:.6;z-index:-1}
@keyframes whatsapp-pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.4);opacity:0}}
.whatsapp-float svg{width:32px;height:32px;fill:white}
.whatsapp-tooltip{position:absolute;right:72px;background:white;color:var(--text);padding:10px 16px;border-radius:8px;font-size:.85rem;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity .3s}
.whatsapp-float:hover .whatsapp-tooltip{opacity:1}
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:2000;display:none;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .3s}
.modal-overlay.active{display:flex;opacity:1}
.modal{background:white;border-radius:var(--radius-lg);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:fadeUp .4s ease}
.modal-header{padding:32px 32px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.modal-header h2{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--text)}
.modal-header p{color:var(--text-light);font-size:.9rem;margin-top:6px}
.modal-close{width:36px;height:36px;border-radius:50%;background:var(--grey);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.modal-close:hover{background:var(--blue-light);color:var(--blue)}
.modal-close svg{width:16px;height:16px}
.modal-body{padding:24px 32px 32px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:.88rem;font-weight:600;color:var(--text);margin-bottom:8px}
.form-group label span{color:var(--orange)}
.form-input{width:100%;padding:12px 16px;border:1.5px solid var(--grey-dark);border-radius:10px;font-size:.95rem;font-family:var(--font-body);transition:all .2s;background:white;color:var(--text)}
.form-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(11,94,215,.1)}
.form-input::placeholder{color:var(--text-lighter)}
textarea.form-input{resize:vertical;min-height:100px}
select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235A6577' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-submit{width:100%;padding:14px;background:var(--orange);color:white;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--font-body);display:flex;align-items:center;justify-content:center;gap:8px}
.form-submit:hover{background:var(--orange-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(249,115,22,.3)}
.form-note{text-align:center;margin-top:16px;font-size:.82rem;color:var(--text-light)}
.form-note a{color:var(--blue);font-weight:600}
/* ============================================================
   RESPONSIVE — 1024px (tablet landscape)
   ============================================================ */
@media(max-width:1024px){
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero .container{gap:40px}
  .about .container{gap:40px}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:20px}
}

/* ============================================================
   RESPONSIVE — 768px (tablet portrait / large phone)
   ============================================================ */
@media(max-width:768px){
  /* Layout */
  section{padding:56px 0}
  .container{padding:0 16px}

  /* Navbar */
  .nav-links{display:none}
  .hamburger{display:flex}

  /* Hero */
  .hero{padding:100px 0 56px}
  .hero .container{grid-template-columns:1fr;gap:32px}
  .hero h1{font-size:2.2rem}
  .hero-sub{font-size:1rem}
  .hero-visual{display:none} /* hide decorative card on small screens */
  .hero-buttons{flex-direction:column;align-items:flex-start}
  .hero-buttons .btn{width:100%;justify-content:center}

  /* About */
  .about .container{grid-template-columns:1fr;gap:32px}
  .about-visual{order:-1}

  /* Trust */
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-top:32px}

  /* Why Us */
  .why-grid{grid-template-columns:1fr;gap:16px;margin-top:32px}

  /* Testimonials */
  .testimonial-grid{grid-template-columns:1fr}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer{padding:48px 0 0}

  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .contact-map{min-height:300px}
  .contact-map iframe{min-height:300px}

  /* Forms */
  .form-row{grid-template-columns:1fr}

  /* Floating buttons */
  .call-float{width:48px;height:48px;right:80px;bottom:20px}
  .whatsapp-float{width:48px;height:48px;right:20px;bottom:20px}
  .call-float svg{width:22px;height:22px}
  .whatsapp-float svg{width:28px;height:28px}

  /* Back to top */
  .back-to-top{bottom:80px;right:20px;width:44px;height:44px}

  /* Page header */
  .page-header{padding:100px 0 48px}
  .page-header h1{font-size:2rem}

  /* Section titles */
  .section-title{font-size:1.9rem}

  /* Service grids */
  .service-grid{grid-template-columns:1fr}
  .service-single{grid-template-columns:1fr 1fr}

  /* Team */
  .team-grid{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}
  .team-image{height:280px}
  .team-avatar{width:140px;height:140px;font-size:3rem}

  /* Cookie banner */
  .cookie-content{flex-direction:column;text-align:center}
  .cookie-buttons{width:100%;flex-direction:column}
  .cookie-btn{width:100%}

  /* Modal */
  .modal{margin:0 8px;max-height:95vh}
  .modal-header{padding:24px 20px 0}
  .modal-body{padding:20px}

  /* SD pages */
  .sd-header-grid{grid-template-columns:1fr;gap:24px}
  .sd-header-grid h1{font-size:1.9rem}
  .sd-two-col{grid-template-columns:1fr;gap:24px}
  .sd-cta-row{flex-direction:column}
  .sd-cta-row .btn{width:100%;justify-content:center}
}

/* ============================================================
   RESPONSIVE — 480px (small phones)
   ============================================================ */
@media(max-width:480px){
  section{padding:44px 0}
  .hero{padding:88px 0 44px}
  .hero h1{font-size:1.8rem}
  .hero-trust{flex-direction:column;gap:8px}
  .trust-grid{grid-template-columns:1fr}
  .trust-item .number{font-size:2.2rem}
  .service-single{grid-template-columns:1fr}
  .page-header h1{font-size:1.7rem}
  .section-title{font-size:1.6rem}
  .footer-grid{gap:24px}
  .why-grid{gap:12px}
  .team-grid{max-width:100%}
  .modal-header h2{font-size:1.3rem}
  .sd-header-grid h1{font-size:1.6rem}
}
.theme-toggle {
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  border-radius: 8px;
  transition: all 0.2s;
  color: var(--text);
}
.theme-toggle:hover {
  background: var(--grey);
}
.theme-toggle svg{width:20px;height:20px;stroke:var(--text)}

.back-to-top {
  position: fixed;
  bottom: 90px;
  right: 24px;
  width: 50px;
  height: 50px;
  background: var(--blue);
  color: white;
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
  z-index: 998;
  box-shadow: 0 4px 12px rgba(11,94,215,.3);
}
.back-to-top.visible {
  opacity: 1;
  visibility: visible;
}
.back-to-top:hover {
  background: var(--blue-dark);
  transform: translateY(-3px);
}
.back-to-top svg{width:24px;height:24px}
.page-loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: white;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.5s;
}
.page-loader.hidden {
  opacity: 0;
  pointer-events: none;
}
.loader {
  width: 60px;
  height: 60px;
  border: 4px solid var(--grey);
  border-top-color: var(--blue);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--navy);
  color: white;
  padding: 20px;
  z-index: 1001;
  transform: translateY(100%);
  transition: transform 0.4s;
  box-shadow: 0 -4px 20px rgba(0,0,0,.2);
}
.cookie-banner.show {
  transform: translateY(0);
}
.cookie-content {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.cookie-text{flex:1;font-size:.9rem;line-height:1.6}
.cookie-text a{color:var(--gold);text-decoration:underline}
.cookie-buttons {
  display: flex;
  gap: 12px;
}
.cookie-btn {
  padding: 10px 24px;
  border: none;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  font-family: var(--font-body);
}
.cookie-accept {
  background: var(--gold);
  color: var(--navy);
}
.cookie-accept:hover {
  background: var(--gold-light);
}
.cookie-decline {
  background: transparent;
  color: white;
  border: 1px solid rgba(255,255,255,.3);
}
.cookie-decline:hover {
  background: rgba(255,255,255,.1);
}
body.dark-mode {
  /* CSS variable overrides — these cascade through every var() reference */
  --white: #0F1B2D;
  --grey: #1A2B42;
  --grey-dark: #2D3748;
  --text: #E2E8F0;
  --text-light: #A0AEC0;
  --text-lighter: #718096;
  --blue-light: #1E3A8A;
  --orange-light: #3D2817;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,.35);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.4);
  --shadow-xl: 0 20px 60px rgba(0,0,0,.5);
  background: #0F1B2D;
  color: #E2E8F0;
}
body.dark-mode .navbar {
  background: rgba(15,27,45,.95);
}
body.dark-mode .nav-links a{color:#A0AEC0}
body.dark-mode .nav-links a:hover{color:#E2E8F0}
body.dark-mode .nav-links a.active{color:#E2E8F0}
body.dark-mode .contact-dropdown-menu{background:#1A2B42}
body.dark-mode .contact-dropdown-menu a{color:#E2E8F0}
body.dark-mode .contact-dropdown-menu a:hover{background:#2D3748}
body.dark-mode .hero {
  background: linear-gradient(165deg,#0F1B2D 0%,#1A2B42 50%,#0F1B2D 100%);
}
body.dark-mode .hero h1{color:#E2E8F0}
body.dark-mode .hero h1 .highlight{color:#60A5FA}
body.dark-mode .hero-sub{color:#A0AEC0}
body.dark-mode .hero-badge{background:#1A2B42;color:#F97316}
body.dark-mode .hero-trust .badge{color:#E2E8F0}
body.dark-mode .hero-card{background:#1A2B42}
body.dark-mode .hero-service-chip{background:#2D3748;color:#E2E8F0}
body.dark-mode .hero-service-chip:hover{background:#374151}
body.dark-mode .hero-floating{background:#1A2B42;color:#E2E8F0}
body.dark-mode .section-label{color:#60A5FA}
body.dark-mode .section-title{color:#E2E8F0}
body.dark-mode .section-title .accent{color:#60A5FA}
body.dark-mode .about-img-box{background:linear-gradient(135deg,#1A2B42,#2D3748)}
body.dark-mode .about-text p{color:#A0AEC0}
body.dark-mode .service-card,body.dark-mode .testimonial-card,body.dark-mode .contact-card,body.dark-mode .why-card{background:#1A2B42;color:#E2E8F0}
body.dark-mode .service-card h4,body.dark-mode .testimonial-card p,body.dark-mode .contact-card h4,body.dark-mode .why-card h3{color:#E2E8F0}
body.dark-mode .service-card ul li,body.dark-mode .contact-card p,body.dark-mode .why-card p{color:#A0AEC0}
body.dark-mode .service-category-title{color:#E2E8F0}
body.dark-mode .service-single-item{background:#1A2B42;color:#E2E8F0}
body.dark-mode .service-single-item:hover{background:#2D3748}
body.dark-mode .testimonial-stars{color:#F97316}
body.dark-mode .testimonial-card .quote-mark{color:#2D3748}
body.dark-mode .faq-item{background:#1A2B42;border-color:#2D3748}
body.dark-mode .faq-question{color:#E2E8F0}
body.dark-mode .faq-question:hover{color:#60A5FA}
body.dark-mode .faq-item.active .faq-question{color:#60A5FA}
body.dark-mode .faq-toggle{background:#2D3748;color:#E2E8F0}
body.dark-mode .faq-item.active .faq-toggle{background:#0B5ED7;color:white}
body.dark-mode .faq-answer-inner{color:#A0AEC0}
body.dark-mode .contact-card a{color:#A0AEC0}
body.dark-mode .contact-card a:hover{color:#60A5FA}
body.dark-mode .trust{background:linear-gradient(135deg,#0A1219,#1A2B42)}
body.dark-mode .trust .section-title{color:#E2E8F0}
body.dark-mode .trust .section-title .accent{color:#D4A843}
body.dark-mode .trust-item{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1)}
body.dark-mode .trust-item:hover{background:rgba(255,255,255,.08);border-color:#D4A843}
body.dark-mode .trust-item .number{color:#D4A843}
body.dark-mode .trust-item .label{color:#E2E8F0}
body.dark-mode .btn-primary{background:#0B5ED7;color:white}
body.dark-mode .btn-primary:hover{background:#094BB0}
body.dark-mode .btn-outline{color:#60A5FA;border-color:#60A5FA}
body.dark-mode .btn-outline:hover{background:#60A5FA;color:#0F1B2D}
body.dark-mode .footer {
  background: #0A1219;
}
body.dark-mode .footer-brand p{color:#A0AEC0}
body.dark-mode .footer h4{color:#E2E8F0}
body.dark-mode .footer-links a{color:#A0AEC0}
body.dark-mode .footer-links a:hover{color:#D4A843}
body.dark-mode .footer-contact-item{color:#A0AEC0}
body.dark-mode .footer-bottom{color:#6B7280;border-top-color:#2D3748}
body.dark-mode .modal {
  background: #1A2B42;
  color: #E2E8F0;
}
body.dark-mode .modal-header h2{color:#E2E8F0}
body.dark-mode .modal-header p{color:#A0AEC0}
body.dark-mode .modal-close{background:#2D3748;color:#E2E8F0}
body.dark-mode .modal-close:hover{background:#374151}
body.dark-mode .form-input {
  background: #0F1B2D;
  color: #E2E8F0;
  border-color: #2D3748;
}
body.dark-mode .form-input::placeholder{color:#6B7280}
body.dark-mode .form-group label{color:#E2E8F0}
body.dark-mode .form-group label span{color:#F97316}
body.dark-mode .form-submit{background:#F97316;color:white}
body.dark-mode .form-submit:hover{background:#EA6A0E}
body.dark-mode .form-note{color:#A0AEC0}
body.dark-mode .form-note a{color:#60A5FA}
body.dark-mode .cookie-banner {
  background: #1A2B42;
}
body.dark-mode .cookie-content p{color:#E2E8F0}
body.dark-mode .cookie-content a{color:#D4A843}
body.dark-mode .cookie-accept{background:#D4A843;color:#0F1B2D}
body.dark-mode .cookie-decline{color:#E2E8F0;border-color:#4B5563}

body.dark-mode .page-header{background:linear-gradient(165deg,#0F1B2D 0%,#1A2B42 50%,#0F1B2D 100%)}
body.dark-mode .page-header h1{color:#E2E8F0}
body.dark-mode .page-header h1 .accent{color:#60A5FA}
body.dark-mode .page-header p{color:#A0AEC0}
body.dark-mode .team-card{background:#1A2B42}
body.dark-mode .team-name{color:#E2E8F0}
body.dark-mode .team-role{color:#60A5FA}
body.dark-mode .team-bio{color:#A0AEC0}
body.dark-mode .team-social a{background:#2D3748;color:#E2E8F0}
body.dark-mode .team-social a:hover{background:#0B5ED7;color:white}
.qr-section{text-align:center;padding:40px;background:var(--grey);border-radius:var(--radius-lg);margin-top:40px}
.qr-section h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:12px}
.qr-section p{color:var(--text-light);margin-bottom:24px}
.qr-code{display:inline-block;padding:20px;background:white;border-radius:var(--radius);box-shadow:var(--shadow-md)}
.page-header{padding:140px 0 60px;background:linear-gradient(165deg,var(--white) 0%,#E8EDF5 50%,var(--white) 100%);text-align:center}
.page-header h1{font-family:var(--font-display);font-size:2.8rem;font-weight:800;margin-bottom:16px}
.page-header h1 .accent{color:var(--navy)}
.page-header p{color:var(--text-light);font-size:1.1rem;max-width:640px;margin:0 auto}
.services{background:var(--white)}
.services-header{text-align:center;max-width:640px;margin:0 auto 48px}
.services-header p{color:var(--text-light);font-size:1.05rem;margin-top:12px}
.service-category{margin-bottom:56px}
.service-category-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin-bottom:24px;display:flex;align-items:center;gap:12px;color:var(--text)}
.service-category-title .cat-icon{width:40px;height:40px;border-radius:10px;background:var(--blue);color:white;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.service-card{background:var(--grey);border-radius:var(--radius);padding:24px;transition:all .3s;border:1px solid transparent;cursor:default}
.service-card:hover{background:white;border-color:var(--blue-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.service-card h4{font-size:1rem;font-weight:700;margin-bottom:10px;color:var(--text);display:flex;align-items:center;gap:8px}
.service-card h4 .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);flex-shrink:0}
.service-card ul{display:flex;flex-direction:column;gap:6px}
.service-card ul li{font-size:.88rem;color:var(--text-light);display:flex;align-items:center;gap:8px}
.service-card ul li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--blue);opacity:.5;flex-shrink:0}
.service-single{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.service-single-item{background:var(--grey);border-radius:10px;padding:16px 20px;font-size:.9rem;font-weight:500;color:var(--text);display:flex;align-items:center;gap:10px;transition:all .2s}
.service-single-item:hover{background:var(--blue-light);color:var(--blue)}
.service-single-item .s-icon{width:32px;height:32px;border-radius:8px;background:white;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;box-shadow:var(--shadow-sm)}

.cookie-content p {
  flex: 1;
  font-size: 0.9rem;
  line-height: 1.6;
}
.cookie-content a {
  color: var(--gold);
  text-decoration: underline;
}
body.dark-mode .hero-card,
body.dark-mode .service-card,
body.dark-mode .testimonial-card,
body.dark-mode .contact-card,
body.dark-mode .why-card {
  background: #1A2B42;
  color: #E2E8F0;
}
.why-us{background:var(--grey)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.why-card{background:white;border-radius:var(--radius);padding:32px 28px;transition:all .3s;border:1px solid transparent;position:relative;overflow:hidden}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--blue);transform:scaleX(0);transition:transform .3s;transform-origin:left}
.why-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--blue-light)}
.why-card:hover::before{transform:scaleX(1)}
.why-icon{width:52px;height:52px;border-radius:12px;background:var(--blue-light);display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:1.4rem;color:var(--blue)}
.why-card h3{font-size:1.1rem;font-weight:700;margin-bottom:8px}
.why-card p{color:var(--text-light);font-size:.9rem;line-height:1.6}
.team-section{background:var(--white)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px;margin-top:60px}
.team-card{background:white;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all .3s;border:1px solid var(--grey-dark)}
.team-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--blue-light)}
.team-image{width:100%;height:350px;background:linear-gradient(135deg,var(--blue-light),var(--orange-light));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.team-image::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(11,94,215,.1) 0%,transparent 70%);animation:float 6s ease-in-out infinite}
.team-avatar{width:180px;height:180px;border-radius:50%;background:white;display:flex;align-items:center;justify-content:center;font-size:4rem;color:var(--blue);box-shadow:var(--shadow-lg);position:relative;z-index:1}
.team-info{padding:32px}
.team-name{font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin-bottom:8px;color:var(--text)}
.team-role{color:var(--blue);font-weight:600;font-size:1rem;margin-bottom:16px}
.team-bio{color:var(--text-light);font-size:.95rem;line-height:1.7;margin-bottom:20px}
.team-social{display:flex;gap:12px}
.team-social a{width:40px;height:40px;border-radius:50%;background:var(--grey);display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-light)}
.team-social a:hover{background:var(--blue);color:white;transform:translateY(-2px)}
.team-social svg{width:20px;height:20px}
.faq{background:var(--white);padding-top:40px}
.faq .container{max-width:800px}
.faq-header{text-align:center;margin-bottom:48px}
.faq-item{border:1px solid var(--grey-dark);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;transition:all .3s}
.faq-item.active{border-color:var(--blue);box-shadow:var(--shadow-sm)}
.faq-question{padding:20px 24px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s;gap:16px}
.faq-question:hover{color:var(--blue)}
.faq-item.active .faq-question{color:var(--blue)}
.faq-toggle{width:28px;height:28px;border-radius:50%;background:var(--grey);display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0}
.faq-item.active .faq-toggle{background:var(--blue);color:white;transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease}
.faq-answer-inner{padding:0 24px 20px;color:var(--text-light);font-size:.9rem;line-height:1.7}
.contact{background:var(--grey);padding-top:40px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:48px}
.contact-info{display:flex;flex-direction:column;gap:20px}
.contact-card{background:white;border-radius:var(--radius);padding:24px;display:flex;align-items:flex-start;gap:16px;border:1px solid var(--grey-dark);transition:all .3s}
.contact-card:hover{border-color:var(--blue-light);box-shadow:var(--shadow-sm)}
.contact-card-icon{width:48px;height:48px;border-radius:12px;background:var(--blue-light);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.contact-card h4{font-size:.95rem;font-weight:700;margin-bottom:4px}
.contact-card p,.contact-card a{color:var(--text-light);font-size:.9rem}
.contact-card a:hover{color:var(--blue)}
.contact-map{background:white;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--grey-dark);min-height:450px;display:flex;align-items:center;justify-content:center}
.contact-map iframe{width:100%;height:100%;min-height:450px;border:0;border-radius:var(--radius-lg)}
.qr-code img{width:200px;height:200px}

/* ============================================================
   v2.1 PATCHES — Dark-mode fixes for previously invisible content
   Add overrides for elements that hard-coded `background:white`
   ============================================================ */
body.dark-mode .mobile-nav{background:#0F1B2D}
body.dark-mode .mobile-nav a{color:#E2E8F0;border-bottom-color:#1A2B42}
body.dark-mode .mobile-nav a:hover{color:#60A5FA}
body.dark-mode .whatsapp-tooltip,
body.dark-mode .call-tooltip{background:#1A2B42;color:#E2E8F0;box-shadow:0 4px 16px rgba(0,0,0,.4)}
body.dark-mode .contact-map{background:#1A2B42;border-color:#2D3748}
body.dark-mode .contact-map-placeholder{color:#A0AEC0}
body.dark-mode .contact-map-placeholder h3{color:#E2E8F0}
body.dark-mode .hero-card{background:#1A2B42;color:#E2E8F0}
body.dark-mode .hero-floating{background:#1A2B42;color:#E2E8F0;box-shadow:0 12px 40px rgba(0,0,0,.4)}
body.dark-mode .hero-service-chip .chip-icon{filter:brightness(.85)}
body.dark-mode .service-single-item .s-icon{background:#0F1B2D;color:#E2E8F0}
body.dark-mode .team-card{background:#1A2B42;border-color:#2D3748}
body.dark-mode .team-name{color:#E2E8F0}
body.dark-mode .team-bio{color:#A0AEC0}
body.dark-mode .team-avatar{background:#0F1B2D;color:#60A5FA}
body.dark-mode .team-social a{background:#0F1B2D;color:#A0AEC0}
body.dark-mode .team-social a:hover{background:#0B5ED7;color:#fff}
body.dark-mode .testimonial-card{background:#1A2B42;border-color:#2D3748}
body.dark-mode .contact-card{background:#1A2B42;border-color:#2D3748}
body.dark-mode .contact-card h4{color:#E2E8F0}
body.dark-mode .contact-card p,
body.dark-mode .contact-card a{color:#A0AEC0}
body.dark-mode .why-card{background:#1A2B42;border-color:#2D3748}
body.dark-mode .why-card h3{color:#E2E8F0}
body.dark-mode .modal{background:#1A2B42;color:#E2E8F0}
body.dark-mode .modal-close{background:#0F1B2D;color:#E2E8F0}
body.dark-mode .modal-close:hover{background:#2D3748}
body.dark-mode .form-input{background-color:#0F1B2D;color:#E2E8F0;border-color:#2D3748}
body.dark-mode select.form-input{background-color:#0F1B2D;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23A0AEC0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
body.dark-mode .qr-section{background:#1A2B42}
body.dark-mode .qr-section h3{color:#E2E8F0}
body.dark-mode .qr-section p{color:#A0AEC0}
body.dark-mode .qr-code{background:#fff} /* keep white for scannability */
body.dark-mode .page-loader{background:#0F1B2D}

body.dark-mode .contact-dropdown-menu{background:#1A2B42;border:1px solid #2D3748}
body.dark-mode .contact-dropdown-menu a{color:#E2E8F0}
body.dark-mode .contact-dropdown-menu a:hover{background:#0F1B2D;color:#60A5FA}
body.dark-mode .navbar{background:rgba(15,27,45,.92);border-bottom-color:#1A2B42}
body.dark-mode .navbar.scrolled{border-bottom-color:#2D3748}
body.dark-mode .hamburger span{background:#E2E8F0}
body.dark-mode .theme-toggle{color:#E2E8F0}
body.dark-mode .theme-toggle:hover{background:#1A2B42}

/* Contact-page form wrapper (replaces inline style="background:white;...") */
.contact-form-wrapper{background:#fff;padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--grey-dark)}
body.dark-mode .contact-form-wrapper{background:#1A2B42;border-color:#2D3748}
body.dark-mode .contact-form-wrapper h2,
body.dark-mode .contact-form-wrapper h3,
body.dark-mode .contact-form-wrapper p{color:#E2E8F0}

/* Trust section dark-mode adjustment */
body.dark-mode .trust{background:linear-gradient(135deg,#0A1219 0%,#0F1B2D 100%)}
@media (max-width:768px){
  body.dark-mode .mobile-nav a{color:#E2E8F0}
}

/* ============================================================
   v2.1 PATCHES — Misc improvements
   ============================================================ */
/* Smoother focus rings (accessibility) */
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:6px}
body.dark-mode :focus-visible{outline-color:#60A5FA}

/* Prevent layout shift while page loader is active */
body.loading{overflow:hidden}

/* Honor user OS preference if no manual choice yet */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* === v2.2 Toast ====================================================== */
.ez-toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--navy);color:#fff;padding:14px 24px;border-radius:10px;font-size:.9rem;font-weight:600;box-shadow:var(--shadow-lg);z-index:2500;opacity:0;transition:transform .35s cubic-bezier(.22,1,.36,1),opacity .35s;pointer-events:none;max-width:90vw;text-align:center}
.ez-toast.show{transform:translateX(-50%) translateY(0);opacity:1}
body.dark-mode .ez-toast{background:#1A2B42;border:1px solid #2D3748}


/* === v2.3 — Heading hierarchy fixes (mirror old h3 styles for new h2) === */
.about-img-box h2.about-img-h2{font-family:var(--font-display);font-size:2rem;margin-bottom:12px;color:#fff}
h2.team-name{font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin-bottom:6px;color:var(--text)}
h2.service-category-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin-bottom:24px;display:flex;align-items:center;gap:12px;color:var(--text)}
h3.service-card-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:6px;color:var(--text)}
h3.contact-card-h{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:4px;color:var(--text)}
body.dark-mode h3.contact-card-h,
body.dark-mode h2.team-name,
body.dark-mode h2.service-category-title,
body.dark-mode h3.service-card-title{color:#E2E8F0}

h3.service-list-item{font-size:1rem;font-weight:500;margin:0;padding:8px 0;color:var(--text);display:flex;align-items:center;gap:10px}
body.dark-mode h3.service-list-item{color:#E2E8F0}

/* === v2.3 — FAQ question heading semantic fix === */
.faq-q-text{font-family:var(--font-body);font-size:1.05rem;font-weight:600;color:var(--text);margin:0;flex:1;line-height:1.4}
body.dark-mode .faq-q-text{color:#E2E8F0}
.faq-question{align-items:center}

/* === Footer h3 hierarchy (was h4) === */
.footer-col h3{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:16px}
body.dark-mode .footer-col h3{color:#E2E8F0}

/* Visually-hidden utility (accessibility) */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* === v2.3 — Accessibility: WCAG AA contrast fixes ===================== */
:root {
  /* Darkened from #8892A0 (3.6:1) to #5A6577 (6.6:1) for AA on white */
  --text-lighter: #5A6577;
  /* Orange used as TEXT — darken so we meet 4.5:1 on light backgrounds */
  --orange-text: #B8530F;
}
/* Hero badge: dark orange text on cream had ~3.3:1 → use --orange-text */
.hero-badge { color: var(--orange-text); }
/* Form placeholders & cookie banner small text */
.form-input::placeholder { color: var(--text-lighter); opacity: 1; }
.cookie-text { color: rgba(255,255,255,.85) }
.cookie-text a { color: #FFD27D }
/* Footer link / bottom-text contrast bump */
.footer-brand p, .footer-links a, .footer-contact-item { color: rgba(255,255,255,.78) }
.footer-bottom { color: rgba(255,255,255,.7) }
/* Trust section eyebrow */
.trust .section-label { color: rgba(255,255,255,.9) }

/* === v2.3 — Service detail (SD) pages =============================== */
.sd-breadcrumb{font-size:.85rem;color:var(--text-light);margin-bottom:20px}
.sd-breadcrumb a{color:var(--blue)}
.sd-breadcrumb a:hover{text-decoration:underline}
.sd-breadcrumb span:not([aria-current]){margin:0 6px;opacity:.5}
.sd-breadcrumb [aria-current]{color:var(--text);font-weight:500}
body.dark-mode .sd-breadcrumb{color:#A0AEC0}
body.dark-mode .sd-breadcrumb a{color:#60A5FA}
body.dark-mode .sd-breadcrumb [aria-current]{color:#E2E8F0}

.sd-header{text-align:left;padding-bottom:80px}
.sd-header-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;margin-top:24px}
.sd-header-grid h1{font-size:2.6rem;line-height:1.15;margin-bottom:14px}
.sd-header-grid p{font-size:1.1rem;color:var(--text-light);max-width:560px;margin-bottom:24px}
body.dark-mode .sd-header-grid p{color:#A0AEC0}
.sd-category-pill{display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:14px}
.sd-cta-row{display:flex;gap:14px;flex-wrap:wrap}

.sd-quick-card{background:var(--white);border:1px solid var(--grey-dark);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-md)}
.sd-quick-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin:0 0 16px;color:var(--text)}
.sd-quick-list{margin:0}
.sd-quick-list div{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:10px 0;border-bottom:1px dashed var(--grey-dark)}
.sd-quick-list div:last-child{border-bottom:0}
.sd-quick-list dt{font-size:.85rem;color:var(--text-light);font-weight:500;margin:0}
.sd-quick-list dd{margin:0;font-size:.9rem;color:var(--text);font-weight:600;text-align:right}
.sd-quick-list dd a{color:var(--blue)}
body.dark-mode .sd-quick-card{background:#1A2B42;border-color:#2D3748}
body.dark-mode .sd-quick-list dt{color:#A0AEC0}
body.dark-mode .sd-quick-list dd{color:#E2E8F0}
body.dark-mode .sd-quick-list dd a{color:#60A5FA}

.sd-section{padding:72px 0}
.sd-section-alt{background:var(--grey)}
body.dark-mode .sd-section-alt{background:#0A1219}

.sd-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:32px}
.sd-feature{display:flex;gap:14px;background:var(--white);border:1px solid var(--grey-dark);border-radius:var(--radius);padding:20px;transition:transform .2s,box-shadow .2s}
.sd-feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.sd-feature-icon{width:32px;height:32px;border-radius:50%;background:var(--blue-light);color:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700}
.sd-feature h3{font-family:var(--font-display);font-size:1.05rem;margin:0 0 6px;color:var(--text)}
.sd-feature p{font-size:.9rem;color:var(--text-light);margin:0;line-height:1.55}
body.dark-mode .sd-feature{background:#1A2B42;border-color:#2D3748}
body.dark-mode .sd-feature-icon{background:#1E3A8A;color:#60A5FA}
body.dark-mode .sd-feature h3{color:#E2E8F0}
body.dark-mode .sd-feature p{color:#A0AEC0}

.sd-two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.sd-doc-list{list-style:none;padding:0;margin:24px 0}
.sd-doc-list li{position:relative;padding:10px 0 10px 32px;border-bottom:1px solid var(--grey-dark);font-size:.95rem;color:var(--text)}
.sd-doc-list li::before{content:'📄';position:absolute;left:0;top:10px}
body.dark-mode .sd-doc-list li{border-bottom-color:#2D3748;color:#E2E8F0}
.sd-note{margin-top:24px;padding:14px 18px;background:var(--orange-light);border-left:3px solid var(--orange);border-radius:6px;font-size:.9rem;color:var(--text)}
body.dark-mode .sd-note{background:#3D2817;color:#E2E8F0}

.sd-steps{display:flex;flex-direction:column;gap:18px;margin-top:24px}
.sd-step{display:flex;gap:18px;align-items:flex-start}
.sd-step-num{width:36px;height:36px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}
.sd-step h3{margin:0 0 4px;font-family:var(--font-display);font-size:1.05rem;color:var(--text)}
.sd-step p{margin:0;font-size:.92rem;color:var(--text-light);line-height:1.55}
body.dark-mode .sd-step h3{color:#E2E8F0}
body.dark-mode .sd-step p{color:#A0AEC0}

.sd-faq-list{max-width:840px;margin:32px auto 0}

.sd-cta-block{padding:72px 0;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);color:#fff;text-align:center}
.sd-cta-block h2{font-family:var(--font-display);font-size:2rem;margin-bottom:12px;color:#fff}
.sd-cta-block p{opacity:.85;margin-bottom:28px;font-size:1.05rem}
.sd-cta-block .btn-outline{color:#fff;border-color:rgba(255,255,255,.5)}
.sd-cta-block .btn-outline:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-lg{padding:14px 32px;font-size:1.05rem}

.sd-related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:32px}
.sd-related-card{display:flex;align-items:center;gap:12px;background:var(--white);border:1px solid var(--grey-dark);border-radius:var(--radius);padding:18px;color:var(--text);text-decoration:none;font-weight:600;transition:all .2s}
.sd-related-card:hover{transform:translateY(-2px);border-color:var(--blue);box-shadow:var(--shadow-md)}
.sd-related-card span:nth-child(2){flex:1}
.sd-related-icon{font-size:1.5rem}
.sd-related-card svg{color:var(--blue);transition:transform .2s}
.sd-related-card:hover svg{transform:translateX(4px)}
body.dark-mode .sd-related-card{background:#1A2B42;border-color:#2D3748;color:#E2E8F0}
body.dark-mode .sd-related-card svg{color:#60A5FA}




/* === Content Protection ================================================= */
/* Disable text selection site-wide (allow in form inputs) */
body {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
input, textarea, select, [contenteditable] {
  -webkit-user-select: text;
  -moz-user-select: text;
  user-select: text;
}
img {
  pointer-events: none;
  -webkit-user-drag: none;
  user-drag: none;
}
