:root{
  --brand1:#1682b0;
  --brand2:#0a4d6b;
  --brand-light:#5cb3d9;
  --brand-pale:#e8f4f9;
  --accent:#f59e0b;
  --dark:#0a2540;
  --darker:#061828;
  --light:#f8fafc;
  --white:#fff;
  --slate:#64748b;
  --slate-dark:#334155;
  --border:#e2e8f0;
  --shadow-sm:0 2px 8px rgba(10,37,64,.06);
  --shadow:0 8px 30px rgba(10,37,64,.1);
  --shadow-lg:0 20px 60px rgba(10,37,64,.18);
  --radius:12px;
  --radius-lg:18px;
  --grad:linear-gradient(135deg,var(--brand1),var(--brand2));
  --grad-dark:linear-gradient(135deg,var(--brand2),var(--dark));
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--slate-dark);background:var(--white);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;font-size:15px}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color .2s}
h1,h2,h3,h4,h5,.serif{font-family:'Playfair Display',Georgia,serif;color:var(--dark);line-height:1.2;font-weight:700}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:8px;font-weight:600;font-size:14px;transition:all .25s;border:none;cursor:pointer;font-family:inherit;white-space:nowrap;line-height:1.2}
.btn-primary{background:var(--grad);color:var(--white);box-shadow:0 4px 14px rgba(22,130,176,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(22,130,176,.45);color:var(--white)}
.btn-outline{background:transparent;border:2px solid rgba(255,255,255,.4);color:var(--white)}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:var(--white);color:var(--white)}
.btn-light{background:var(--white);color:var(--brand1)}
.btn-light:hover{background:var(--brand-pale);color:var(--brand2)}
.btn-dark{background:var(--dark);color:var(--white)}
.btn-dark:hover{background:var(--brand2);color:var(--white)}
.btn-gold{background:var(--accent);color:var(--dark)}
.btn-gold:hover{background:#fbbf24;color:var(--dark)}

/* Top bar */
.topbar{background:var(--grad-dark);color:rgba(255,255,255,.85);font-size:13px;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.topbar a{color:rgba(255,255,255,.85)}
.topbar a:hover{color:var(--brand-light)}
.topbar-info{display:flex;gap:22px;flex-wrap:wrap}
.topbar-info span{display:inline-flex;align-items:center;gap:6px}
.topbar-info i{color:var(--brand-light);font-size:12px}
.topbar-social{display:flex;gap:14px}

/* Navbar */
.navbar{background:var(--white);box-shadow:0 1px 0 var(--border);position:sticky;top:0;z-index:1000;transition:box-shadow .3s}
.navbar.scrolled{box-shadow:var(--shadow-sm)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:24px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand-logo{width:46px;height:46px;background:var(--grad);border-radius:10px;display:grid;place-items:center;color:var(--white);font-family:'Playfair Display',serif;font-size:16px;font-weight:700;letter-spacing:.5px}
.brand-text .name{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--dark);line-height:1.1}
.brand-text .sub{font-size:10.5px;color:var(--brand1);font-weight:600;letter-spacing:1.2px;text-transform:uppercase;margin-top:2px}
.nav-menu{display:flex;align-items:center;gap:6px;list-style:none}
.nav-menu>li>a{font-size:14.5px;font-weight:500;color:var(--slate-dark);padding:8px 14px;border-radius:6px;display:inline-block}
.nav-menu>li>a:hover,.nav-menu>li>a.active{color:var(--brand1)}
.has-dropdown{position:relative}
.has-dropdown>a::after{content:'\f107';font-family:'Font Awesome 6 Free';font-weight:900;font-size:11px;margin-left:5px;opacity:.6}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;background:var(--white);min-width:280px;border-radius:12px;box-shadow:var(--shadow-lg);padding:10px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s;border:1px solid var(--border)}
.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:13.5px;color:var(--slate-dark)}
.dropdown a:hover{background:var(--brand-pale);color:var(--brand1)}
.dropdown a i{width:18px;color:var(--brand1)}
.btn-nav{background:var(--grad)!important;color:var(--white)!important;padding:10px 22px!important;border-radius:8px!important;font-weight:600!important;margin-left:8px;display:inline-flex!important;align-items:center;gap:6px}
.btn-nav:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(22,130,176,.4);color:var(--white)!important}
.menu-toggle{display:none;background:none;border:none;font-size:22px;color:var(--dark);cursor:pointer;padding:6px}

