
:root{
  --navy:#0d2137; --navy2:#162d47;
  --blue:#1e6fbf; --blue2:#2580d8;
  --sky:#f0f7ff;  --sky2:#dbeafe;
  --off:#f8fafc;  --stone:#f1f5f9;
  --border:#e2e8f0;
  --text:#0f172a; --mid:#334155; --muted:#475569;
  --gold:#f59e0b; --green:#22c55e;

  /* radius scale — every rounded corner in the site pulls from here */
  --r-sm:8px; --r:14px; --r-lg:20px; --r-full:100px;

  /* spacing scale — section rhythm stays consistent top to bottom */
  --sp-section:104px; --sp-section-mobile:68px;
  --sp-block:56px; --sp-card:28px;

  /* shadow scale — soft, layered, consistent tint (navy-tinted, not flat black) */
  --shadow-sm:0 2px 8px rgba(13,33,55,.06);
  --shadow-md:0 8px 24px rgba(13,33,55,.10);
  --shadow-lg:0 16px 40px rgba(13,33,55,.14);
  --shadow-xl:0 28px 64px rgba(13,33,55,.20);
  --shadow-blue:0 12px 32px rgba(30,111,191,.22);
  --shadow-blue-lg:0 20px 48px rgba(30,111,191,.28);

  --ease:cubic-bezier(.2,.8,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
      background:#fff;color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;
      -webkit-text-size-adjust:100%;line-height:1.5}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit}



/* ── LAYOUT ─────────────────────────────────── */
.w{max-width:1140px;margin:0 auto;padding:0 40px}
@media(max-width:600px){.w{padding:0 22px}}
.sec{padding:var(--sp-section) 0}

/* ── NAV (white bg → dark text) ─────────────── */
#nav{position:fixed;top:0;left:0;right:0;z-index:800;height:64px;
      background:rgba(255,255,255,.96);backdrop-filter:blur(16px);
      border-bottom:1px solid var(--border);display:flex;align-items:center;
      transition:box-shadow .2s}
#nav.raised{box-shadow:0 2px 16px rgba(13,33,55,.07)}
.nav-in{max-width:1120px;margin:0 auto;padding:0 40px;width:100%;
         display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav-logo{display:flex;align-items:center;gap:11px;cursor:pointer;flex-shrink:0;height:64px}
.nav-logo-text{display:flex;flex-direction:column;gap:1px}.nav-logo-text{display:flex;flex-direction:column;justify-content:center;line-height:1}
.nav-logo-text .n1{font-size:14px;font-weight:800;color:var(--navy);letter-spacing:-.3px;line-height:1.2;display:block;white-space:nowrap}
.nav-logo-text .n2{font-size:9px;font-weight:600;letter-spacing:1.3px;text-transform:uppercase;color:var(--muted);line-height:1.2;display:block;white-space:nowrap;margin-top:1px}
.nav-links{display:flex;list-style:none;gap:2px}
.nav-links a{font-size:12px;font-weight:600;color:var(--muted);padding:8px 12px;
              border-radius:8px;cursor:pointer;display:block;transition:all .15s}
.nav-links a:hover,.nav-links a.on{color:var(--navy);background:var(--stone)}
.nav-r{display:flex;align-items:center;gap:10px}
.nav-tel{font-size:13px;font-weight:700;color:var(--blue);transition:color .15s}
.nav-tel:hover{color:var(--navy)}
.nav-cta{background:var(--navy);color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;
           padding:11px 22px;border-radius:12px;cursor:pointer;transition:all .18s;border:none;white-space:nowrap}
.nav-cta:hover{background:var(--navy2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(13,33,55,.25)}
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:3px}
.hbg span{display:block;width:20px;height:2px;background:var(--navy);border-radius:2px;transition:all .25s}
.hbg.o span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.hbg.o span:nth-child(2){opacity:0}
.hbg.o span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}
.mob-nav{display:none;position:fixed;top:64px;left:0;right:0;z-index:799;
          background:rgba(255,255,255,.98);backdrop-filter:blur(16px);
          border-bottom:1px solid var(--border);padding:8px 16px 20px}
.mob-nav.o{display:block}
.mob-nav a{display:block;padding:12px 14px;font-size:12px;font-weight:600;
            color:var(--muted);border-radius:8px;cursor:pointer;transition:all .15s}
.mob-nav a:hover{color:var(--navy);background:var(--stone)}
.mob-div{height:1px;background:var(--border);margin:6px 0}
.mob-tel{display:block;padding:12px 14px;font-size:18px;font-weight:800;color:var(--blue)}
.mob-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:797;
          background:rgba(255,255,255,.97);backdrop-filter:blur(16px);
          border-top:1px solid var(--border);padding:10px 16px;gap:10px;
          padding-bottom:max(10px,env(safe-area-inset-bottom))}
.mob-bar a,.mob-bar span{flex:1;text-align:center;padding:14px;border-radius:10px;
                           font-size:12px;font-weight:800;cursor:pointer;
                           text-decoration:none;transition:all .15s;
                           display:flex;align-items:center;justify-content:center;gap:6px}
