/* ==========================================================================
   YouDoDigitals — White & Blue Theme
   Primary: #0A66C2 | Accent: #3B82F6 | BG: #FFFFFF / #F8FAFC
   ========================================================================== */

:root {
    --primary:        #0A66C2;
    --primary-dark:   #084D91;
    --primary-light:  #3B82F6;
    --primary-10:     rgba(10,102,194,0.08);
    --primary-20:     rgba(10,102,194,0.15);
    --primary-glow:   rgba(10,102,194,0.25);

    --accent:         #3B82F6;
    --accent-10:      rgba(59,130,246,0.1);
    --accent-20:      rgba(59,130,246,0.18);

    --success:        #10B981;
    --warning:        #F59E0B;
    --error:          #EF4444;

    /* Backgrounds */
    --bg:             #FFFFFF;
    --bg-soft:        #F8FAFC;
    --bg-blue:        #EFF6FF;
    --bg-card:        #FFFFFF;

    /* Text */
    --text:           #1E293B;
    --text-2:         #475569;
    --text-3:         #64748B;
    --text-4:         #94A3B8;

    /* Borders */
    --border:         #E2E8F0;
    --border-blue:    rgba(10,102,194,0.2);

    /* Glassmorphism — light version */
    --glass-bg:       rgba(255,255,255,0.75);
    --glass-border:   rgba(10,102,194,0.15);
    --glass-blur:     blur(20px);
    --glass-shadow:   0 8px 32px rgba(10,102,194,0.1);

    --font-head:      'Poppins', sans-serif;
    --font-body:      'Inter', sans-serif;

    --r-sm:  0.375rem;
    --r-md:  0.5rem;
    --r-lg:  0.75rem;
    --r-xl:  1rem;
    --r-2xl: 1.5rem;
    --r-3xl: 2rem;
    --r-full:9999px;

    --transition: 300ms ease;
    --fast:      150ms ease;

    --shadow-sm:  0 1px 2px rgba(0,0,0,0.05);
    --shadow-md:  0 4px 16px rgba(10,102,194,0.1);
    --shadow-lg:  0 10px 40px rgba(10,102,194,0.15);
    --shadow-xl:  0 20px 60px rgba(10,102,194,0.2);
    --shadow-glow:0 0 30px rgba(10,102,194,0.25),0 0 60px rgba(10,102,194,0.1);

    --container: 1280px;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
body{font-family:var(--font-body);font-size:1rem;line-height:1.6;color:var(--text);background:var(--bg);overflow-x:hidden;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;transition:color var(--transition);}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
input,textarea,select{font-family:inherit;font-size:inherit;}
ul,ol{list-style:none;}

/* ── Content layer above canvas ── */
.content-layer{position:relative;z-index:10;}

/* ── Container ── */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 1.5rem;}
@media(min-width:1024px){.container{padding:0 2rem;}}

/* ── Typography ── */
.font-heading{font-family:var(--font-head);}
.font-body{font-family:var(--font-body);}
.font-light{font-weight:300;}.font-normal{font-weight:400;}.font-medium{font-weight:500;}
.font-semibold{font-weight:600;}.font-bold{font-weight:700;}.font-extrabold{font-weight:800;}
.text-xs{font-size:.75rem;}.text-sm{font-size:.875rem;}.text-base{font-size:1rem;}
.text-lg{font-size:1.125rem;}.text-xl{font-size:1.25rem;}.text-2xl{font-size:1.5rem;}
.text-3xl{font-size:1.875rem;}.text-4xl{font-size:2.25rem;}.text-5xl{font-size:3rem;}
.text-6xl{font-size:3.75rem;}.text-7xl{font-size:4.5rem;}