/* Hero (homepage) */
.hero{background:linear-gradient(135deg,var(--brand2) 0%,var(--brand1) 60%,var(--dark) 100%);color:var(--white);padding:90px 0 100px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-30%;right:-15%;width:700px;height:700px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);border-radius:50%;animation:floatBlob 20s ease-in-out infinite}
.hero::after{content:'';position:absolute;bottom:-30%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(245,158,11,.08) 0%,transparent 70%);border-radius:50%;animation:floatBlob 25s ease-in-out infinite reverse}
@keyframes floatBlob{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-30px) scale(1.1)}}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);color:var(--white);font-size:12px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;padding:8px 18px;border-radius:50px;margin-bottom:24px}
.hero-tag i{color:var(--accent)}
.hero h1{font-size:clamp(34px,5vw,58px);color:var(--white);margin-bottom:22px;letter-spacing:-.5px}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--accent),#fcd34d);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}
.hero-desc{font-size:17px;color:rgba(255,255,255,.82);margin-bottom:32px;max-width:540px;line-height:1.7}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:520px}
.hero-stat{position:relative;padding-left:18px;border-left:3px solid var(--accent)}
.hero-stat .num{font-family:'Playfair Display',serif;font-size:34px;font-weight:700;color:var(--white);line-height:1}
.hero-stat .lbl{font-size:12px;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.8px;margin-top:6px;font-weight:500}
.hero-visual{position:relative}
.hero-img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:20px;box-shadow:var(--shadow-lg)}
.hero-card{position:absolute;background:var(--white);color:var(--dark);padding:18px 22px;border-radius:14px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:14px}
.hero-card.c1{bottom:30px;left:-20px;animation:float 4s ease-in-out infinite}
.hero-card.c2{top:30px;right:-20px;animation:float 4s ease-in-out infinite .5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hero-card .ico{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;font-size:18px;flex-shrink:0}
.hero-card.c1 .ico{background:#dcfce7;color:#16a34a}
.hero-card.c2 .ico{background:var(--brand-pale);color:var(--brand1)}
.hero-card .t{font-size:13px;font-weight:700;color:var(--dark);line-height:1.3}
.hero-card .s{font-size:11px;color:var(--slate);font-weight:500}

/* Page hero (sub-pages) */
.page-hero{background:linear-gradient(135deg,var(--brand2),var(--brand1),var(--dark));color:var(--white);padding:80px 0 90px;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'><circle cx='40' cy='40' r='1' fill='%23ffffff' opacity='0.15'/></svg>");opacity:.4}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:var(--white);font-size:clamp(30px,4.5vw,52px);margin-bottom:14px;letter-spacing:-.5px}
.page-hero h1 i{color:var(--accent);margin-right:14px}
.page-hero p{color:rgba(255,255,255,.85);font-size:17px;max-width:680px;margin:0 auto;line-height:1.7}
.crumb{display:inline-flex;align-items:center;gap:8px;list-style:none;margin-bottom:20px;font-size:13px}
.crumb li{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.7)}
.crumb li:not(:last-child)::after{content:'/';color:rgba(255,255,255,.4);margin-left:4px}
.crumb a{color:var(--accent)}
.crumb a:hover{color:var(--white)}

/* Section */
.section{padding:90px 0}
.section-tag{display:inline-block;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--brand1);margin-bottom:14px;position:relative;padding-left:42px}
.section-tag::before{content:'';position:absolute;left:0;top:50%;width:32px;height:2px;background:var(--grad);transform:translateY(-50%)}
.section-title{font-size:clamp(26px,3.5vw,42px);margin-bottom:18px;letter-spacing:-.5px}
.section-desc{color:var(--slate);font-size:16.5px;line-height:1.75;max-width:680px}
.text-center{text-align:center}
.text-center .section-tag{padding-left:0}
.text-center .section-tag::before{display:none}
.section-head{text-align:center;max-width:740px;margin:0 auto 50px}
.section-head .section-desc{margin:0 auto}

/* Animation utilities */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-l{transform:translateX(-30px)}
.reveal-l.visible{transform:translateX(0)}
.reveal-r{transform:translateX(30px)}
.reveal-r.visible{transform:translateX(0)}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}
.reveal[data-delay="4"]{transition-delay:.4s}
.reveal[data-delay="5"]{transition-delay:.5s}