.mbc{background:#fff;color:var(--navy);border:1.5px solid var(--navy)}
.mbc:active{background:var(--stone)}
.mbq{background:var(--navy);color:#fff;border:1.5px solid var(--navy)}
.mbq:active{background:var(--navy2)}

/* ── HERO (photo bg → white text) ─────────────── */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 35%}
.hero-ov{position:absolute;inset:0;
  background:linear-gradient(110deg,rgba(13,33,55,.94) 0%,rgba(13,33,55,.86) 45%,rgba(13,33,55,.55) 100%),
             linear-gradient(to bottom,transparent 45%,rgba(13,33,55,.75) 75%,rgba(13,33,55,.97) 100%)}
.hero-body{position:relative;z-index:1;max-width:1120px;margin:0 auto;
            padding:100px 40px 72px;display:grid;
            grid-template-columns:1fr 400px;gap:60px;align-items:center;width:100%}
.hero-badge{display:inline-flex;align-items:center;gap:8px;
             background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
             backdrop-filter:blur(6px);color:rgba(255,255,255,.85);
             font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
             padding:8px 16px;border-radius:var(--r-full);margin-bottom:24px}
.hero-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0;
           animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-size:clamp(42px,6vw,70px);font-weight:800;line-height:1.02;
          letter-spacing:-2px;color:#fff;margin-bottom:20px}
.hero h1 em{font-style:italic;color:rgba(255,255,255,.58)}
.hero-sub{font-size:17px;font-weight:400;color:rgba(255,255,255,.7);line-height:1.7;
           max-width:440px;margin-bottom:32px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:40px}
.btn-p{background:var(--blue);color:#fff;font-size:13px;font-weight:700;
        padding:15px 28px;border-radius:12px;border:none;cursor:pointer;
        transition:all .2s;box-shadow:0 4px 16px rgba(30,111,191,.4);
        display:inline-flex;align-items:center;gap:8px}
.btn-p:hover{background:var(--blue2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(30,111,191,.45)}
.btn-s{background:rgba(255,255,255,.1);color:#fff;font-size:13px;font-weight:700;
        padding:15px 28px;border-radius:12px;border:1.5px solid rgba(255,255,255,.3);
        cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}
.btn-s:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.14)}
.hero-trust{display:flex;align-items:center;gap:14px;flex-wrap:wrap;
             padding-top:28px;border-top:1px solid rgba(255,255,255,.12)}
.trust-pill{display:flex;align-items:center;gap:7px;
             background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
             border-radius:var(--r-full);padding:7px 14px}
.trust-pill .stars{color:var(--gold);font-size:11px;letter-spacing:1px}
.trust-pill span{font-size:12px;font-weight:600;color:rgba(255,255,255,.85)}
.trust-check{display:flex;align-items:center;gap:6px;
              font-size:12px;font-weight:600;color:rgba(255,255,255,.8)}
.trust-check::before{content:'✓';color:var(--green);font-size:13px;font-weight:800}
.hero-card{position:relative}
.hero-card-img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4;
                box-shadow:0 28px 72px rgba(0,0,0,.45)}
.hero-card-img img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.hero-float-g{position:absolute;bottom:22px;left:-22px;background:#fff;border-radius:var(--r);
               padding:13px 16px;box-shadow:0 8px 32px rgba(0,0,0,.15);
               display:flex;align-items:center;gap:11px;min-width:185px}