/* Text colours — DARK on white bg */
.text-white{color:#FFFFFF;}
.text-dark{color:var(--text);}
.text-primary{color:var(--primary);}
.text-primary-light{color:var(--primary-light);}
.text-accent{color:var(--accent);}
.text-secondary{color:var(--text-2);}
.text-muted{color:var(--text-3);}
.text-success{color:var(--success);}
/* Legacy dark-theme helpers remapped */
.text-white-70{color:var(--text-2);}
.text-white-60{color:var(--text-2);}
.text-white-50{color:var(--text-3);}
.text-white-40{color:var(--text-4);}

.leading-tight{line-height:1.25;}.leading-snug{line-height:1.375;}
.leading-normal{line-height:1.6;}.leading-relaxed{line-height:1.75;}
.text-left{text-align:left;}.text-center{text-align:center;}.text-right{text-align:right;}

/* ── Gradient text (blue on white) ── */
.gradient-text{
    background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 60%,var(--accent) 100%);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.text-glow{filter:drop-shadow(0 0 12px rgba(10,102,194,.4));}

/* ── Layout ── */
.block{display:block;}.inline-block{display:inline-block;}.inline{display:inline;}
.flex{display:flex;}.inline-flex{display:inline-flex;}.grid{display:grid;}.hidden{display:none;}
.relative{position:relative;}.absolute{position:absolute;}.fixed{position:fixed;}.sticky{position:sticky;}
.z-0{z-index:0;}.z-10{z-index:10;}.z-50{z-index:50;}
.overflow-hidden{overflow:hidden;}.overflow-x-hidden{overflow-x:hidden;}
.flex-col{flex-direction:column;}.flex-wrap{flex-wrap:wrap;}
.items-start{align-items:flex-start;}.items-center{align-items:center;}.items-end{align-items:flex-end;}
.justify-start{justify-content:flex-start;}.justify-center{justify-content:center;}
.justify-end{justify-content:flex-end;}.justify-between{justify-content:space-between;}
.flex-shrink-0{flex-shrink:0;}.flex-1{flex:1 1 0%;}
.gap-1{gap:.25rem;}.gap-2{gap:.5rem;}.gap-3{gap:.75rem;}.gap-4{gap:1rem;}
.gap-6{gap:1.5rem;}.gap-8{gap:2rem;}.gap-12{gap:3rem;}.gap-16{gap:4rem;}
.grid-cols-2{grid-template-columns:repeat(2,1fr);}
.grid-cols-3{grid-template-columns:repeat(3,1fr);}
.grid-cols-4{grid-template-columns:repeat(4,1fr);}
.m-0{margin:0;}.m-auto{margin:auto;}.mx-auto{margin-left:auto;margin-right:auto;}
.mt-2{margin-top:.5rem;}.mt-4{margin-top:1rem;}.mt-6{margin-top:1.5rem;}.mt-8{margin-top:2rem;}
.mt-10{margin-top:2.5rem;}.mt-12{margin-top:3rem;}.mt-16{margin-top:4rem;}.mt-20{margin-top:5rem;}
.mb-1{margin-bottom:.25rem;}.mb-2{margin-bottom:.5rem;}.mb-3{margin-bottom:.75rem;}
.mb-4{margin-bottom:1rem;}.mb-6{margin-bottom:1.5rem;}.mb-8{margin-bottom:2rem;}
.mb-10{margin-bottom:2.5rem;}.mb-12{margin-bottom:3rem;}.mb-16{margin-bottom:4rem;}
.ml-2{margin-left:.5rem;}.ml-3{margin-left:.75rem;}.mr-3{margin-right:.75rem;}
.p-2{padding:.5rem;}.p-3{padding:.75rem;}.p-4{padding:1rem;}.p-6{padding:1.5rem;}
.p-8{padding:2rem;}.p-10{padding:2.5rem;}.p-12{padding:3rem;}
.px-3{padding-left:.75rem;padding-right:.75rem;}.px-4{padding-left:1rem;padding-right:1rem;}
.px-6{padding-left:1.5rem;padding-right:1.5rem;}.px-8{padding-left:2rem;padding-right:2rem;}
.px-10{padding-left:2.5rem;padding-right:2.5rem;}
.py-2{padding-top:.5rem;padding-bottom:.5rem;}.py-3{padding-top:.75rem;padding-bottom:.75rem;}
.py-4{padding-top:1rem;padding-bottom:1rem;}.py-5{padding-top:1.25rem;padding-bottom:1.25rem;}
.py-6{padding-top:1.5rem;padding-bottom:1.5rem;}
.pt-2{padding-top:.5rem;}.pt-4{padding-top:1rem;}.pt-6{padding-top:1.5rem;}
.pt-8{padding-top:2rem;}.pt-12{padding-top:3rem;}.pt-20{padding-top:5rem;}.pt-24{padding-top:6rem;}
.pb-6{padding-bottom:1.5rem;}.pb-8{padding-bottom:2rem;}.pb-24{padding-bottom:6rem;}
.w-full{width:100%;}.w-screen{width:100vw;}.h-full{height:100%;}.h-screen{height:100vh;}
.min-h-screen{min-height:100vh;}
.w-1{width:.25rem;}.w-5{width:1.25rem;}.w-6{width:1.5rem;}.w-8{width:2rem;}
.w-10{width:2.5rem;}.w-12{width:3rem;}.w-14{width:3.5rem;}.w-16{width:4rem;}
.w-20{width:5rem;}.w-24{width:6rem;}.w-32{width:8rem;}
.h-1{height:.25rem;}.h-3{height:.75rem;}.h-5{height:1.25rem;}.h-6{height:1.5rem;}
.h-8{height:2rem;}.h-10{height:2.5rem;}.h-12{height:3rem;}.h-14{height:3.5rem;}
.h-16{height:4rem;}.h-20{height:5rem;}.h-40{height:10rem;}.h-56{height:14rem;}.h-64{height:16rem;}
.max-w-xs{max-width:20rem;}.max-w-xl{max-width:36rem;}.max-w-2xl{max-width:42rem;}
.max-w-5xl{max-width:64rem;}.max-w-7xl{max-width:80rem;}

/* ── Glassmorphism — light ── */
.glass{
    background:var(--glass-bg);
    backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    border:1px solid var(--glass-border);
}
.glass-card{
    background:rgba(255,255,255,0.85);
    backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    border:1px solid var(--glass-border);
    box-shadow:var(--glass-shadow);
}
.glass-dark{
    background:rgba(10,102,194,0.08);
    backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    border:1px solid var(--border-blue);
}
.glass-border{border:1px solid var(--glass-border);}
.glass-border-light{border:1px solid rgba(10,102,194,.1);}

/* ── Borders ── */
.border{border:1px solid var(--border);}
.border-t{border-top:1px solid var(--border);}
.border-b{border-bottom:1px solid var(--border);}
.border-white-10{border-color:rgba(255,255,255,.1);}
.border-white-20{border-color:rgba(255,255,255,.2);}
.border-primary-30{border-color:rgba(10,102,194,.3);}
.rounded-sm{border-radius:var(--r-sm);}.rounded-md{border-radius:var(--r-md);}
.rounded-lg{border-radius:var(--r-lg);}.rounded-xl{border-radius:var(--r-xl);}
.rounded-2xl{border-radius:var(--r-2xl);}.rounded-3xl{border-radius:var(--r-3xl);}
.rounded-full{border-radius:var(--r-full);}

/* ── Backgrounds ── */
.bg-transparent{background:transparent;}
.bg-white{background:#FFFFFF;}
.bg-white-5{background:rgba(255,255,255,.05);}
.bg-white-10{background:rgba(255,255,255,.1);}
.bg-white-20{background:rgba(255,255,255,.2);}
.bg-primary{background:var(--primary);}
.bg-primary-20{background:var(--primary-20);}
.bg-accent-20{background:var(--accent-20);}
.bg-green-500-20{background:rgba(16,185,129,.15);}
.bg-purple-500-20{background:rgba(139,92,246,.15);}
.bg-soft{background:var(--bg-soft);}
.bg-blue-light{background:var(--bg-blue);}

.bg-gradient-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));}
.bg-gradient-primary-accent{background:linear-gradient(135deg,var(--primary),var(--accent));}
.bg-gradient-primary-light{background:linear-gradient(135deg,var(--primary-light),var(--accent));}
.bg-gradient-blue-cyan{background:linear-gradient(135deg,var(--primary),var(--accent));}
.bg-gradient-purple-pink{background:linear-gradient(135deg,#8B5CF6,#EC4899);}
.bg-gradient-green-emerald{background:linear-gradient(135deg,#10B981,#059669);}
.bg-gradient-cyan-blue{background:linear-gradient(135deg,#06B6D4,#3B82F6);}
.bg-gradient-emerald-teal{background:linear-gradient(135deg,#10B981,#14B8A6);}
.bg-gradient-red-rose{background:linear-gradient(135deg,#EF4444,#F43F5E);}
.bg-gradient-blue-purple{background:linear-gradient(135deg,#3B82F6,#8B5CF6);}
.bg-gradient-green-cyan{background:linear-gradient(135deg,#22C55E,#06B6D4);}
.bg-gradient-amber-orange{background:linear-gradient(135deg,#F59E0B,#F97316);}
/* Legacy dark helpers that need mapping for white bg */
.bg-gradient-primary-light{background:linear-gradient(135deg,var(--primary-light),var(--accent));}

/* ── Glow ── */
.glow-primary{box-shadow:var(--shadow-glow);}
.glow-accent{box-shadow:0 0 30px rgba(59,130,246,.3);}

/* ── Buttons ── */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
    padding:.75rem 1.5rem;font-family:var(--font-head);font-weight:600;
    font-size:.875rem;border-radius:var(--r-full);transition:all var(--transition);cursor:pointer;border:none;
}
.btn-primary{
    background:linear-gradient(135deg,var(--primary),var(--primary-dark));
    color:#FFFFFF;box-shadow:var(--shadow-md);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);}
.btn-secondary{
    background:#FFFFFF;color:var(--primary);
    border:1.5px solid var(--primary);
}
.btn-secondary:hover{background:var(--primary-10);}
.btn-glow{position:relative;overflow:hidden;}
.btn-glow::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s;}
.btn-glow:hover::before{left:100%;}
.btn-lg{padding:1rem 2rem;font-size:1.125rem;}
.btn-xl{padding:1.25rem 2.5rem;font-size:1.25rem;}

/* ── Hover ── */
.hover-lift{transition:transform var(--transition),box-shadow var(--transition);}
.hover-lift:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);}
.hover-scale:hover{transform:scale(1.05);}
.hover-scale-110:hover{transform:scale(1.1);}
.hover-glow:hover{box-shadow:var(--shadow-glow);}
.hover-bg-white-10:hover{background:rgba(255,255,255,.1);}
.hover-text-accent:hover{color:var(--accent);}
.hover-opacity-100:hover{opacity:1;}
.hover-translate-x:hover .hover-icon{transform:translateX(4px);}

/* ── Forms ── */
.form-input{
    width:100%;padding:.75rem 1rem;border-radius:var(--r-xl);
    background:#FFFFFF;border:1.5px solid var(--border);
    color:var(--text);transition:all var(--transition);
}
.form-input::placeholder{color:var(--text-4);}
.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-10);}
.form-label{display:block;color:var(--text-2);font-size:.875rem;margin-bottom:.5rem;}
.form-textarea{resize:none;}
.form-select{appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%230A66C2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 1rem center;background-size:1.5rem;}

/* ── Animations ── */
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-20px);}}
@keyframes pulse-slow{0%,100%{opacity:1;}50%{opacity:.5;}}
@keyframes bounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-25%);}}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.5;}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes glow-pulse{0%,100%{box-shadow:0 0 20px var(--primary-glow);}50%{box-shadow:0 0 40px var(--primary-glow),0 0 80px rgba(10,102,194,.15);}}
.animate-float{animation:float 6s ease-in-out infinite;}
.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite;}
.animate-pulse-slow{animation:pulse-slow 4s cubic-bezier(.4,0,.6,1) infinite;}
.animate-bounce{animation:bounce 1s infinite;}
.animate-glow{animation:glow-pulse 2s ease-in-out infinite;}
.delay-100{animation-delay:100ms;}.delay-200{animation-delay:200ms;}
.delay-300{animation-delay:300ms;}.delay-500{animation-delay:500ms;}
.delay-1000{animation-delay:1000ms;}.delay-2000{animation-delay:2000ms;}
.delay-4000{animation-delay:4000ms;}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:8px;}
::-webkit-scrollbar-track{background:var(--bg-soft);}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--primary),var(--accent));border-radius:4px;}