/* About preview */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center}
.about-img-wrap{position:relative}
.about-img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:20px}
.about-deco{position:absolute;top:-20px;left:-20px;width:60%;height:60%;border:3px solid var(--brand1);border-radius:20px;z-index:-1}
.about-badge{position:absolute;bottom:24px;right:-20px;background:var(--grad);color:var(--white);padding:18px 24px;border-radius:14px;box-shadow:var(--shadow-lg);text-align:center;min-width:160px}
.about-badge .n{font-family:'Playfair Display',serif;font-size:32px;font-weight:700;line-height:1}
.about-badge .l{font-size:12px;font-weight:500;margin-top:4px;opacity:.9}
.creds{list-style:none;margin-top:24px;display:grid;gap:12px}
.creds li{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--light);border-radius:10px;border-left:3px solid var(--brand1);font-size:14.5px;color:var(--slate-dark);font-weight:500}
.creds li i{color:var(--brand1);font-size:16px;flex-shrink:0;width:20px}

/* Services */
.services-bg{background:linear-gradient(180deg,var(--light) 0%,#fff 100%)}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:26px}
.svc-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:34px 28px;text-decoration:none;color:inherit;position:relative;overflow:hidden;transition:all .35s;display:flex;flex-direction:column}
.svc-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.svc-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc-card:hover::before{transform:scaleX(1)}
.svc-icon{width:60px;height:60px;border-radius:14px;background:var(--grad);color:var(--white);display:grid;place-items:center;font-size:24px;margin-bottom:22px;transition:transform .35s}
.svc-card:hover .svc-icon{transform:rotate(-6deg) scale(1.05)}
.svc-card h3{font-size:20px;margin-bottom:12px;color:var(--dark)}
.svc-card p{font-size:14.5px;color:var(--slate);line-height:1.7;margin-bottom:18px;flex:1}
.svc-link{display:inline-flex;align-items:center;gap:8px;color:var(--brand1);font-weight:600;font-size:14px;transition:gap .25s}
.svc-card:hover .svc-link{gap:12px}

/* Service big card with image */
.svc-big{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:all .35s;text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}
.svc-big:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc-big-img{position:relative;aspect-ratio:5/3;overflow:hidden}
.svc-big-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.svc-big:hover .svc-big-img img{transform:scale(1.06)}
.svc-big-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,37,64,.6),transparent 50%)}
.svc-big-icon{position:absolute;bottom:16px;left:18px;width:50px;height:50px;background:var(--grad);color:var(--white);border-radius:12px;display:grid;place-items:center;font-size:20px;z-index:2;box-shadow:var(--shadow)}
.svc-big-body{padding:26px;display:flex;flex-direction:column;flex:1}
.svc-big-body h3{font-size:20px;margin-bottom:10px;color:var(--dark)}
.svc-big-body p{font-size:14px;color:var(--slate);line-height:1.65;margin-bottom:16px;flex:1}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.tag{font-size:11.5px;background:var(--brand-pale);color:var(--brand1);padding:5px 11px;border-radius:50px;font-weight:600}