.hfg-ico{width:38px;height:38px;border-radius:12px;background:var(--sky2);
           display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.hfg-stars{color:#b45309;font-size:11px;letter-spacing:1.5px}
.hfg-t1{font-size:15px;font-weight:800;color:var(--navy);letter-spacing:-.3px}
.hfg-t2{font-size:10px;color:var(--muted);margin-top:1px}
.hero-float-b{position:absolute;top:22px;right:-16px;background:var(--navy);color:#fff;
               border-radius:var(--r);padding:13px 16px;
               box-shadow:0 8px 28px rgba(13,33,55,.4);text-align:center}
.hfb-n{font-size:24px;font-weight:800;line-height:1;letter-spacing:-1px}
.hfb-l{font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;opacity:.8;margin-top:3px}

/* ── STAT BAR (navy bg → white text)
      Big-number proof strip — scale over icon-grid cliché ── */
.promise{position:relative;overflow:hidden;background:linear-gradient(175deg,var(--navy) 0%,#0a1a2e 100%)}
.promise::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 90% at 10% 0%,rgba(30,111,191,.3),transparent 62%),
             radial-gradient(ellipse 50% 80% at 100% 100%,rgba(30,111,191,.18),transparent 65%);
  pointer-events:none}
.promise-in{max-width:1080px;margin:0 auto;padding:60px 40px;
             display:grid;grid-template-columns:repeat(4,1fr);
             position:relative;z-index:1}
.stat-item{position:relative;text-align:center;padding:0 14px}
.stat-item::before{content:'';position:absolute;left:0;top:4px;bottom:4px;width:1px;
  background:rgba(255,255,255,.14)}
.stat-item:nth-child(4n+1)::before{display:none}
.stat-icon{width:30px;height:30px;margin:0 auto 12px;display:flex;align-items:center;
  justify-content:center;color:rgba(255,255,255,.4)}
.stat-num{font-size:clamp(32px,4vw,44px);font-weight:800;color:#fff;letter-spacing:-1px;
  line-height:1;font-variant-numeric:tabular-nums;white-space:nowrap}
.stat-num .stat-suffix{color:#5aa3e0}
.stat-lbl{margin-top:10px;font-size:12px;font-weight:600;letter-spacing:.3px;color:rgba(255,255,255,.55)}

/* ── TYPE hierarchy ──────────────────────────── */
/* on white/off bg → navy label & heading, muted body */
.lbl{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;
      color:var(--blue);margin-bottom:14px;display:block}
/* on navy bg → use this version */
.lbl-wh{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:14px;display:block}
h2.hed{font-size:clamp(30px,3.9vw,48px);font-weight:800;line-height:1.08;
        letter-spacing:-.6px;color:var(--navy);margin-bottom:18px}
h2.hed.wh{color:#fff}
h3.hed3{font-size:clamp(19px,2.2vw,22px);font-weight:700;line-height:1.25;
         letter-spacing:-.2px;color:var(--navy);margin-bottom:10px}
p.dek{font-size:17px;color:var(--muted);line-height:1.75;max-width:480px;font-weight:400}
p.dek.wh{color:rgba(255,255,255,.72)}

/* ── BUTTONS ───────────────────────────────── */
.btn-navy{background:var(--navy);color:#fff;font-size:12.5px;font-weight:700;padding:14px 28px;
           border-radius:12px;border:none;cursor:pointer;transition:all .28s var(--ease);
           display:inline-flex;align-items:center;gap:8px;letter-spacing:.1px}
.btn-navy:hover{background:var(--navy2);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-navy:active{transform:translateY(0)}
.btn-blue{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;font-size:12.5px;font-weight:700;padding:14px 28px;
           border-radius:12px;border:none;cursor:pointer;transition:all .28s var(--ease);
           display:inline-flex;align-items:center;gap:8px;letter-spacing:.1px}
.btn-blue:hover{transform:translateY(-2px);box-shadow:var(--shadow-blue-lg)}
.btn-blue:active{transform:translateY(0)}
.btn-ghost{background:transparent;color:var(--navy);font-size:12.5px;font-weight:700;padding:14px 28px;
            border-radius:12px;border:1.5px solid var(--border);cursor:pointer;
            transition:all .28s var(--ease);display:inline-flex;align-items:center;gap:8px;letter-spacing:.1px}
.btn-ghost:hover{border-color:var(--navy);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
/* on navy bg */
.btn-outline{background:transparent;color:#fff;font-size:12.5px;font-weight:700;padding:14px 28px;
              border-radius:12px;border:1.5px solid rgba(255,255,255,.32);cursor:pointer;
              transition:all .28s var(--ease);display:inline-flex;align-items:center;gap:8px;letter-spacing:.1px}
.btn-outline:hover{border-color:rgba(255,255,255,.75);background:rgba(255,255,255,.1);transform:translateY(-2px)}
.btn-wht{background:#fff;color:var(--navy);font-size:12.5px;font-weight:700;padding:14px 28px;
          border-radius:12px;border:none;cursor:pointer;transition:all .28s var(--ease);
          display:inline-flex;align-items:center;gap:8px;letter-spacing:.1px}
.btn-wht:hover{background:var(--sky);transform:translateY(-2px);box-shadow:var(--shadow-lg)}

/* ── SERVICES (white bg → dark text) ─────── */
.svc-top{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:end;margin-bottom:44px}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.svc-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);
           overflow:hidden;transition:all .35s cubic-bezier(.2,.8,.2,1);position:relative;
           --accent:var(--blue)}
.svc-card:hover{border-color:var(--accent);transform:translateY(-6px);
                 box-shadow:0 20px 44px rgba(13,33,55,.16)}
.svc-photo{position:relative;aspect-ratio:16/9;background-size:cover;background-position:center;
            overflow:hidden;transition:background-size .5s cubic-bezier(.2,.8,.2,1)}
.svc-photo::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(13,33,55,0) 55%,rgba(13,33,55,.5) 100%)}
.svc-card:hover .svc-photo{background-size:108%}
.svc-photo-grad{background:linear-gradient(135deg,var(--accent),var(--navy));
                  display:flex;align-items:center;justify-content:center}
.svc-photo-icon{position:relative;z-index:1;opacity:.92}
/* diagonal shine sweep on hover — subtle "alive" motion, contained to the photo */
.svc-photo::before{content:'';position:absolute;top:-20%;left:-60%;width:35%;height:140%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);
  transform:skewX(-18deg);z-index:1;transition:left .75s cubic-bezier(.2,.8,.2,1);pointer-events:none}
.svc-card:hover .svc-photo::before{left:130%}
.svc-num{position:absolute;top:16px;left:16px;z-index:2;font-size:10.5px;font-weight:800;
          letter-spacing:2px;color:#fff;background:var(--accent);
          padding:5px 11px;border-radius:var(--r-full);box-shadow:0 4px 12px rgba(13,33,55,.3)}
.svc-body{padding:24px 24px 26px}
.svc-title{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:9px;
            transition:color .22s;letter-spacing:-.1px}
.svc-card:hover .svc-title{color:var(--accent)}
.svc-desc{font-size:13.5px;color:var(--muted);line-height:1.65;margin-bottom:16px}
.svc-link{font-size:13px;font-weight:700;color:var(--navy);display:inline-flex;
           align-items:center;gap:5px;transition:gap .22s,color .22s}
.svc-card:hover .svc-link{color:var(--accent);gap:9px}

/* ── FEATURED SERVICE (home teaser bento — one flagship + a compact row) ── */
.svc-bento{display:flex;flex-direction:column;gap:20px}
.svc-featured{display:grid;grid-template-columns:1.1fr 1fr;background:#fff;
  border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;
  transition:all .35s cubic-bezier(.2,.8,.2,1);--accent:var(--blue)}
.svc-featured:hover{border-color:var(--accent);transform:translateY(-6px);
  box-shadow:0 24px 52px rgba(13,33,55,.16)}
.svc-featured-photo{position:relative;overflow:hidden;min-height:280px;
  background-size:cover;background-position:center;transition:background-size .6s cubic-bezier(.2,.8,.2,1)}
.svc-featured:hover .svc-featured-photo{background-size:110%}
.svc-featured-photo::after{content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(13,33,55,.08),transparent 40%)}
.svc-featured-photo::before{content:'';position:absolute;top:-30%;left:-60%;width:35%;height:160%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);
  transform:skewX(-18deg);z-index:1;transition:left .8s cubic-bezier(.2,.8,.2,1);pointer-events:none}
.svc-featured:hover .svc-featured-photo::before{left:130%}
.svc-flag{position:absolute;top:18px;left:18px;z-index:1;font-size:10.5px;font-weight:800;
  letter-spacing:1.5px;text-transform:uppercase;color:#fff;background:var(--accent);
  padding:6px 13px;border-radius:var(--r-full);box-shadow:0 4px 12px rgba(13,33,55,.3)}
.svc-featured-body{padding:36px 38px;display:flex;flex-direction:column;justify-content:center}
.svc-featured-title{font-size:clamp(21px,2.2vw,26px);font-weight:800;color:var(--navy);
  letter-spacing:-.3px;line-height:1.15;margin-bottom:12px;transition:color .22s}