/* ════════════════════════════════════════════
   NAVBAR
   ════════════════════════════════════════════ */
.navbar{
    position:fixed;top:0;left:0;width:100%;z-index:50;
    transition:all var(--transition);
    /* Always visible on white bg */
    background:rgba(255,255,255,0.92);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border);
}
.navbar-scrolled{
    background:rgba(255,255,255,0.97);
    box-shadow:0 4px 24px rgba(10,102,194,.08);
}
.navbar-container{display:flex;align-items:center;justify-content:space-between;height:5rem;}
.nav-logo{display:flex;align-items:center;gap:.5rem;}
.nav-logo-icon{
    width:2.5rem;height:2.5rem;border-radius:var(--r-xl);
    background:linear-gradient(135deg,var(--primary),var(--accent));
    display:flex;align-items:center;justify-content:center;
    font-family:var(--font-head);font-weight:700;font-size:1.25rem;color:#FFFFFF;
    transition:transform var(--transition);
}
.nav-logo:hover .nav-logo-icon{transform:scale(1.1);}
.nav-logo-text{font-family:var(--font-head);font-weight:700;font-size:1.25rem;color:var(--text);transition:color var(--transition);}
.nav-logo:hover .nav-logo-text{color:var(--primary);}
.nav-logo-accent{color:var(--primary);}
.nav-links{display:flex;align-items:center;gap:.25rem;}
.nav-link{
    padding:.5rem 1rem;border-radius:var(--r-lg);font-size:.875rem;font-weight:500;
    color:var(--text-2);transition:all var(--transition);
}
.nav-link:hover{color:var(--primary);background:var(--primary-10);}
.nav-cta{
    display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;
    border-radius:var(--r-full);
    background:linear-gradient(135deg,var(--primary),var(--primary-light));
    color:#FFFFFF;font-weight:600;font-size:.875rem;
    box-shadow:0 4px 16px rgba(10,102,194,.3);transition:all var(--transition);
}
.nav-cta:hover{box-shadow:0 6px 24px rgba(10,102,194,.45);transform:translateY(-1px);}
.nav-cta-icon{transition:transform var(--transition);}
.nav-cta:hover .nav-cta-icon{transform:translateX(4px);}
.mobile-menu-btn{display:flex;padding:.5rem;border-radius:var(--r-lg);color:var(--text-2);transition:all var(--transition);}
.mobile-menu-btn:hover{color:var(--primary);background:var(--primary-10);}
.mobile-menu{display:none;position:absolute;top:100%;left:0;width:100%;
    background:rgba(255,255,255,.97);backdrop-filter:blur(20px);
    border-top:1px solid var(--border);border-bottom:1px solid var(--border);
    box-shadow:var(--shadow-lg);}