/* Stats band */
.stats-band{background:var(--grad-dark);color:var(--white);padding:70px 0;position:relative;overflow:hidden}
.stats-band::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><path d='M0 30L30 0L60 30L30 60Z' fill='none' stroke='%23ffffff' stroke-width='0.5' opacity='0.05'/></svg>");opacity:.5}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px;position:relative;z-index:2}
.stat-item{text-align:center}
.stat-item .num{font-family:'Playfair Display',serif;font-size:48px;font-weight:700;background:linear-gradient(135deg,var(--brand-light),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;line-height:1}
.stat-item .lbl{font-size:14px;color:rgba(255,255,255,.8);margin-top:8px;text-transform:uppercase;letter-spacing:1px;font-weight:500}

/* Why us */
.why-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.why-list{display:grid;gap:18px;margin-top:32px}
.why-item{display:flex;gap:18px;padding:22px;background:var(--white);border-radius:14px;border:1px solid var(--border);transition:all .3s}
.why-item:hover{border-color:transparent;box-shadow:var(--shadow);transform:translateX(6px)}
.why-icon{width:54px;height:54px;border-radius:12px;background:linear-gradient(135deg,var(--brand-pale),#fff);color:var(--brand1);display:grid;place-items:center;font-size:22px;flex-shrink:0;border:1px solid var(--border)}
.why-item h4{font-size:16.5px;margin-bottom:6px;color:var(--dark);font-family:'Inter',sans-serif;font-weight:600}
.why-item p{font-size:14px;color:var(--slate);line-height:1.65}
.why-img{width:100%;aspect-ratio:5/6;object-fit:cover;border-radius:20px;box-shadow:var(--shadow-lg)}

/* Reviews */
.reviews-bg{background:linear-gradient(180deg,#fff,var(--light))}
.rev-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:26px}
.rev-card{background:var(--white);border-radius:var(--radius-lg);padding:32px 28px;border:1px solid var(--border);position:relative;transition:all .3s}
.rev-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.rev-quote{position:absolute;top:24px;right:28px;font-size:50px;color:var(--brand-pale);font-family:Georgia,serif;line-height:.8}
.rev-stars{color:#f59e0b;margin-bottom:14px;font-size:14px;letter-spacing:2px}
.rev-text{font-size:14.5px;color:var(--slate-dark);line-height:1.75;margin-bottom:22px;font-style:italic;position:relative;z-index:2}
.rev-author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--border)}
.rev-avatar{width:46px;height:46px;border-radius:50%;background:var(--grad);color:var(--white);display:grid;place-items:center;font-size:18px;font-weight:700;font-family:'Playfair Display',serif;flex-shrink:0}
.rev-name{font-weight:600;font-size:14.5px;color:var(--dark)}
.rev-role{font-size:12.5px;color:var(--slate);margin-top:2px}

/* CTA */
.cta-band{background:var(--grad);color:var(--white);padding:70px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before,.cta-band::after{content:'';position:absolute;border-radius:50%}
.cta-band::before{top:-50%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.cta-band::after{bottom:-50%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(245,158,11,.1),transparent 70%)}
.cta-band .container{position:relative;z-index:2}
.cta-band h2{color:var(--white);font-size:clamp(26px,3.5vw,40px);margin-bottom:14px}
.cta-band p{font-size:17px;opacity:.92;margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}

/* Service detail page */
.svc-detail{display:grid;grid-template-columns:1fr 360px;gap:50px;align-items:flex-start}
.svc-banner{width:100%;aspect-ratio:21/9;object-fit:cover;border-radius:var(--radius-lg);margin-bottom:30px}
.svc-intro{font-size:16px;color:var(--slate-dark);line-height:1.8;margin-bottom:30px}
.group{margin-top:34px}
.group-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--dark);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.group-title i{width:42px;height:42px;background:var(--grad);color:var(--white);border-radius:10px;display:grid;place-items:center;font-size:18px}
.checks{list-style:none;display:grid;gap:8px}
.checks li{padding:12px 16px;background:var(--light);border-radius:10px;font-size:14.5px;color:var(--slate-dark);display:flex;align-items:flex-start;gap:12px;transition:all .25s;border-left:3px solid transparent}
.checks li:hover{background:var(--brand-pale);border-left-color:var(--brand1);transform:translateX(4px)}
.checks li::before{content:'\f00c';font-family:'Font Awesome 6 Free';font-weight:900;color:var(--brand1);flex-shrink:0;margin-top:2px}
.tax-badges{display:flex;flex-wrap:wrap;gap:8px;margin:20px 0 30px}
.tax-badge{display:inline-flex;align-items:center;gap:6px;background:var(--grad);color:var(--white);padding:8px 16px;border-radius:50px;font-size:12.5px;font-weight:600}
.tax-badge i{font-size:10px}
.steps{display:grid;gap:14px;margin-top:8px}
.step{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:22px;display:flex;gap:18px;transition:all .3s}
.step:hover{border-color:transparent;box-shadow:var(--shadow);transform:translateX(6px)}
.step-num{width:46px;height:46px;background:var(--grad);color:var(--white);border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:17px;flex-shrink:0;font-family:'Playfair Display',serif}
.step-c h5{font-size:16px;margin-bottom:6px;color:var(--dark);font-family:'Inter',sans-serif;font-weight:600}
.step-c p{font-size:14px;color:var(--slate);line-height:1.65}

/* Sidebar */
.sidebar{display:grid;gap:22px;position:sticky;top:90px}
.side-card{border-radius:var(--radius-lg);padding:28px;border:1px solid var(--border);background:var(--white)}
.side-card.dark{background:var(--grad-dark);color:var(--white);border-color:transparent}
.side-card h4{font-size:19px;margin-bottom:14px;font-family:'Playfair Display',serif}
.side-card.dark h4{color:var(--white)}
.side-card.dark p{color:rgba(255,255,255,.8);font-size:14px;line-height:1.65;margin-bottom:18px}
.side-card .btn{width:100%;justify-content:center}
.side-list{list-style:none;display:grid;gap:2px}
.side-list a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:8px;font-size:13.5px;color:rgba(255,255,255,.78);border-left:3px solid transparent;transition:all .25s}
.side-list a:hover{background:rgba(255,255,255,.06);color:var(--white);border-left-color:var(--accent)}
.side-list i{color:var(--brand-light);width:18px}
.qc{display:grid;gap:10px;margin-top:6px}
.qc a{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--slate-dark)}
.qc a:hover{color:var(--brand1)}
.qc i{color:var(--brand1);width:18px}

/* Founder profile */
.founder-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:center}
.founder-img-wrap{position:relative}
.founder-img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:20px;box-shadow:var(--shadow-lg)}
.founder-yrs{position:absolute;bottom:24px;left:24px;background:var(--accent);color:var(--dark);padding:14px 22px;border-radius:12px;box-shadow:var(--shadow)}
.founder-yrs .n{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;line-height:1}
.founder-yrs .l{font-size:11px;font-weight:600;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.founder-content p{font-size:16px;color:var(--slate-dark);line-height:1.85;margin-bottom:18px}
.cred-pills{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0}
.cred-pill{display:inline-flex;align-items:center;gap:8px;background:var(--white);border:1px solid var(--border);color:var(--dark);padding:8px 16px;border-radius:50px;font-size:13px;font-weight:600;transition:all .25s}
.cred-pill:hover{border-color:var(--brand1);color:var(--brand1)}
.cred-pill i{color:var(--brand1)}
.expertise-box{background:var(--light);border-radius:14px;padding:24px;border-left:4px solid var(--brand1)}
.expertise-box h5{font-size:16px;margin-bottom:14px;color:var(--dark);font-family:'Inter',sans-serif;font-weight:600}
.exp-list{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.exp-list li{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--slate-dark)}
.exp-list li i{color:var(--brand1);width:18px}

/* Vision/mission */
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.vm-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;transition:all .35s;position:relative;overflow:hidden}
.vm-card::before{content:'';position:absolute;top:0;left:0;width:6px;height:100%;background:var(--grad);transform:scaleY(0);transform-origin:top;transition:transform .4s}
.vm-card:hover::before{transform:scaleY(1)}
.vm-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.vm-icon{width:60px;height:60px;border-radius:14px;background:var(--brand-pale);color:var(--brand1);display:grid;place-items:center;font-size:24px;margin-bottom:22px}
.vm-card h3{font-size:24px;margin-bottom:14px;color:var(--dark)}
.vm-card p{font-size:15.5px;color:var(--slate-dark);line-height:1.85;font-style:italic}