.svc-featured:hover .svc-featured-title{color:var(--accent)}
.svc-featured-body .svc-desc{font-size:14.5px;margin-bottom:18px}
.svc-featured-body .svc-link{font-size:13.5px}
.svc-featured:hover .svc-featured-body .svc-link{color:var(--accent)}
.svc-grid-secondary{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-grid-secondary .svc-photo{aspect-ratio:4/3}
.svc-grid-secondary .svc-body{padding:20px 20px 22px}
.svc-grid-secondary .svc-title{font-size:15.5px}
.svc-grid-secondary .svc-desc{font-size:12.5px;margin-bottom:12px}

/* ── PHOTO GALLERY (reused on service pages for proof/before-after shots) ── */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-photo{aspect-ratio:4/3;background-size:cover;background-position:center;
                border-radius:var(--r-lg);box-shadow:var(--shadow-md);border:1.5px solid var(--border);
                transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.gallery-photo:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.gallery-cap{margin-top:10px;font-size:12.5px;color:var(--muted);text-align:center}
@media(max-width:768px){.gallery-grid{grid-template-columns:1fr;gap:14px}}

.why-icon-circle svg{transition:all .3s cubic-bezier(.2,.8,.2,1)}
.why-card:hover .why-icon-circle svg{stroke:#fff;fill:#fff}
.ci-ico svg{transition:none}

/* ── ABOUT PREVIEW (off-white bg → dark text) ── */
.story-grid{display:grid;grid-template-columns:420px 1fr;gap:72px;align-items:start}
.story-photo-wrap{position:relative;flex-shrink:0}
.story-photo{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4;
              box-shadow:0 20px 60px rgba(13,33,55,.18)}
.story-photo img{width:100%;height:100%;object-fit:cover;object-position:center top}
.story-badge{position:absolute;bottom:-14px;left:-14px;
              background:var(--blue);color:#fff;border-radius:var(--r);
              padding:15px 18px;box-shadow:0 10px 28px rgba(30,111,191,.45);text-align:center;
              z-index:2}
.sb-num{font-size:28px;font-weight:800;line-height:1;letter-spacing:-1px}
.sb-lbl{font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;opacity:.92;margin-top:3px}
.story-body p{font-size:15px;color:var(--mid);line-height:1.8;margin-bottom:14px}
/* quote on sky bg → navy italic text */
.story-quote{border-left:3px solid var(--blue);padding:14px 18px;background:var(--sky);
              border-radius:0 10px 10px 0;margin:20px 0}
.story-quote p{font-size:15px;font-style:italic;color:var(--navy);
                line-height:1.6;margin:0;font-weight:500}
.story-vals{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:22px}
/* cards on off-white → white bg */
.sv{padding:14px;border:1.5px solid var(--border);border-radius:var(--r);
     background:#fff;transition:border-color .2s}
.sv:hover{border-color:var(--blue)}
.sv-name{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:3px}
.sv-txt{font-size:12px;color:var(--muted);line-height:1.5}

/* ── NEWS (navy bg → white text) ─────────── */
.news{background:var(--navy);padding:32px 40px}
.news-in{max-width:1120px;margin:0 auto;display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.news-logo-img{height:52px;width:auto;border-radius:6px;flex-shrink:0}
.news-div{width:1px;height:40px;background:rgba(255,255,255,.25);flex-shrink:0}
.news-txt{font-size:15px;font-weight:400;font-style:italic;
           color:rgba(255,255,255,.8);line-height:1.55;flex:1}
.news-btn{background:rgba(255,255,255,.1);color:#fff;font-size:11px;font-weight:700;
           letter-spacing:.5px;padding:11px 22px;border-radius:12px;
           border:1.5px solid rgba(255,255,255,.25);cursor:pointer;white-space:nowrap;
           flex-shrink:0;transition:all .25s var(--ease);text-decoration:none;display:inline-block}
.news-btn:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}

/* ── WHY US (off-white bg → white cards, dark text) ── */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.why-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r);
           padding:28px 22px;transition:all .3s cubic-bezier(.2,.8,.2,1);
           position:relative;overflow:hidden}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--blue2));
  transform:scaleX(0);transform-origin:left;transition:transform .35s}
.why-card:hover{border-color:var(--blue);transform:translateY(-6px);
                 box-shadow:0 16px 40px rgba(30,111,191,.14)}
.why-card:hover::before{transform:scaleX(1)}
.why-icon-circle{
  width:48px;height:48px;border-radius:50%;
  background:var(--sky);border:1px solid var(--sky2);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:16px;
  transition:all .3s cubic-bezier(.2,.8,.2,1);
}
.why-card:hover .why-icon-circle{
  background:var(--blue);border-color:var(--blue);
  transform:scale(1.1) rotate(-6deg);
  box-shadow:0 8px 20px rgba(30,111,191,.35);
}
.why-icon{font-size:26px;margin-bottom:13px;display:block}
.why-title{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:6px}
.why-txt{font-size:13px;color:var(--muted);line-height:1.65}

/* ── REVIEWS (navy bg → light text) ────────── */
.rev-bg{position:relative;overflow:hidden;background:var(--navy)}
.rev-bg-photo{position:absolute;inset:0;background-size:cover;background-position:center;
               opacity:.22;filter:saturate(1.05)}
.rev-bg::before{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(13,33,55,.92) 0%,rgba(13,33,55,.97) 100%),
             radial-gradient(ellipse 70% 60% at 85% 10%,rgba(30,111,191,.3),transparent 60%);
  pointer-events:none}
.rev-bg>*{position:relative;z-index:1}
.rev-top{display:flex;align-items:flex-end;justify-content:space-between;
          gap:24px;flex-wrap:wrap;margin-bottom:40px}