.mobile-menu.active{display:block;}
.mobile-menu-link{display:block;padding:.75rem 1rem;border-radius:var(--r-lg);
    font-size:1rem;font-weight:500;color:var(--text-2);transition:all var(--transition);}
.mobile-menu-link:hover{color:var(--primary);background:var(--primary-10);}
.mobile-menu-cta{display:block;width:100%;text-align:center;padding:.75rem 1.5rem;
    border-radius:var(--r-full);
    background:linear-gradient(135deg,var(--primary),var(--primary-light));
    color:#FFFFFF;font-weight:600;}

/* ════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════ */
.hero{ position:relative;min-height:100vh;display:flex;align-items:center;padding-top:5rem;overflow:hidden;}
.hero-bg-gradient{
    position:absolute;inset:0;
    /* background:linear-gradient(160deg,#EFF6FF 0%,#FFFFFF 40%,#F0F9FF 100%); */
    z-index:0;
}
.hero-container{position:relative;z-index:10;width:100%;}
.hero-grid{display:grid;gap:3rem;align-items:center;}
@media(min-width:1024px){.hero-grid{grid-template-columns:1fr 1fr;}}
.hero-content{text-align:center;}
@media(min-width:1024px){.hero-content{text-align:left;}}

.hero-badge{
    display:inline-flex;align-items:center;gap:.5rem;padding:.375rem 1rem;
    border-radius:var(--r-full);
    background:var(--primary-10);border:1px solid var(--border-blue);margin-bottom:1.5rem;
}
.hero-badge-dot{width:.5rem;height:.5rem;border-radius:50%;background:var(--success);animation:pulse 2s infinite;}
.hero-badge-text{font-size:.875rem;font-weight:500;color:var(--primary);}

.hero-title{font-family:var(--font-head);font-weight:700;font-size:2.25rem;line-height:1.15;
    margin-bottom:1.5rem;color:var(--text);}
@media(min-width:640px){.hero-title{font-size:3rem;}}
@media(min-width:1024px){.hero-title{font-size:3.75rem;}}
@media(min-width:1280px){.hero-title{font-size:4.5rem;}}

.hero-subtitle{font-size:1.125rem;color:var(--text-2);margin-bottom:2rem;max-width:36rem;margin-left:auto;margin-right:auto;}
@media(min-width:1024px){.hero-subtitle{margin-left:0;margin-right:0;}}

.hero-buttons{display:flex;flex-direction:column;gap:1rem;justify-content:center;}
@media(min-width:640px){.hero-buttons{flex-direction:row;}}
@media(min-width:1024px){.hero-buttons{justify-content:flex-start;}}

.hero-trust{margin-top:2.5rem;display:flex;align-items:center;justify-content:center;gap:2rem;}
@media(min-width:1024px){.hero-trust{justify-content:flex-start;}}
.hero-avatars{display:flex;}
.hero-avatar{width:2.5rem;height:2.5rem;border-radius:50%;border:2px solid #FFFFFF;margin-left:-.75rem;}
.hero-avatar:first-child{margin-left:0;}
.hero-trust-text{text-align:left;}

.hero-visual{display:none;position:relative;}
@media(min-width:1024px){.hero-visual{display:block;}}
.hero-visual-glow{
    position:absolute;inset:-1rem;
    background:radial-gradient(ellipse,rgba(59,130,246,.2) 0%,transparent 70%);
    border-radius:var(--r-3xl);animation:pulse-slow 4s infinite;
}
.hero-dashboard{
    position:relative;background:rgba(255,255,255,.9);
    backdrop-filter:blur(20px);border-radius:var(--r-3xl);
    padding:1.5rem;border:1px solid var(--border);
    box-shadow:var(--shadow-xl);animation:float 6s ease-in-out infinite;
}
.hero-dashboard-inner{
    background:linear-gradient(135deg,#EFF6FF 0%,#DBEAFE 100%);
    border-radius:var(--r-2xl);padding:1.5rem;
}
/* Fix text inside dashboard */
.hero-dashboard-inner .text-white{color:var(--text) !important;}
.hero-dashboard-inner .text-white-50{color:var(--text-3) !important;}
.hero-dashboard-inner .text-accent{color:var(--accent) !important;}
.hero-dashboard-inner .text-primary-light{color:var(--primary) !important;}
.hero-dashboard-inner p.text-white{color:var(--text) !important;}
.hero-dashboard-inner p.font-semibold{color:var(--text) !important;}
.hero-dashboard-inner p.text-sm{color:var(--text-3) !important;}
/* chart bars */
.hero-dashboard-inner .bg-primary-20{background:rgba(10,102,194,.25) !important;}
.hero-dashboard-inner .bg-accent-20{background:rgba(59,130,246,.35) !important;}
.hero-dashboard-inner .bg-white-5{background:rgba(255,255,255,.7) !important;}

.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:none;flex-direction:column;align-items:center;}
@media(min-width:1024px){.hero-scroll{display:flex;}}
.hero-scroll-text{font-size:.875rem;color:var(--text-3);margin-bottom:.5rem;}
.hero-scroll-indicator{width:1.5rem;height:2.5rem;border-radius:var(--r-full);border:2px solid var(--border);display:flex;justify-content:center;padding-top:.5rem;}
.hero-scroll-dot{width:.25rem;height:.75rem;border-radius:var(--r-full);background:var(--primary);animation:bounce 1s infinite;}

/* Floating cards on hero */
.hero-dashboard .glass-card{background:rgba(255,255,255,.92);}
.hero-dashboard .text-white{color:var(--text);}
.hero-dashboard .text-white-60{color:var(--text-3);}

/* ════════════════════════════════════════════
   SECTION HEADER
   ════════════════════════════════════════════ */
.section-header{text-align:center;margin-bottom:4rem;}
.section-label{
    display:inline-flex;align-items:center;gap:.5rem;padding:.375rem 1rem;
    border-radius:var(--r-full);background:var(--primary-10);
    border:1px solid var(--border-blue);margin-bottom:1.5rem;
}
.section-label-text{font-size:.875rem;font-weight:500;color:var(--primary);}
.section-title{font-family:var(--font-head);font-weight:700;font-size:2.25rem;color:var(--text);margin-bottom:1rem;}
@media(min-width:640px){.section-title{font-size:3rem;}}
.section-description{font-size:1.125rem;color:var(--text-2);max-width:42rem;margin:0 auto;}

/* ════════════════════════════════════════════
   CARDS (all sections)
   ════════════════════════════════════════════ */
.card{
    background:#FFFFFF;border:1px solid var(--border);
    border-radius:var(--r-2xl);padding:2rem;transition:all var(--transition);
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.card-icon{width:4rem;height:4rem;border-radius:var(--r-2xl);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;transition:transform var(--transition);}
.card:hover .card-icon{transform:scale(1.1);}
.card-title{font-family:var(--font-head);font-weight:600;font-size:1.25rem;color:var(--text);margin-bottom:.75rem;transition:color var(--transition);}
.card:hover .card-title{color:var(--primary);}
.card-description{color:var(--text-2);margin-bottom:1rem;}
.card-link{display:flex;align-items:center;gap:.5rem;color:var(--primary);font-size:.875rem;font-weight:500;opacity:0;transition:opacity var(--transition);}
.card:hover .card-link{opacity:1;}

/* Service Card */
.service-card{
    position:relative;background:#FFFFFF;border:1px solid var(--border);
    border-radius:var(--r-2xl);overflow:hidden;transition:all var(--transition);
}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.service-card-bar{position:absolute;top:0;left:0;width:100%;height:4px;}
.service-card-content{padding:2rem;}
.service-card-icon{width:3.5rem;height:3.5rem;border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;transition:all var(--transition);}
.service-card:hover .service-card-icon{transform:scale(1.1);}
.service-card-title{font-family:var(--font-head);font-weight:600;font-size:1.25rem;color:var(--text);margin-bottom:.75rem;}
.service-card-description{color:var(--text-2);margin-bottom:1.5rem;}

/* Project Card */
.project-card{position:relative;border-radius:var(--r-2xl);overflow:hidden;transition:all var(--transition);background:#FFFFFF;border:1px solid var(--border);}
.project-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.project-card-image{position:relative;height:14rem;overflow:hidden;}
.project-card-overlay{position:absolute;inset:0;background:rgba(10,102,194,.8);opacity:0;display:flex;align-items:center;justify-content:center;transition:opacity var(--transition);}
.project-card:hover .project-card-overlay{opacity:1;}
.project-card-content{padding:1.5rem;background:#FFFFFF;}
.project-card-tags{display:flex;gap:.5rem;margin-bottom:.75rem;}
.project-card-tag{padding:.25rem .75rem;border-radius:var(--r-full);font-size:.75rem;font-weight:500;background:var(--primary-10);color:var(--primary);}

/* Testimonial Card */
.testimonial-card{
    background:#FFFFFF;border:1px solid var(--border);border-radius:var(--r-2xl);
    padding:2rem;position:relative;transition:all var(--transition);
}
.testimonial-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.testimonial-card-quote{position:absolute;top:1.5rem;right:1.5rem;color:var(--accent-20);}
.testimonial-card-rating{display:flex;gap:.25rem;margin-bottom:1.5rem;}
.testimonial-card-text{color:var(--text-2);font-size:1.125rem;line-height:1.75;margin-bottom:2rem;}
.testimonial-card-author{display:flex;align-items:center;gap:1rem;}
.testimonial-card-avatar{width:3.5rem;height:3.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;color:#FFFFFF;}

/* Team Card */
.team-card{border-radius:var(--r-2xl);overflow:hidden;transition:all var(--transition);background:#FFFFFF;border:1px solid var(--border);}
.team-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.team-card-avatar-section{position:relative;height:16rem;display:flex;align-items:center;justify-content:center;}
.team-card-avatar{width:8rem;height:8rem;border-radius:50%;background:rgba(255,255,255,.2);backdrop-filter:blur(10px);border:4px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;}
.team-card-social{position:absolute;inset:0;background:rgba(10,102,194,.7);opacity:0;display:flex;align-items:center;justify-content:center;gap:1rem;transition:opacity var(--transition);}
.team-card:hover .team-card-social{opacity:1;}
.team-card-social-link{width:2.5rem;height:2.5rem;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;transition:background var(--transition);}
.team-card-social-link:hover{background:var(--accent);}
.team-card-info{padding:1.5rem;text-align:center;background:#FFFFFF;border-top:1px solid var(--border);}

/* ════════════════════════════════════════════
   STATS SECTION
   ════════════════════════════════════════════ */
/* Override dark text in stats */
#stats .text-white{color:var(--text) !important;}
#stats .text-white-60{color:var(--text-2) !important;}
#stats .text-white-50{color:var(--text-2) !important;}
#stats .text-5xl.font-bold{color:var(--text) !important;}
#stats .text-4xl.font-bold{color:var(--text) !important;}
#stats .text-accent{color:var(--accent) !important;}
#stats .glass-card{background:rgba(255,255,255,.85) !important;border:1px solid var(--border) !important;}

/* ════════════════════════════════════════════
   SERVICES SECTION
   ════════════════════════════════════════════ */
#services .section-title{color:var(--text);}
#services .section-description{color:var(--text-2);}

/* ════════════════════════════════════════════
   ABOUT / WHY-CHOOSE / TEAM / TESTIMONIALS
   ════════════════════════════════════════════ */
#about .text-white{color:var(--text) !important;}
#about .text-white-70{color:var(--text-2) !important;}
#about .text-white-60{color:var(--text-2) !important;}
#about .text-white-50{color:var(--text-3) !important;}
#why-choose-us .text-white{color:var(--text) !important;}
#why-choose-us .text-white-60{color:var(--text-2) !important;}
#team .text-white{color:var(--text) !important;}
#team .text-white-60{color:var(--text-2) !important;}
#testimonials .text-white{color:var(--text) !important;}
#testimonials .text-white-60{color:var(--text-2) !important;}

/* Global override — any leftover white text on white bg */
.content-layer .text-white{color:var(--text);}
/* But keep white text inside coloured elements */
.content-layer .bg-gradient-primary .text-white,
.content-layer .bg-gradient-primary-accent .text-white,
.content-layer [class*="bg-gradient"] .text-white,
.content-layer .nav-cta .text-white,
.content-layer .btn-primary,
.content-layer .testimonial-card-avatar .text-white,
.content-layer .team-card-avatar .text-white,
.content-layer .hero-dashboard-inner .text-white-specific,
.nav-cta{color:#FFFFFF !important;}

/* Safe overrides for explicitly white text inside blue/dark containers */
.bg-gradient-primary *,
.bg-gradient-primary-accent *,
[style*="background: linear-gradient(135deg, var(--color-primary)"] *{color:inherit;}

/* ════════════════════════════════════════════
   CONTACT
   ════════════════════════════════════════════ */
.contact-info-card{
    background:#FFFFFF;border:1px solid var(--border);border-radius:var(--r-xl);
    padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all var(--transition);
}
.contact-info-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.contact-info-icon{width:3.5rem;height:3.5rem;border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-form{
    background:#FFFFFF;border:1px solid var(--border);border-radius:var(--r-2xl);padding:2rem;
    box-shadow:var(--shadow-md);
}
@media(min-width:768px){.contact-form{padding:2.5rem;}}
#contact .text-white{color:var(--text) !important;}
#contact .text-white-60{color:var(--text-2) !important;}

/* ════════════════════════════════════════════
   CTA SECTION
   ════════════════════════════════════════════ */
.cta-section{position:relative;padding:6rem 0;overflow:hidden;}
.cta-bg-gradient{
    position:absolute;inset:0;
    background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 50%,#0A3A82 100%);
}
.cta-bg-pattern{position:absolute;inset:0;
    background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    opacity:.4;}
.cta-content{position:relative;z-index:10;text-align:center;}
/* CTA text must be white (on dark blue bg) */
.cta-content *{color:#FFFFFF !important;}
.cta-content .gradient-text{background:linear-gradient(135deg,#FFFFFF,#BAE6FD);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.cta-content .btn-secondary{color:var(--primary) !important;background:#FFFFFF !important;}
.cta-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:3rem;}
.cta-trust-item{display:flex;align-items:center;gap:.5rem;}

/* ════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════ */
.footer{position:relative;padding-top:5rem;padding-bottom:2rem;overflow:hidden;background:var(--bg-soft);border-top:1px solid var(--border);}
.footer-bg{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,102,194,.04),transparent);}
.footer-content{position:relative;z-index:10;}
.footer-card{
    background:#FFFFFF;border:1px solid var(--border);border-radius:var(--r-3xl);
    padding:3rem;margin-bottom:3rem;box-shadow:var(--shadow-sm);
}
.footer-grid{display:grid;gap:3rem;}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1024px){.footer-grid{grid-template-columns:repeat(4,1fr);}}
.footer-social{display:flex;gap:.75rem;}
.footer-social-link{width:2.5rem;height:2.5rem;border-radius:var(--r-xl);background:var(--primary-10);display:flex;align-items:center;justify-content:center;transition:all var(--transition);}
.footer-social-link:hover{background:var(--primary);color:#FFFFFF;}
.footer-links{display:flex;flex-direction:column;gap:.75rem;}
.footer-link{color:var(--text-3);transition:color var(--transition);}
.footer-link:hover{color:var(--primary);}
.footer-contact-item{display:flex;align-items:flex-start;gap:.75rem;}
.footer-bottom{display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:1rem;padding-top:2rem;border-top:1px solid var(--border);}
@media(min-width:768px){.footer-bottom{flex-direction:row;}}
.footer-bottom-links{display:flex;gap:1.5rem;}
.footer-bottom-link{font-size:.875rem;color:var(--text-4);transition:color var(--transition);}
.footer-bottom-link:hover{color:var(--primary);}
/* Footer text visibility */
.footer .text-white{color:var(--text) !important;}
.footer .text-white-70{color:var(--text-2) !important;}
.footer .text-white-60{color:var(--text-2) !important;}
.footer .text-white-50{color:var(--text-3) !important;}
.footer .text-white-40{color:var(--text-4) !important;}
.footer .text-muted{color:var(--text-3);}

/* ════════════════════════════════════════════
   FLASH MESSAGES
   ════════════════════════════════════════════ */
.flash-message{position:fixed;top:6rem;left:50%;transform:translateX(-50%);z-index:50;padding:1rem 1.5rem;border-radius:var(--r-xl);display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-lg);}
.flash-success{background:var(--success);color:#FFFFFF;}
.flash-error{background:var(--error);color:#FFFFFF;}

/* ════════════════════════════════════════════
   TRUST LOGOS
   ════════════════════════════════════════════ */
.trust-logo{background:#FFFFFF;border:1px solid var(--border);border-radius:var(--r-xl);padding:1rem 1.5rem;opacity:.7;transition:opacity var(--transition);}
.trust-logo:hover{opacity:1;}

/* ════════════════════════════════════════════
   BG GLOW EFFECTS
   ════════════════════════════════════════════ */
.bg-glow-primary{position:absolute;width:24rem;height:24rem;background:rgba(10,102,194,.06);border-radius:50%;filter:blur(64px);}
.bg-glow-accent{position:absolute;width:24rem;height:24rem;background:rgba(59,130,246,.06);border-radius:50%;filter:blur(64px);}

/* ════════════════════════════════════════════
   UTILITIES
   ════════════════════════════════════════════ */
.pointer-events-none{pointer-events:none;}.cursor-pointer{cursor:pointer;}
.opacity-0{opacity:0;}.opacity-30{opacity:.3;}.opacity-50{opacity:.5;}.opacity-60{opacity:.6;}.opacity-80{opacity:.8;}
.transform{transform:translateX(-50%);}
.list-disc{list-style-type:disc;}.list-inside{list-style-position:inside;}
.space-y-1>*+*{margin-top:.25rem;}.space-y-3>*+*{margin-top:.75rem;}
.space-y-4>*+*{margin-top:1rem;}.space-y-6>*+*{margin-top:1.5rem;}

/* ════════════════════════════════════════════
   SECTION SPACING
   ════════════════════════════════════════════ */
section{position:relative;padding:6rem 0;}
section#hero{padding-top:0;}

/* ════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════ */
@media(min-width:768px){
    .md-block{display:block;}.md-flex{display:flex;}.md-hidden{display:none;}
    .md-grid-cols-2{grid-template-columns:repeat(2,1fr);}
    .md-grid-cols-3{grid-template-columns:repeat(3,1fr);}
    .md-flex-row{flex-direction:row;}.md-text-left{text-align:left;}
    .md-p-16{padding:4rem;}.md-pt-12{padding-top:3rem;}
    .md-border-t{border-top:1px solid var(--border);}
}
@media(min-width:1024px){
    .lg-block{display:block;}.lg-hidden{display:none;}
    .lg-grid-cols-2{grid-template-columns:repeat(2,1fr);}
    .lg-grid-cols-3{grid-template-columns:repeat(3,1fr);}
    .lg-grid-cols-4{grid-template-columns:repeat(4,1fr);}
    .lg-text-left{text-align:left;}.lg-justify-start{justify-content:flex-start;}
    .lg-col-span-1{grid-column:span 1;}
}
@media(min-width:768px){.md-hidden{display:none !important;}}
@media(max-width:767px){.md-flex{display:none !important;}}