/* Contact page */
.contact-grid{display:grid;grid-template-columns:5fr 7fr;gap:50px;align-items:flex-start}
.contact-info{display:grid;gap:22px;margin-top:30px}
.ci-item{display:flex;gap:16px;padding:20px;background:var(--white);border:1px solid var(--border);border-radius:14px;transition:all .3s}
.ci-item:hover{border-color:transparent;box-shadow:var(--shadow);transform:translateX(4px)}
.ci-icon{width:48px;height:48px;border-radius:12px;background:var(--grad);color:var(--white);display:grid;place-items:center;font-size:18px;flex-shrink:0}
.ci-l{font-size:11.5px;text-transform:uppercase;letter-spacing:1.2px;font-weight:700;color:var(--slate);margin-bottom:4px}
.ci-v{font-size:15px;font-weight:600;color:var(--dark)}
.ci-v a{color:var(--dark)}
.ci-v a:hover{color:var(--brand1)}
.wa-card{margin-top:8px;display:flex;align-items:center;gap:14px;background:#25d366;color:#fff;padding:16px 22px;border-radius:14px;font-weight:700;font-size:15px;transition:all .25s;box-shadow:0 6px 16px rgba(37,211,102,.3)}
.wa-card:hover{background:#1ebe5c;color:#fff;transform:translateY(-2px);box-shadow:0 10px 24px rgba(37,211,102,.4)}
.wa-card i{font-size:24px}
.contact-form{background:var(--white);border-radius:var(--radius-lg);padding:38px;box-shadow:var(--shadow);border:1px solid var(--border)}
.contact-form h3{font-size:24px;margin-bottom:8px}
.contact-form>p{color:var(--slate);font-size:14.5px;margin-bottom:26px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--dark);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;border:1px solid var(--border);border-radius:8px;font-size:14px;padding:12px 14px;background:var(--light);color:var(--dark);font-family:inherit;transition:all .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--brand1);box-shadow:0 0 0 3px rgba(22,130,176,.15);background:var(--white)}
.form-group textarea{resize:vertical;min-height:120px}
.form-submit{width:100%;background:var(--grad);color:var(--white);border:none;padding:14px;border-radius:8px;font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;transition:all .25s;display:flex;align-items:center;justify-content:center;gap:8px}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(22,130,176,.4)}