.rev-scroll{overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.rev-belt{display:flex;gap:14px;width:max-content;animation:rb 44s linear infinite}
.rev-belt:hover{animation-play-state:paused}
@keyframes rb{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rev-card{width:290px;flex-shrink:0;
           background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);
           border-radius:var(--r);padding:22px 18px;transition:all .3s cubic-bezier(.2,.8,.2,1);
           backdrop-filter:blur(4px)}
.rev-card:hover{background:rgba(255,255,255,.11);border-color:rgba(37,128,216,.4);
                 transform:translateY(-5px);box-shadow:0 16px 32px rgba(0,0,0,.25)}
.rev-card:hover .rev-ava{transform:scale(1.08)}
.rev-stars{color:var(--gold);font-size:11px;letter-spacing:2px;margin-bottom:11px}
.rev-q{font-size:14px;font-style:italic;color:rgba(255,255,255,.94);
        line-height:1.65;margin-bottom:14px}
.rev-au{display:flex;align-items:center;gap:10px}
.rev-ava{width:34px;height:34px;border-radius:50%;
           background:linear-gradient(135deg,var(--blue),var(--navy));
           display:flex;align-items:center;justify-content:center;
           font-size:13px;font-weight:700;color:#fff;flex-shrink:0;
           transition:transform .3s cubic-bezier(.2,.8,.2,1)}
/* vary avatar colors per card so the row doesn't read as copy-pasted */
.rev-card:nth-of-type(9n+1) .rev-ava{background:linear-gradient(135deg,#2580d8,#0d2137)}
.rev-card:nth-of-type(9n+2) .rev-ava{background:linear-gradient(135deg,#f59e0b,#b45309)}
.rev-card:nth-of-type(9n+3) .rev-ava{background:linear-gradient(135deg,#22c55e,#166534)}
.rev-card:nth-of-type(9n+4) .rev-ava{background:linear-gradient(135deg,#a855f7,#5b21b6)}
.rev-card:nth-of-type(9n+5) .rev-ava{background:linear-gradient(135deg,#ec4899,#9d174d)}
.rev-card:nth-of-type(9n+6) .rev-ava{background:linear-gradient(135deg,#14b8a6,#115e59)}
.rev-card:nth-of-type(9n+7) .rev-ava{background:linear-gradient(135deg,#1e6fbf,#162d47)}
.rev-card:nth-of-type(9n+8) .rev-ava{background:linear-gradient(135deg,#f97316,#9a3412)}
.rev-card:nth-of-type(9n+9) .rev-ava{background:linear-gradient(135deg,#6366f1,#312e81)}
.rev-name{font-size:12px;font-weight:700;color:#fff}
.rev-meta{font-size:10px;color:rgba(255,255,255,.8);margin-top:2px}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rev-grid .rev-card{width:auto}
@media(max-width:900px){.rev-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.rev-grid{grid-template-columns:1fr}}

/* ── 404 ────────────────────────────────────── */
.err-wrap{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:100px 22px}
.err-num{font-size:clamp(72px,14vw,140px);font-weight:800;color:var(--blue);line-height:1;letter-spacing:-.03em}
.err-ttl{font-size:clamp(22px,3vw,30px);font-weight:800;color:var(--navy);margin-top:6px}
.err-txt{color:var(--muted);font-size:14.5px;margin-top:12px;max-width:420px;margin-left:auto;margin-right:auto}
.err-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:26px}

/* ── AREA (white bg → dark text) ──────────── */
.area-g{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.area-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.area-tag{font-size:12px;font-weight:600;color:var(--navy);
           background:var(--sky);border:1.5px solid var(--sky2);
           padding:6px 15px;border-radius:var(--r-full);transition:all .25s cubic-bezier(.2,.8,.2,1);cursor:default}
.area-tag:hover{background:var(--blue);color:#fff;border-color:var(--blue);
                 transform:translateY(-2px);box-shadow:0 6px 14px rgba(30,111,191,.3)}
.map-wrap{border-radius:var(--r-lg);overflow:hidden;height:380px;
           border:2px solid var(--border);box-shadow:0 8px 32px rgba(13,33,55,.08);
           transition:box-shadow .3s,border-color .3s}
.map-wrap:hover{border-color:var(--blue);box-shadow:0 16px 44px rgba(30,111,191,.16)}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}

/* ── FAQ (off-white bg → dark text) ────────── */
.faq-wrap{max-width:660px;margin:0 auto}
.faq-item{background:#fff;border:1.5px solid var(--border);border-radius:var(--r);
           margin-bottom:12px;padding:0 22px;transition:all .3s cubic-bezier(.2,.8,.2,1);
           overflow:hidden}
.faq-item:hover{border-color:var(--blue);box-shadow:0 8px 24px rgba(30,111,191,.08);
                 transform:translateY(-2px)}
.faq-q{width:100%;background:none;border:none;padding:22px 0;
        display:flex;align-items:center;justify-content:space-between;gap:14px;
        text-align:left;font-size:15.5px;font-weight:600;color:var(--text);
        cursor:pointer;transition:color .15s}
.faq-q:hover{color:var(--blue)}
.faq-tog{width:28px;height:28px;border-radius:50%;flex-shrink:0;
          border:1.5px solid var(--border);display:flex;align-items:center;
          justify-content:center;transition:all .3s cubic-bezier(.2,.8,.2,1)}
.faq-tog svg{width:11px;height:11px;stroke:var(--muted);stroke-width:2.5;
              fill:none;transition:transform .3s}
.faq-q.o .faq-tog{background:var(--blue);border-color:var(--blue);transform:rotate(90deg)}
.faq-q.o .faq-tog svg{stroke:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;font-size:14.5px;color:var(--muted);line-height:1.78;
        transition:max-height .4s cubic-bezier(.4,0,.2,1),padding .4s}
.faq-a.o{max-height:220px;padding-bottom:20px}

/* ── CTA (navy bg → white text) ──────────── */
.cta{background:linear-gradient(160deg,var(--navy) 0%,#0a1a2e 55%,#0d2137 100%);
     padding:112px 40px;text-align:center;position:relative;overflow:hidden}
.cta-bg{position:absolute;inset:0;background-size:cover;background-position:center;
         opacity:.16;filter:saturate(1.05)}
.cta::before{content:'';position:absolute;top:-10%;left:50%;
  transform:translateX(-50%);width:900px;height:900px;border-radius:50%;
  background:radial-gradient(circle,rgba(37,128,216,.22),transparent 62%);pointer-events:none}
.cta::after{content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(13,33,55,.88) 0%,rgba(10,26,46,.93) 55%,rgba(13,33,55,.96) 100%),
             radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:100% 100%,28px 28px;pointer-events:none}
.cta h2{color:#fff;margin-bottom:16px;position:relative;z-index:1}
.cta h2 em{font-style:italic;color:rgba(255,255,255,.55)}
.cta p{font-size:16px;color:rgba(255,255,255,.68);margin-bottom:40px;position:relative;z-index:1}
.cta-btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;position:relative;z-index:1}

/* ── INNER PAGE HERO (navy bg → white text) ── */
.pg-hero{background:linear-gradient(135deg,#0a1b2e 0%,#122844 100%);
          padding:126px 40px 60px;position:relative;overflow:hidden}
.pg-hero::after{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 75% 50%,rgba(30,111,191,.14),transparent 65%);pointer-events:none}
.pg-hero-in{max-width:1120px;margin:0 auto;position:relative;z-index:1}
.pg-bc{font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:14px}
.pg-hero h1{font-size:clamp(32px,5vw,58px);font-weight:800;letter-spacing:-1.5px;
             line-height:1.05;color:#fff;margin-bottom:14px;max-width:600px}
.pg-hero p{font-size:16px;color:rgba(255,255,255,.75);max-width:480px;line-height:1.75}

/* ── SERVICES DETAIL (one per dedicated service page) ── */
.sd{padding:var(--sp-block) 0}
.sd-in{max-width:1140px;margin:0 auto;padding:0 40px;
        display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:center}
.sd-photo{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;background:var(--sky);
           display:flex;align-items:center;justify-content:center;font-size:64px;
           position:relative;box-shadow:var(--shadow-md)}
.sd-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.sd-photo-illus svg{position:absolute;inset:0;width:100%;height:100%}
.sd-num{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;
         color:var(--blue);margin-bottom:12px}
.sd-title{font-size:30px;font-weight:800;letter-spacing:-.6px;color:var(--navy);
           margin-bottom:14px;line-height:1.12}
.sd-desc{font-size:16px;color:var(--muted);line-height:1.78;margin-bottom:20px}
.sd-incs{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;margin-bottom:20px}
.sd-inc{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--mid)}
.sd-inc::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0}
.sd-best{font-size:13.5px;color:var(--muted);line-height:1.7;
          padding:14px 18px;background:var(--sky);
          border-left:3px solid var(--blue);border-radius:0 var(--r-sm) var(--r-sm) 0;margin-bottom:24px}
.sd-best strong{font-weight:700;color:var(--navy)}
/* per-service accent so the five callouts aren't identical copy-pasted blocks */
.sd-01 .sd-best{border-left-color:#1e6fbf;background:#eef6fd}
.sd-02 .sd-best{border-left-color:#0d2137;background:#eef1f4}
.sd-03 .sd-best{border-left-color:#14b8a6;background:#ecfbf9}
.sd-04 .sd-best{border-left-color:#f59e0b;background:#fef8ec}
.sd-05 .sd-best{border-left-color:#a855f7;background:#f7effe}
.sd-01 .sd-best strong{color:#1e6fbf}
.sd-02 .sd-best strong{color:#0d2137}
.sd-03 .sd-best strong{color:#0f766e}
.sd-04 .sd-best strong{color:#b45309}
.sd-05 .sd-best strong{color:#7e22ce}
.sd-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-sd{background:var(--navy);color:#fff;font-size:12.5px;font-weight:700;
         padding:14px 28px;border-radius:12px;border:none;cursor:pointer;transition:all .28s var(--ease)}
.btn-sd:hover{background:var(--navy2);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-sd-g{background:#fff;color:var(--navy);font-size:12.5px;font-weight:700;
           padding:14px 28px;border-radius:12px;border:1.5px solid var(--border);
           cursor:pointer;transition:all .28s var(--ease);text-decoration:none;display:inline-block}
.btn-sd-g:hover{border-color:var(--navy);transform:translateY(-2px);box-shadow:var(--shadow-sm)}

/* ── SERVICE PLANS (pricing tiers, no dollar figures) ── */
.plan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:8px}
.plan-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);
            padding:26px 22px;position:relative;transition:all .3s cubic-bezier(.2,.8,.2,1)}
.plan-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--blue)}
.plan-best{background:var(--navy);border-color:var(--navy)}
.plan-best:hover{border-color:var(--blue2)}
.plan-badge{display:inline-block;background:var(--gold);color:var(--navy);font-size:10px;
             font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:5px 12px;
             border-radius:var(--r-full);margin-bottom:14px}
.plan-save{font-size:12px;font-weight:700;color:var(--blue);margin-bottom:6px}
.plan-best .plan-save{color:#7dd3fc}
.plan-name{font-size:19px;font-weight:800;color:var(--navy);letter-spacing:-.2px}
.plan-best .plan-name{color:#fff}
.plan-sub{font-size:12px;color:var(--muted);margin-bottom:16px}
.plan-best .plan-sub{color:rgba(255,255,255,.65)}
.plan-card:first-child .plan-name{margin-top:0}
.plan-incs{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.plan-inc{font-size:13px;color:var(--mid);display:flex;align-items:center;justify-content:space-between;gap:8px}
.plan-best .plan-inc{color:rgba(255,255,255,.88)}
.plan-inc::before{content:'✓';color:var(--blue);font-weight:800;margin-right:7px}
.plan-best .plan-inc::before{color:#7dd3fc}
.plan-free{font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;
            color:var(--green);flex-shrink:0}
.plan-best .plan-free{color:#86efac}
@media(max-width:1024px){.plan-grid{grid-template-columns:1fr 1fr;gap:14px}}
@media(max-width:600px){.plan-grid{grid-template-columns:1fr}}

/* ── ABOUT PAGE ── */
.about-g{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-photo{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4;position:relative;
              box-shadow:0 16px 48px rgba(13,33,55,.14)}
.about-photo img{width:100%;height:100%;object-fit:cover;object-position:center top}
.about-badge{position:absolute;bottom:20px;left:18px;background:rgba(255,255,255,.96);
              backdrop-filter:blur(8px);border-radius:var(--r);padding:14px 18px;
              display:flex;align-items:center;gap:12px;
              box-shadow:0 8px 24px rgba(13,33,55,.14)}
.about-avatar-wrap{position:absolute;top:18px;right:18px;display:flex;flex-direction:column;align-items:center;gap:7px;z-index:2}
.about-avatar{width:76px;height:76px;border-radius:50%;overflow:hidden;
               border:3px solid #fff;box-shadow:0 8px 22px rgba(13,33,55,.3)}
.about-avatar img{width:100%;height:100%;object-fit:cover;object-position:center;background:var(--sky2)}
.about-avatar-lbl{font-size:10px;font-weight:700;letter-spacing:1px;color:#fff;
                   background:rgba(13,33,55,.72);backdrop-filter:blur(6px);
                   padding:4px 10px;border-radius:var(--r-full)}
.ab-stars{color:#b45309;font-size:13px;letter-spacing:2px}
.ab-t1{font-size:14px;font-weight:800;color:var(--navy)}
.ab-t2{font-size:10px;color:var(--muted)}
.about-body p{font-size:15px;color:var(--mid);line-height:1.8;margin-bottom:14px}
.about-quote{border-left:3px solid var(--blue);padding:14px 18px;background:var(--sky);
              border-radius:0 10px 10px 0;margin:22px 0}
.about-quote p{font-size:15px;font-style:italic;color:var(--navy);
                line-height:1.6;margin:0;font-weight:500}
.founder-note{position:relative;background:var(--navy);border-radius:var(--r-lg);
               padding:26px 26px 22px;margin:22px 0;overflow:hidden}
.founder-note-mark{position:absolute;top:-6px;right:18px;font-size:76px;font-weight:800;
                    color:rgba(255,255,255,.08);line-height:1;font-family:Georgia,serif}
.founder-note p{position:relative;font-size:15.5px;font-style:italic;color:#fff;
                 line-height:1.7;margin:0 0 12px;font-weight:500}
.founder-note-sig{position:relative;font-size:12.5px;font-weight:700;color:var(--sky2);
                   letter-spacing:.2px}
.about-vals{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:22px}
.av{padding:14px;border:1.5px solid var(--border);border-radius:var(--r);
     background:var(--off);transition:border-color .2s}
.av:hover{border-color:var(--blue)}
.av-name{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:3px}
.av-txt{font-size:12px;color:var(--muted);line-height:1.5}

/* ── CONTACT ── */
.contact-g{display:grid;grid-template-columns:1fr 1.4fr;gap:56px;align-items:start}
.contact-ttl{font-size:21px;font-weight:800;color:var(--navy);margin-bottom:26px;letter-spacing:-.3px}
.ci{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.ci-ico{width:42px;height:42px;border-radius:12px;background:var(--sky);
         border:1px solid var(--sky2);display:flex;align-items:center;
         justify-content:center;font-size:18px;flex-shrink:0}
.ci-lbl{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
         color:var(--muted);margin-bottom:3px}
.ci-val{font-size:14.5px;font-weight:600;color:var(--navy)}
.ci-val a{transition:color .15s}
.ci-val a:hover{color:var(--blue)}
.c-map{border-radius:var(--r);overflow:hidden;height:210px;border:1px solid var(--border);margin-top:22px}
.c-map iframe{width:100%;height:100%;border:0;display:block}
.form-box{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-lg);padding:38px;
           box-shadow:var(--shadow-md)}
.form-ttl{font-size:23px;font-weight:800;color:var(--navy);margin-bottom:5px;letter-spacing:-.3px}
.form-sub{font-size:13.5px;color:var(--muted);margin-bottom:28px;line-height:1.55}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.fg{margin-bottom:14px}
.fg label{display:block;font-size:10.5px;font-weight:700;letter-spacing:1.5px;
           text-transform:uppercase;color:var(--mid);margin-bottom:7px}
.fg input,.fg select,.fg textarea{width:100%;background:var(--off);
  border:1.5px solid var(--border);border-radius:10px;padding:12px 15px;
  font-size:14.5px;color:var(--text);transition:all .2s var(--ease);outline:none;
  appearance:none;-webkit-appearance:none}
.fg input::placeholder,.fg textarea::placeholder{color:var(--mid);opacity:.75}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue);
  background:#fff;box-shadow:0 0 0 3px rgba(30,111,191,.12)}
.fg textarea{resize:vertical;min-height:96px}
.f-go{width:100%;padding:16px;border:none;border-radius:12px;background:var(--navy);
       color:#fff;font-size:12.5px;font-weight:700;letter-spacing:.5px;
       cursor:pointer;transition:all .28s var(--ease);margin-top:6px}
.f-go:hover{background:var(--navy2);transform:translateY(-2px);
             box-shadow:var(--shadow-lg)}
.f-priv{font-size:11px;color:var(--muted);text-align:center;margin-top:11px}
.f-done{display:none;margin-top:14px;background:var(--sky);border:1px solid var(--sky2);
         border-radius:var(--r);padding:16px;text-align:center;
         font-size:14px;font-weight:600;color:var(--navy);line-height:1.5}

/* ── FOOTER (navy bg → muted light text) ── */
footer{background:linear-gradient(180deg,var(--navy) 0%,#0a1a2e 100%);padding:72px 0 0;position:relative}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(37,128,216,.4),transparent)}
.ft-g{max-width:1140px;margin:0 auto;padding:0 40px;
       display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:48px;
       padding-bottom:52px;border-bottom:1px solid rgba(255,255,255,.09)}
.ft-logo{display:flex;align-items:center;gap:11px;cursor:pointer;margin-bottom:16px}
.ft-logo-t{font-size:15px;font-weight:800;color:#fff;letter-spacing:-.2px}
.ft-tag{font-size:13.5px;color:rgba(255,255,255,.65);line-height:1.75;max-width:220px;margin-bottom:20px}
.ft-soc{display:flex;gap:10px}
.ft-soc a{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.07);
           border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;
           justify-content:center;font-size:13px;font-weight:700;
           color:rgba(255,255,255,.68);transition:all .28s var(--ease)}
.ft-soc a:hover{background:var(--blue);border-color:var(--blue);color:#fff;
                 transform:translateY(-3px);box-shadow:0 8px 18px rgba(30,111,191,.4)}
.ft-col h4{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
            color:rgba(255,255,255,.55);margin-bottom:18px}
.ft-col ul{list-style:none}
.ft-col li{margin-bottom:12px}
.ft-col li a,.ft-col li span{font-size:13.5px;color:rgba(255,255,255,.65);
                              transition:all .2s var(--ease);cursor:pointer}
.ft-col li a:hover{color:#fff;padding-left:3px}
.ft-bot{max-width:1140px;margin:0 auto;padding:18px 40px;
         display:flex;align-items:center;justify-content:space-between}
.ft-copy{font-size:11.5px;color:rgba(255,255,255,.62)}
.ft-badge{font-size:9.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
           color:rgba(255,255,255,.55);background:rgba(255,255,255,.1);
           border:1px solid rgba(255,255,255,.12);padding:6px 14px;border-radius:var(--r-full)}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(10px);
     transition:opacity .18s cubic-bezier(.4,0,.2,1),transform .18s cubic-bezier(.4,0,.2,1)}
.rv.d1{transition-delay:.04s}.rv.d2{transition-delay:.08s}.rv.d3{transition-delay:.12s}
.rv.in{opacity:1;transform:none}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .hero-body{grid-template-columns:1fr;padding-bottom:64px}
  .hero-float-g,.hero-float-b,.hero-card{display:none}
  .svc-top{grid-template-columns:1fr;gap:24px}
  .svc-featured{grid-template-columns:1fr}
  .svc-featured-photo{min-height:220px}
  .svc-grid-secondary{grid-template-columns:1fr 1fr}
  .promise-in{grid-template-columns:1fr 1fr;row-gap:36px;padding:54px 40px}
  .stat-item:nth-child(4n+1)::before{display:block}
  .stat-item:nth-child(2n+1)::before{display:none}
  .story-grid{grid-template-columns:1fr;gap:48px}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .area-g{grid-template-columns:1fr;gap:36px}
  .about-g{grid-template-columns:1fr;gap:40px}
  .contact-g{grid-template-columns:1fr;gap:40px}
  .sd-in{grid-template-columns:1fr;gap:40px}
  .sd-incs{grid-template-columns:1fr}
  .ft-g{grid-template-columns:1fr 1fr;gap:32px}
  .story-vals{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links{display:none}
  .hbg{display:flex}
  .nav-tel,.nav-cta{display:none}
  .mob-bar{display:flex}
  body{padding-bottom:68px}
  .sec{padding:var(--sp-section-mobile) 0}
  .pg-hero{padding:104px 22px 46px}
  .news{padding:22px}
  .news-in{flex-direction:column;align-items:flex-start;gap:16px}
  .news-div{display:none}
  .why-grid{grid-template-columns:1fr;gap:14px}
  .svc-grid{grid-template-columns:1fr;gap:14px}
  .svc-grid-secondary{grid-template-columns:1fr;gap:14px}
  .svc-featured-body{padding:26px 22px 28px}
  .hero{min-height:auto}
  .hero-body{padding:118px 22px 48px}
  .hero-trust{padding-top:20px}
  .hero::after{height:60px;min-height:60px}
  .promise-in{grid-template-columns:1fr 1fr;row-gap:26px;padding:38px 22px}
  .stat-icon{width:24px;height:24px;margin-bottom:8px}
  .stat-num{font-size:28px}
  .stat-lbl{font-size:10.5px;margin-top:6px}
  .story-vals{grid-template-columns:1fr}
  .f-row{grid-template-columns:1fr}
  .form-box{padding:26px 20px}
  .ft-g{grid-template-columns:1fr;padding:0 22px;padding-bottom:40px;gap:36px}
  .ft-bot{flex-direction:column;gap:10px;padding:16px 22px;text-align:center}
  .cta{padding:76px 22px}
  .about-vals{grid-template-columns:1fr}
  /* buttons: comfortable tap targets, never feel cramped */
  .btn-navy,.btn-blue,.btn-ghost,.btn-outline,.btn-wht,.btn-sd,.btn-sd-g{
    padding:15px 26px;font-size:13px;
  }
  .cta-btns,.hero-btns{width:100%}
  .cta-btns a,.cta-btns button,.cta-btns .btn-wht,.cta-btns .btn-outline{flex:1 1 auto;justify-content:center}
  h2.hed{margin-bottom:14px}
  p.dek{font-size:15.5px}
}
@media(max-width:420px){
  .cta-btns{flex-direction:column}
  .cta-btns a,.cta-btns button{width:100%}
}