/* Footer */
.footer{background:linear-gradient(135deg,var(--darker),var(--dark));color:rgba(255,255,255,.65);padding:70px 0 24px;position:relative}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:46px;margin-bottom:46px}
.footer h5{color:var(--white);font-family:'Playfair Display',serif;font-size:18px;margin-bottom:20px;font-weight:600}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.footer-brand .name{color:var(--white);font-family:'Playfair Display',serif;font-size:17px;font-weight:700;line-height:1.1}
.footer-brand .sub{font-size:10.5px;color:var(--brand-light);font-weight:600;letter-spacing:1.2px;text-transform:uppercase;margin-top:2px}
.footer p{font-size:14px;line-height:1.75}
.footer ul{list-style:none}
.footer ul li{margin-bottom:10px}
.footer ul a{font-size:14px;color:rgba(255,255,255,.65);transition:all .2s;display:inline-block}
.footer ul a:hover{color:var(--brand-light);transform:translateX(4px)}
.footer-contact{display:flex;flex-direction:column;gap:12px}
.footer-contact a,.footer-contact span{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:rgba(255,255,255,.7)}
.footer-contact a:hover{color:var(--brand-light)}
.footer-contact i{color:var(--brand-light);margin-top:4px;width:16px;flex-shrink:0}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:38px;height:38px;background:rgba(255,255,255,.06);border-radius:10px;display:grid;place-items:center;color:rgba(255,255,255,.7);transition:all .25s;border:1px solid rgba(255,255,255,.08)}
.socials a:hover{background:var(--grad);color:var(--white);transform:translateY(-3px);border-color:transparent}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:13px;color:rgba(255,255,255,.5)}

/* WhatsApp float */
.wa-float{position:fixed;bottom:24px;right:24px;width:58px;height:58px;background:#25d366;color:#fff;border-radius:50%;display:grid;place-items:center;font-size:28px;box-shadow:0 8px 24px rgba(37,211,102,.5);z-index:998;transition:transform .3s;animation:pulse 2s infinite}
.wa-float:hover{transform:scale(1.1);color:#fff}
@keyframes pulse{0%,100%{box-shadow:0 8px 24px rgba(37,211,102,.5)}50%{box-shadow:0 8px 30px rgba(37,211,102,.8),0 0 0 12px rgba(37,211,102,.15)}}

/* RESPONSIVE */
@media (max-width:992px){
  .hero-grid,.about-grid,.why-grid,.founder-grid,.vm-grid,.contact-grid,.svc-detail{grid-template-columns:1fr;gap:40px}
  .hero{padding:60px 0 80px}
  .hero-visual{order:-1;max-width:380px;margin:0 auto}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .menu-toggle{display:block}
  .nav-menu{position:fixed;top:0;right:-100%;width:85%;max-width:340px;height:100vh;background:var(--white);flex-direction:column;align-items:stretch;padding:90px 24px 24px;box-shadow:-10px 0 40px rgba(0,0,0,.1);transition:right .35s;gap:0;overflow-y:auto}
  .nav-menu.open{right:0}
  .nav-menu>li>a{padding:14px 16px;border-radius:8px;width:100%}
  .has-dropdown>a::after{float:right}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:4px 0 4px 14px;background:var(--light);margin-top:6px;border-radius:8px;display:none;min-width:0;width:100%}
  .has-dropdown.active .dropdown{display:block}
  .btn-nav{width:100%;justify-content:center;margin:14px 0 0}
  .nav-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;opacity:0;visibility:hidden;transition:all .3s}
  .nav-overlay.show{opacity:1;visibility:visible}
  .sidebar{position:static}
  .exp-list{grid-template-columns:1fr}
}
@media (max-width:768px){
  .section{padding:60px 0}
  .page-hero{padding:55px 0 65px}
  .hero{padding:40px 0 60px}
  .hero-stats{grid-template-columns:repeat(3,1fr);gap:14px}
  .hero-stat{padding-left:12px}
  .hero-stat .num{font-size:26px}
  .hero-card{display:none}
  .topbar-info{font-size:12px;gap:14px}
  .topbar-social{display:none}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-bottom{flex-direction:column;text-align:center}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .about-deco,.about-badge{display:none}
  .why-item{padding:18px}
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:26px}
  .group-title{font-size:19px}
  .group-title i{width:38px;height:38px;font-size:16px}
}
@media (max-width:480px){
  .hero h1{font-size:30px}
  .hero-cta{flex-direction:column;width:100%}
  .hero-cta .btn{width:100%;justify-content:center}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-item .num{font-size:38px}
  .topbar .container{justify-content:center}
  .topbar-info{justify-content:center}
}
@media print{
  .topbar,.navbar,.footer,.cta-band,.wa-float,.menu-toggle{display:none}
}

/* ============================================
   PAGE-SPECIFIC EXTENSIONS (added for redesign)
   ============================================ */

/* Page hero blobs (animated background) */
.ph-blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.25;animation:floatBlob 14s ease-in-out infinite;pointer-events:none;z-index:1}
.ph-blob-1{width:340px;height:340px;background:var(--brand-light);top:-80px;left:-80px}
.ph-blob-2{width:380px;height:380px;background:var(--accent);bottom:-120px;right:-100px;animation-delay:-7s}
@keyframes floatBlob{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-30px) scale(1.1)}}

/* Crumb (inline span pattern) */
.crumb{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}
.crumb a{color:var(--accent);font-weight:500}
.crumb a:hover{color:var(--white)}
.crumb i{font-size:10px;color:rgba(255,255,255,.5)}
.crumb span{color:rgba(255,255,255,.85);font-weight:500}

/* Founder profile - wrapper div pattern */
.founder-img{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.founder-img>img{width:100%;height:100%;object-fit:cover;display:block}
.founder-yrs strong{display:block;font-family:'Playfair Display',serif;font-size:24px;font-weight:700;line-height:1}
.founder-yrs span{display:block;font-size:11px;font-weight:600;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.founder-content h3{font-family:'Playfair Display',serif;font-size:32px;font-weight:700;color:var(--dark);margin-bottom:6px}
.founder-title{color:var(--brand1);font-weight:600;font-size:15px;margin-bottom:20px;letter-spacing:.3px}
.expertise-box h4{font-size:16px;margin-bottom:14px;color:var(--dark);font-family:'Inter',sans-serif;font-weight:600;display:flex;align-items:center;gap:8px}
.expertise-box h4 i{color:var(--accent)}

/* Services grid (big cards) */
.svc-grid-big{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:30px}

/* Service banner - wrapper div pattern */
.svc-banner{width:100%;aspect-ratio:21/9;border-radius:var(--radius-lg);margin-bottom:30px;overflow:hidden}
.svc-banner img{width:100%;height:100%;object-fit:cover;display:block}

/* svc-main - left column wrapper (just behaves as grid item) */
.svc-main{min-width:0}

/* Disable check::before pseudo when inline icon present */
.checks li>i:first-child{color:var(--brand1);flex-shrink:0;margin-top:2px;font-size:15px}
.checks li>i:first-child~*{flex:1}
.checks li:has(>i:first-child)::before{display:none}
@supports not selector(:has(*)){
  .checks li::before{display:none}
}

/* Side card extras */
.side-cta{display:flex;align-items:center;gap:10px;padding:12px 14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:10px;color:var(--white);font-weight:600;font-size:14px;margin-bottom:10px;transition:all .25s}
.side-cta:hover{background:rgba(255,255,255,.14);color:var(--white);transform:translateX(4px)}
.side-cta.light{background:rgba(255,255,255,.04)}
.side-cta i{color:var(--brand-light);width:18px;text-align:center}

/* Stats (alt class names) */
.stat{text-align:center;position:relative;z-index:2}
.stat-num{font-family:'Playfair Display',serif;font-size:48px;font-weight:700;background:linear-gradient(135deg,var(--brand-light),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;line-height:1}
.stat-lbl{font-size:14px;color:rgba(255,255,255,.8);margin-top:8px;text-transform:uppercase;letter-spacing:1px;font-weight:500}

/* Why-us alt structure (when used as multi-card grid like services page) */
.section .why-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:stretch}
.why-item.reveal{flex-direction:column;align-items:flex-start;text-align:left}
.why-item h3{font-size:17px;margin-bottom:8px;color:var(--dark);font-family:'Inter',sans-serif;font-weight:600}
.why-item .why-icon{margin-bottom:14px}

/* Contact info head section */
.ci-head{margin-bottom:8px}
.ci-head h2{font-family:'Playfair Display',serif;font-size:30px;color:var(--dark);margin-bottom:10px;line-height:1.2}
.ci-head p{color:var(--slate-dark);font-size:15px;line-height:1.7}

/* Contact info items - alternative structure with h4 + a + p */
.ci-item h4{font-size:13px;text-transform:uppercase;letter-spacing:1.2px;font-weight:700;color:var(--slate);margin-bottom:6px}
.ci-item a:not(.btn){font-size:16px;font-weight:600;color:var(--dark);display:block;margin-bottom:4px}
.ci-item a:not(.btn):hover{color:var(--brand1)}
.ci-item address{font-size:16px;font-weight:600;color:var(--dark);font-style:normal;margin-bottom:4px}
.ci-item p{font-size:13px;color:var(--slate);line-height:1.5;margin:0}
.wa-card>div{flex:1}
.wa-card strong{display:block;font-size:15px;margin-bottom:2px}
.wa-card span{display:block;font-size:12.5px;font-weight:400;opacity:.92}
.wa-card>i:last-child{font-size:16px;margin-left:auto}

/* Contact form wrap (pass-through) */
.contact-form-wrap{position:relative}

/* Form fields (alt naming) */
.form-field{margin-bottom:16px}
.form-field label{display:block;font-size:13px;font-weight:600;color:var(--dark);margin-bottom:6px}
.form-field input,.form-field select,.form-field textarea{width:100%;border:1px solid var(--border);border-radius:8px;font-size:14px;padding:12px 14px;background:var(--light);color:var(--dark);font-family:inherit;transition:all .2s}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--brand1);box-shadow:0 0 0 3px rgba(22,130,176,.15);background:var(--white)}
.form-field textarea{resize:vertical;min-height:120px}
.form-row .form-field{margin-bottom:0}
.form-sub{color:var(--slate);font-size:14.5px;margin-bottom:26px}
.form-note{margin-top:14px;font-size:12.5px;color:var(--slate);display:flex;align-items:center;justify-content:center;gap:6px}
.form-note i{color:var(--brand1)}

/* Buttons - primary & block */
.btn-primary{background:var(--grad);color:var(--white);border:none}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(22,130,176,.4);color:var(--white)}
.btn-block{width:100%;justify-content:center}
button.btn{cursor:pointer;font-family:inherit}
button.btn:disabled{opacity:.7;cursor:not-allowed}

/* Active parent indicator (subtle nav state) */
.active-parent>a{color:var(--brand1)}

/* Responsive overrides */
@media (max-width:992px){
  .ci-item{padding:18px}
  .ci-icon{width:42px;height:42px;font-size:16px}
}
@media (max-width:768px){
  .founder-content h3{font-size:26px}
  .vm-grid{grid-template-columns:1fr}
  .svc-grid-big{grid-template-columns:1fr}
  .ph-blob-1{width:240px;height:240px}
  .ph-blob-2{width:260px;height:260px}
}

/* Side-list inside non-dark cards needs dark text */
.side-card:not(.dark){background:var(--white);border:1px solid var(--border)}
.side-card:not(.dark) h4{color:var(--dark)}
.side-card:not(.dark) .side-list a{color:var(--slate-dark);border-left-color:transparent}
.side-card:not(.dark) .side-list a:hover{background:var(--brand-pale);color:var(--brand1);border-left-color:var(--brand1)}
.side-card:not(.dark) .side-list i{color:var(--brand1)}

/* Visibility helper for reveal animations - ensure smooth fallback */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease-out,transform .7s ease-out}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
.reveal[data-delay="5"]{transition-delay:.4s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .ph-blob{animation:none}
  .wa-float{animation:none}
}
