/* =========================================================================
   HomeRun Maintenance — Design System
   Brand: navy + royal blue + steel gray + white (from logo)
   Type:  Sora (display) / Hanken Grotesk (body) / JetBrains Mono (meta)
   Motif: subtle baseball — home-plate shapes, "round the bases"
   ========================================================================= */

:root{
  /* ---- Color ---- */
  --navy-950:#0A1426;
  --navy-900:#0E1B33;
  --navy-850:#102140;
  --navy-800:#132542;
  --navy-700:#1A3461;
  --navy-600:#22467F;
  --navy-500:#2A5290;

  --blue-700:#214FA0;
  --blue-600:#2A5FBF;
  --blue-500:#3B7AF0;   /* royal — the "Run" blue */
  --blue-400:#5C95F7;
  --blue-300:#9CC0FB;

  --steel-600:#6E7480;
  --steel-500:#8A8E96;  /* logo home-plate gray */
  --steel-300:#BFC4CC;
  --steel-200:#D7DBE1;

  --bone-100:#F6F3EC;   /* warm paper */
  --bone-200:#ECE7DB;
  --paper:#F5F7FA;      /* cool paper */
  --paper-2:#EDF1F6;
  --white:#FFFFFF;

  --ink-900:#0F1A2B;
  --ink-800:#1A2738;
  --ink-700:#2C3A4D;
  --ink-500:#586474;
  --ink-400:#7A8493;
  --ink-300:#A4ADB9;

  --amber:#F2A93B;      /* star ratings only */
  --green-500:#2EA56B;

  --line:rgba(15,26,43,0.10);
  --line-2:rgba(15,26,43,0.16);
  --line-light:rgba(255,255,255,0.12);
  --line-light-2:rgba(255,255,255,0.20);

  /* ---- Type ---- */
  --font-display:'Sora',system-ui,sans-serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;

  /* ---- Spacing ---- */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px;
  --s6:32px; --s7:48px; --s8:64px; --s9:96px; --s10:128px;

  /* ---- Radius ---- */
  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px;

  /* ---- Shadow (premium, soft) ---- */
  --sh-sm:0 1px 2px rgba(15,26,43,0.06), 0 1px 1px rgba(15,26,43,0.04);
  --sh-md:0 10px 30px -12px rgba(15,26,43,0.20), 0 2px 8px rgba(15,26,43,0.06);
  --sh-lg:0 30px 60px -20px rgba(15,26,43,0.30), 0 8px 24px -8px rgba(15,26,43,0.14);
  --sh-blue:0 18px 40px -14px rgba(43,95,191,0.55);

  /* ---- Motion ---- */
  --ease:cubic-bezier(0.22,1,0.36,1);
  --ease-io:cubic-bezier(0.65,0,0.35,1);

  --nav-h:72px;
  --maxw:1240px;

  /* home-plate (baseball) pentagon */
  --plate:polygon(0% 0%,100% 0%,100% 58%,50% 100%,0% 58%);
}

/* ---- Reset ---- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--ink-800);
  background:var(--white);
  line-height:1.55;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.05;letter-spacing:-0.02em;color:var(--ink-900)}
::selection{background:var(--blue-500);color:#fff}

:focus-visible{outline:3px solid var(--blue-500);outline-offset:3px;border-radius:4px}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
.wrap-tight{max-width:1080px;margin:0 auto;padding:0 24px;width:100%}
.section{padding:var(--s9) 0}
@media(max-width:760px){.section{padding:var(--s8) 0}}

.eyebrow{
  font-family:var(--font-mono);
  font-size:0.72rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--blue-600);
  font-weight:600;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow.on-dark{color:var(--blue-300)}
.eyebrow .idx{color:var(--ink-300)}
.eyebrow.on-dark .idx{color:rgba(255,255,255,0.4)}

.h-sec{font-size:clamp(2rem,4.4vw,3.3rem);letter-spacing:-0.03em}
.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--ink-500);line-height:1.5;max-width:60ch}
.text-balance{text-wrap:balance}
.text-pretty{text-wrap:pretty}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-body);font-weight:600;font-size:1rem;
  padding:15px 26px;border-radius:var(--r-sm);
  transition:transform .12s var(--ease),background .2s var(--ease),box-shadow .25s var(--ease),border-color .2s var(--ease),color .2s var(--ease);
  white-space:nowrap;line-height:1;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--blue-500);color:#fff;box-shadow:var(--sh-blue)}
.btn-primary:hover{background:var(--blue-400)}
.btn-primary:active{transform:translateY(1px)}
.btn-navy{background:var(--navy-800);color:#fff}
.btn-navy:hover{background:var(--navy-700)}
.btn-ghost{background:rgba(255,255,255,0.06);color:#fff;border:1px solid var(--line-light-2)}
.btn-ghost:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.4)}
.btn-outline{background:#fff;color:var(--navy-800);border:1px solid var(--line-2)}
.btn-outline:hover{border-color:var(--navy-600);color:var(--navy-700)}
.btn-lg{padding:18px 32px;font-size:1.06rem}
.btn-block{width:100%}

.link-arrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--blue-600);transition:gap .2s var(--ease),color .2s}
.link-arrow svg{width:17px;height:17px;transition:transform .2s var(--ease)}
.link-arrow:hover{color:var(--blue-500)}
.link-arrow:hover svg{transform:translateX(3px)}

/* ---- Star rating ---- */
.stars{display:inline-flex;gap:2px;color:var(--amber)}
.stars svg{width:16px;height:16px;fill:currentColor}

/* ---- Home-plate badge (baseball motif) ---- */
.plate{
  clip-path:var(--plate);
  display:inline-flex;align-items:center;justify-content:center;
}

/* =========================================================================
   UTILITY BAR
   ========================================================================= */
.utilbar{
  background:var(--navy-950);color:rgba(255,255,255,0.72);
  font-size:0.82rem;border-bottom:1px solid rgba(255,255,255,0.06);
}
.utilbar .wrap{display:flex;align-items:center;justify-content:space-between;height:38px;gap:16px}
.utilbar svg{width:14px;height:14px;flex-shrink:0}
.utilbar .ub-left{display:flex;align-items:center;gap:18px;font-family:var(--font-mono);font-size:0.72rem;letter-spacing:0.06em}
.utilbar .ub-left .dot{width:7px;height:7px;border-radius:50%;background:var(--green-500);box-shadow:0 0 0 0 rgba(46,165,107,.5);animation:pulse 2.4s infinite}
.utilbar .ub-right{display:flex;align-items:center;gap:20px}
.utilbar a{color:rgba(255,255,255,0.82);transition:color .2s}
.utilbar a:hover{color:#fff}
.utilbar .ub-phone{font-weight:600;color:#fff;display:inline-flex;align-items:center;gap:7px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(46,165,107,.5)}70%{box-shadow:0 0 0 6px rgba(46,165,107,0)}100%{box-shadow:0 0 0 0 rgba(46,165,107,0)}}
@media(max-width:860px){.utilbar .ub-left .sep-hide{display:none}.utilbar{font-size:0.76rem}}
@media(max-width:920px){.utilbar .ub-hours{display:none}}
@media(max-width:560px){.utilbar .ub-right{gap:12px}}

/* =========================================================================
   HEADER / NAV
   ========================================================================= */
.header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,0.86);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:box-shadow .3s,border-color .3s,background .3s}
.header.scrolled{box-shadow:var(--sh-md);border-color:var(--line);background:rgba(255,255,255,0.94)}
.header .wrap,.utilbar .wrap{max-width:1640px;padding-left:44px;padding-right:44px}
@media(max-width:560px){.header .wrap,.utilbar .wrap{padding-left:20px;padding-right:20px}}
.nav{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h);gap:16px}
@media(min-width:1141px){.nav{display:grid;grid-template-columns:1fr auto 1fr;gap:0}.nav>.brand{justify-self:center}.nav>.nav-cta{justify-self:center}.header .wrap{max-width:none;padding-left:0;padding-right:0}.utilbar .wrap{max-width:none;padding-left:44px;padding-right:44px}}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand img{height:46px;width:auto}
.brand .bt{display:none}
.brand .bt .n{font-family:var(--font-display);font-weight:800;font-size:1.18rem;letter-spacing:-0.02em;color:var(--navy-800)}
.brand .bt .n b{color:var(--blue-500)}
.brand .bt .m{font-family:var(--font-mono);font-size:0.6rem;letter-spacing:0.32em;color:var(--steel-600);text-transform:uppercase;margin-top:3px}

.nav-links{display:flex;align-items:center;gap:4px}
.nav-links>li>a,.nav-links>li>button{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 11px;border-radius:8px;font-weight:600;font-size:0.94rem;color:var(--ink-700);
  transition:color .2s,background .2s;
}
.nav-links>li>a:hover,.nav-links>li>button:hover{color:var(--navy-800);background:var(--paper)}
.nav-links .chev{width:15px;height:15px;transition:transform .25s var(--ease);color:var(--ink-400)}
.has-mega{position:static}
.has-mega.open .chev{transform:rotate(180deg)}

.nav-cta{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nav-phone{display:inline-flex;align-items:center;gap:9px;font-weight:700;color:var(--navy-800);font-size:1.02rem;white-space:nowrap}
.nav-phone .np-num{white-space:nowrap}
.nav-phone svg{width:18px;height:18px;color:var(--blue-500)}
.nav-phone .np-sub{display:block;font-family:var(--font-mono);font-size:0.58rem;letter-spacing:0.12em;color:var(--ink-400);font-weight:500;text-transform:uppercase}

/* Mega dropdown */
.mega{
  position:absolute;left:0;right:0;top:100%;
  background:#fff;border-top:1px solid var(--line);box-shadow:var(--sh-lg);
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;
  z-index:55;
}
.has-mega.open .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega-inner{max-width:var(--maxw);margin:0 auto;padding:32px 24px 36px;display:grid;grid-template-columns:1.1fr 1.1fr 1.1fr 0.9fr;gap:8px 36px}
.mega-col h4{font-size:0.74rem;font-family:var(--font-mono);letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-400);margin-bottom:14px;font-weight:600}
.mega-link{display:flex;align-items:flex-start;gap:12px;padding:9px 10px;border-radius:10px;transition:background .18s}
.mega-link:hover{background:var(--paper)}
.mega-link .mi{width:34px;height:34px;border-radius:9px;background:var(--paper-2);display:grid;place-items:center;flex-shrink:0;color:var(--blue-600);transition:background .2s,color .2s}
.mega-link:hover .mi{background:var(--blue-500);color:#fff}
.mega-link .mi svg{width:18px;height:18px}
.mega-link .mt{font-weight:600;color:var(--ink-900);font-size:0.96rem;line-height:1.2;display:block;white-space:nowrap}
.mega-link .md{font-size:0.8rem;color:var(--ink-400);margin-top:3px;display:block;white-space:nowrap}
.mega-feature{background:var(--navy-900);border-radius:var(--r-md);padding:22px;color:#fff;display:flex;flex-direction:column;justify-content:space-between;background-image:linear-gradient(160deg,var(--navy-800),var(--navy-950))}
.mega-feature h5{font-family:var(--font-display);font-size:1.15rem;margin-bottom:6px}
.mega-feature p{font-size:0.85rem;color:rgba(255,255,255,0.7);margin-bottom:16px}

.burger{display:none;width:46px;height:46px;border-radius:10px;border:1px solid var(--line-2);align-items:center;justify-content:center;color:var(--navy-800)}
.burger svg{width:22px;height:22px}

@media(max-width:1140px){
  .nav-links,.nav-phone .np-sub{display:none}
  .burger{display:inline-flex}
}
@media(max-width:560px){
  .brand .bt{display:none}
  .nav-phone span.np-num{display:none}
}

/* Mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:80;background:var(--navy-950);color:#fff;transform:translateX(100%);transition:transform .4s var(--ease);overflow-y:auto;display:flex;flex-direction:column}
.mobile-menu.open{transform:translateX(0)}
.mm-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line-light)}
.mm-close{width:46px;height:46px;border-radius:10px;border:1px solid var(--line-light-2);color:#fff;display:grid;place-items:center}
.mm-close svg{width:22px;height:22px}
.mm-body{padding:14px 22px 30px;flex:1}
.mm-body a{display:block;padding:15px 6px;font-size:1.3rem;font-family:var(--font-display);font-weight:600;border-bottom:1px solid var(--line-light)}
.mm-body .mm-sub a{font-size:0.98rem;font-family:var(--font-body);color:rgba(255,255,255,0.7);padding:9px 6px;border:none}
.mm-body .mm-sub{padding-left:10px;margin:4px 0 10px;border-left:2px solid var(--blue-500)}
.mm-foot{padding:22px;border-top:1px solid var(--line-light);display:grid;gap:12px}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{position:relative;background:var(--navy-950);color:#fff;overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(8,16,32,0.97) 0%,rgba(8,16,32,0.90) 42%,rgba(8,16,32,0.66) 70%,rgba(8,16,32,0.46) 100%),
    linear-gradient(0deg,rgba(8,16,32,0.88) 0%,rgba(8,16,32,0) 48%);
}
.hero-glow{position:absolute;top:-10%;right:-5%;width:55%;height:70%;z-index:-1;
  background:radial-gradient(circle,rgba(59,122,240,0.22),transparent 65%);filter:blur(20px)}
.hero-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(56px,8vw,104px) 24px clamp(48px,6vw,84px);position:relative}
.hero-grid{display:grid;grid-template-columns:1.15fr 0.85fr;gap:48px;align-items:end}
.hero h1{font-size:clamp(2.6rem,6vw,5rem);letter-spacing:-0.035em;line-height:0.98;color:#fff;text-wrap:balance}
.hero h1 .accent{color:var(--blue-400)}
.hero .hero-sub{font-size:clamp(1.08rem,1.7vw,1.34rem);color:rgba(255,255,255,0.78);max-width:54ch;margin-top:22px;line-height:1.5}
.hero-eyebrow{margin-bottom:26px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-trust{display:flex;flex-wrap:wrap;align-items:center;gap:14px 26px;margin-top:38px;padding-top:30px;border-top:1px solid var(--line-light)}
.hero-trust .ht{display:flex;align-items:center;gap:10px}
.hero-trust .ht .num{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:#fff;line-height:1}
.hero-trust .ht .lab{font-size:0.78rem;color:rgba(255,255,255,0.62);line-height:1.2}
.hero-trust .vr{width:1px;height:30px;background:var(--line-light)}

/* hero scorecard card */
.scorecard{background:rgba(255,255,255,0.05);border:1px solid var(--line-light-2);border-radius:var(--r-lg);backdrop-filter:blur(8px);padding:24px;box-shadow:var(--sh-lg)}
.scorecard .sc-top{display:flex;align-items:center;justify-content:space-between;padding-bottom:16px;border-bottom:1px solid var(--line-light);margin-bottom:16px}
.scorecard .sc-top .sct{font-family:var(--font-mono);font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.6)}
.scorecard .sc-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;font-size:0.95rem}
.scorecard .sc-row .k{color:rgba(255,255,255,0.7);display:flex;align-items:center;gap:10px}
.scorecard .sc-row .k svg{width:17px;height:17px;color:var(--blue-400)}
.scorecard .sc-row .v{font-weight:700;color:#fff;font-family:var(--font-mono);font-size:0.92rem}
.scorecard .sc-cta{margin-top:18px}

@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:36px}.scorecard{max-width:420px}}
@media(max-width:560px){.hero-trust .vr{display:none}.hero-trust{gap:18px}}

/* badge marquee */
.badgestrip{background:var(--navy-900);border-top:1px solid var(--line-light);color:rgba(255,255,255,0.6)}
.badgestrip .wrap{display:flex;align-items:center;flex-wrap:wrap;gap:18px 40px;padding-top:20px;padding-bottom:20px;justify-content:space-between}
.badgestrip .bs-item{display:inline-flex;align-items:center;gap:10px;font-size:0.86rem;font-weight:600;letter-spacing:0.01em}
.badgestrip .bs-item svg{width:20px;height:20px;color:var(--blue-400)}
@media(max-width:760px){.badgestrip .wrap{justify-content:center;gap:14px 26px}}

/* =========================================================================
   STATS STRIP
   ========================================================================= */
.stats{background:var(--white)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:#fff;box-shadow:var(--sh-sm)}
.stat{padding:34px 30px;border-right:1px solid var(--line);position:relative}
.stat:last-child{border-right:none}
.stat .sv{font-family:var(--font-display);font-weight:800;font-size:clamp(2.2rem,3.6vw,3rem);letter-spacing:-0.03em;color:var(--navy-800);line-height:1}
.stat .sv .u{color:var(--blue-500)}
.stat .sl{margin-top:10px;color:var(--ink-500);font-size:0.95rem;line-height:1.35}
.stat .splate{position:absolute;top:24px;right:24px;width:12px;height:12px;background:var(--blue-500);clip-path:var(--plate);opacity:.5}
@media(max-width:760px){.stats-grid{grid-template-columns:1fr 1fr}.stat:nth-child(2){border-right:none}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}}

/* =========================================================================
   INTRO / ABOUT
   ========================================================================= */
.intro{background:var(--bone-100)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.intro-media{position:relative}
.intro-media .im-main{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);aspect-ratio:4/3.4}
.intro-media .im-main img{width:100%;height:100%;object-fit:cover}
.intro-media .im-badge{position:absolute;bottom:-26px;left:-26px;background:var(--navy-900);color:#fff;border-radius:var(--r-md);padding:22px 24px;box-shadow:var(--sh-lg);max-width:230px}
.intro-media .im-badge .b-num{font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:var(--blue-400);line-height:1}
.intro-media .im-badge .b-lab{font-size:0.86rem;color:rgba(255,255,255,0.75);margin-top:6px}
.intro-body h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin:18px 0 18px;letter-spacing:-0.03em}
.intro-body p{color:var(--ink-600,#4a5666);font-size:1.08rem;margin-bottom:18px;max-width:54ch}
.intro-checks{display:grid;grid-template-columns:1fr 1fr;gap:12px 20px;margin:24px 0 30px}
.intro-checks li{display:flex;align-items:flex-start;gap:10px;font-weight:600;color:var(--ink-800);font-size:0.98rem}
.intro-checks li svg{width:20px;height:20px;color:var(--blue-500);flex-shrink:0;margin-top:1px}
.sig{display:flex;align-items:center;gap:16px;margin-top:6px}
.sig .sig-name{font-family:var(--font-display);font-weight:700;color:var(--navy-800)}
.sig .sig-role{font-size:0.85rem;color:var(--ink-400)}
@media(max-width:860px){.intro-grid{grid-template-columns:1fr;gap:48px}.intro-media .im-badge{left:auto;right:18px}}
@media(max-width:480px){.intro-checks{grid-template-columns:1fr}}

/* =========================================================================
   SECTION HEADER (shared)
   ========================================================================= */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:48px}
.sec-head .sh-l{max-width:62ch}
.sec-head h2{margin-top:16px}
.sec-head p{margin-top:14px}
@media(max-width:760px){.sec-head{flex-direction:column;align-items:flex-start;gap:18px;margin-bottom:36px}}

/* =========================================================================
   SERVICE CATEGORY CARDS
   ========================================================================= */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cat-card{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--navy-900);min-height:440px;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:var(--sh-md);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.cat-card .cc-img{position:absolute;inset:0;z-index:0}
.cat-card .cc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.cat-card:hover .cc-img img{transform:scale(1.06)}
.cat-card .cc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,16,32,0.96) 8%,rgba(8,16,32,0.7) 40%,rgba(8,16,32,0.15) 75%,rgba(8,16,32,0.35) 100%)}
.cat-card .cc-body{position:relative;z-index:1;padding:28px;color:#fff}
.cat-card .cc-kicker{font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--blue-300);margin-bottom:10px}
.cat-card h3{color:#fff;font-size:1.7rem;letter-spacing:-0.02em}
.cat-card .cc-desc{color:rgba(255,255,255,0.74);font-size:0.96rem;margin-top:10px;max-height:0;opacity:0;overflow:hidden;transition:max-height .4s var(--ease),opacity .4s var(--ease),margin .4s}
.cat-card:hover .cc-desc{max-height:80px;opacity:1}
.cat-card .cc-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.cat-card .cc-tags a{font-size:0.78rem;color:rgba(255,255,255,0.8);background:rgba(255,255,255,0.1);border:1px solid var(--line-light-2);padding:5px 11px;border-radius:99px;transition:background .2s,color .2s,border-color .2s}
.cat-card .cc-tags a:hover{background:var(--blue-500);color:#fff;border-color:var(--blue-500)}
.cat-card .cc-link{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-weight:700;color:#fff;font-size:0.96rem}
.cat-card .cc-link svg{width:18px;height:18px;transition:transform .2s var(--ease)}
.cat-card:hover .cc-link svg{transform:translateX(4px)}
.cat-card .cc-num{position:absolute;top:24px;right:26px;z-index:1;font-family:var(--font-mono);font-size:0.8rem;color:rgba(255,255,255,0.55);letter-spacing:0.1em}
@media(max-width:920px){.cat-grid{grid-template-columns:1fr}.cat-card{min-height:340px}.cat-card .cc-desc{max-height:none;opacity:1;margin-top:10px}}

/* =========================================================================
   TRADES GRID
   ========================================================================= */
.trades{background:var(--paper)}
.trade-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.trade{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:26px;transition:border-color .25s,box-shadow .25s,transform .25s;display:flex;flex-direction:column}
.trade:hover{border-color:var(--blue-300);box-shadow:var(--sh-md);transform:translateY(-3px)}
.trade .t-ico{width:50px;height:50px;border-radius:12px;background:linear-gradient(150deg,var(--navy-700),var(--navy-900));display:grid;place-items:center;color:var(--blue-300);margin-bottom:18px}
.trade .t-ico svg{width:24px;height:24px}
.trade h3{font-size:1.28rem}
.trade .t-desc{color:var(--ink-500);font-size:0.94rem;margin-top:8px}
.trade .t-links{margin-top:16px;display:flex;flex-direction:column;gap:2px}
.trade .t-links a{display:flex;align-items:center;justify-content:space-between;padding:9px 2px;font-size:0.92rem;font-weight:500;color:var(--ink-700);border-top:1px solid var(--line);transition:color .2s,padding .2s}
.trade .t-links a:hover{color:var(--blue-600);padding-left:6px}
.trade .t-links a svg{width:15px;height:15px;opacity:0;transform:translateX(-4px);transition:opacity .2s,transform .2s;color:var(--blue-500)}
.trade .t-links a:hover svg{opacity:1;transform:translateX(0)}
.trade .t-foot{margin-top:auto;padding-top:18px}
@media(max-width:920px){.trade-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.trade-grid{grid-template-columns:1fr}}

/* =========================================================================
   BEFORE / AFTER + GALLERY
   ========================================================================= */
.work{background:var(--navy-950);color:#fff}
.work .eyebrow{color:var(--blue-300)}
.work .sec-head h2{color:#fff}
.work .sec-head p{color:rgba(255,255,255,0.7)}
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:30px}
.ba{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/11;user-select:none;box-shadow:var(--sh-lg);cursor:ew-resize;border:1px solid var(--line-light)}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba .ba-after{z-index:1}
.ba .ba-before{z-index:2;clip-path:inset(0 50% 0 0);filter:grayscale(0.9) brightness(0.62) contrast(0.95)}
.ba .ba-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;z-index:3;transform:translateX(-1px)}
.ba .ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;color:var(--navy-800);display:grid;place-items:center;box-shadow:var(--sh-md)}
.ba .ba-knob svg{width:22px;height:22px}
.ba .ba-tag{position:absolute;bottom:14px;z-index:4;font-family:var(--font-mono);font-size:0.66rem;letter-spacing:0.14em;text-transform:uppercase;padding:5px 11px;border-radius:6px;background:rgba(8,16,32,0.75);color:#fff;backdrop-filter:blur(4px)}
.ba .ba-tag.t-before{left:14px}
.ba .ba-tag.t-after{right:14px;background:var(--blue-500)}
.ba .ba-cap{position:absolute;top:14px;left:14px;z-index:4;font-weight:600;font-size:0.9rem;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.6)}
@media(max-width:760px){.ba-grid{grid-template-columns:1fr}}

.gallery-filter{display:flex;flex-wrap:wrap;gap:10px;margin:34px 0 24px}
.gchip{font-family:var(--font-body);font-weight:600;font-size:0.9rem;padding:9px 18px;border-radius:99px;border:1px solid var(--line-light-2);color:rgba(255,255,255,0.7);transition:all .2s}
.gchip:hover{color:#fff;border-color:rgba(255,255,255,0.5)}
.gchip.active{background:var(--blue-500);color:#fff;border-color:var(--blue-500)}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gitem{position:relative;border-radius:var(--r-md);overflow:hidden;aspect-ratio:1;cursor:pointer;transition:transform .3s var(--ease)}
.gitem img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gitem:hover img{transform:scale(1.08)}
.gitem::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,16,32,0.7),transparent 55%);opacity:0;transition:opacity .3s}
.gitem:hover::after{opacity:1}
.gitem .gi-lab{position:absolute;left:12px;bottom:10px;z-index:1;font-size:0.8rem;font-weight:600;color:#fff;opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
.gitem:hover .gi-lab{opacity:1;transform:translateY(0)}
.gitem.tall{grid-row:span 2;aspect-ratio:auto}
.gitem.hide{display:none}
@media(max-width:760px){.gallery{grid-template-columns:1fr 1fr}.gitem.tall{grid-row:span 1}}

/* =========================================================================
   WHY US
   ========================================================================= */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.why{padding:30px;border-radius:var(--r-md);background:#fff;border:1px solid var(--line);transition:border-color .25s,box-shadow .25s}
.why:hover{border-color:var(--blue-300);box-shadow:var(--sh-md)}
.why .w-ico{width:48px;height:48px;border-radius:12px;background:var(--paper-2);display:grid;place-items:center;color:var(--blue-600);margin-bottom:18px}
.why .w-ico svg{width:24px;height:24px}
.why h3{font-size:1.22rem}
.why p{color:var(--ink-500);font-size:0.96rem;margin-top:8px}
@media(max-width:920px){.why-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.why-grid{grid-template-columns:1fr}}

/* =========================================================================
   PROCESS — round the bases
   ========================================================================= */
.process{background:var(--navy-900);color:#fff;position:relative;overflow:hidden}
.process .glow{position:absolute;bottom:-30%;left:-10%;width:50%;height:80%;background:radial-gradient(circle,rgba(59,122,240,0.18),transparent 65%);filter:blur(10px)}
.process .eyebrow{color:var(--blue-300)}
.process .sec-head h2{color:#fff}
.process .sec-head p{color:rgba(255,255,255,0.7)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
.step{position:relative;padding-top:14px}
.step .s-base{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--blue-300);margin-bottom:18px}
.step .s-plate{width:54px;height:54px;background:linear-gradient(150deg,var(--blue-500),var(--blue-700));clip-path:var(--plate);display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:1.4rem;color:#fff;margin-bottom:18px;box-shadow:var(--sh-blue)}
.step h3{font-size:1.3rem;color:#fff}
.step p{color:rgba(255,255,255,0.66);font-size:0.95rem;margin-top:8px}
.step .s-line{position:absolute;top:41px;left:64px;right:-20px;height:2px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.25) 0 6px,transparent 6px 12px)}
.step:last-child .s-line{display:none}
@media(max-width:860px){.steps{grid-template-columns:1fr 1fr;gap:30px 20px}.step .s-line{display:none}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}

/* =========================================================================
   SERVICE AREAS
   ========================================================================= */
.areas{background:var(--bone-100)}
.areas-grid{display:grid;grid-template-columns:0.95fr 1.05fr;gap:56px;align-items:center}
.area-map{position:relative;background:linear-gradient(160deg,var(--navy-800),var(--navy-950));border-radius:var(--r-lg);padding:30px;aspect-ratio:4/3.1;overflow:hidden;box-shadow:var(--sh-lg);border:1px solid var(--line-light)}
.area-map .am-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.05) 1px,transparent 1px);background-size:34px 34px}
.area-map .am-coast{position:absolute;right:-6%;top:0;bottom:0;width:42%;background:radial-gradient(circle at 120% 50%,rgba(59,122,240,0.16),transparent 60%)}
.area-map .am-label{position:absolute;font-family:var(--font-mono);font-size:0.64rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.5)}
.pin{position:absolute;transform:translate(-50%,-50%);z-index:2}
.pin .pdot{width:12px;height:12px;border-radius:50%;background:var(--blue-500);box-shadow:0 0 0 4px rgba(59,122,240,0.28);cursor:pointer;transition:transform .2s}
.pin:hover .pdot{transform:scale(1.3)}
.pin.hq .pdot{width:18px;height:18px;background:#fff;box-shadow:0 0 0 5px rgba(59,122,240,0.4),0 0 16px rgba(59,122,240,0.6)}
.pin.hq .pdot::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--blue-500);animation:ping 2.2s var(--ease-io) infinite}
@keyframes ping{0%{transform:scale(1);opacity:.7}80%,100%{transform:scale(2.6);opacity:0}}
.pin .plab{position:absolute;left:50%;top:16px;transform:translateX(-50%);white-space:nowrap;font-size:0.72rem;font-weight:600;color:#fff;background:rgba(8,16,32,0.7);padding:2px 8px;border-radius:5px;backdrop-filter:blur(4px)}
.pin.hq .plab{font-weight:700;color:var(--blue-300)}

.areas-body h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin:16px 0 16px;letter-spacing:-0.03em}
.areas-body>p{color:var(--ink-600,#4a5666);font-size:1.06rem;max-width:52ch;margin-bottom:26px}
.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.city{display:flex;align-items:center;gap:9px;padding:12px 14px;background:#fff;border:1px solid var(--line);border-radius:10px;font-weight:600;font-size:0.92rem;color:var(--ink-800);transition:all .2s}
.city svg{width:15px;height:15px;color:var(--blue-500);flex-shrink:0;transition:transform .2s}
.city:hover{border-color:var(--blue-400);color:var(--blue-600);box-shadow:var(--sh-sm);transform:translateY(-2px)}
.city:hover svg{transform:translateY(-1px)}
.city.feat{background:var(--navy-800);color:#fff;border-color:var(--navy-800)}
.city.feat svg{color:var(--blue-300)}
.areas-more{margin-top:18px;font-size:0.92rem;color:var(--ink-500);line-height:1.6}
.areas-more a{color:var(--blue-600);font-weight:600;text-decoration:underline;text-decoration-color:var(--blue-300);text-underline-offset:3px}
@media(max-width:900px){.areas-grid{grid-template-columns:1fr;gap:40px}}
@media(max-width:520px){.city-grid{grid-template-columns:1fr 1fr}}

/* =========================================================================
   REVIEWS
   ========================================================================= */
.reviews-top{display:flex;flex-wrap:wrap;align-items:center;gap:14px 28px;margin-bottom:40px}
.rscore{display:flex;align-items:center;gap:14px}
.rscore .rs-num{font-family:var(--font-display);font-weight:800;font-size:3rem;color:var(--navy-800);line-height:1}
.rscore .rs-meta .stars{margin-bottom:3px}
.rscore .rs-meta div{font-size:0.88rem;color:var(--ink-500)}
.rbadges{display:flex;gap:12px;margin-left:auto}
.rbadge{display:flex;align-items:center;gap:9px;padding:10px 16px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:0.86rem;font-weight:600;color:var(--ink-700)}
.rbadge svg{width:18px;height:18px}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:28px;display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s}
.review:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.review .stars{margin-bottom:14px}
.review .r-quote{font-size:1.04rem;color:var(--ink-800);line-height:1.55;font-weight:500}
.review .r-quote b{color:var(--navy-700)}
.review .r-foot{display:flex;align-items:center;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.review .r-av{width:44px;height:44px;border-radius:50%;object-fit:cover;background:var(--paper-2)}
.review .r-av.init{display:grid;place-items:center;font-family:var(--font-display);font-weight:700;color:#fff;background:var(--navy-700)}
.review .r-name{font-weight:700;color:var(--ink-900);font-size:0.96rem}
.review .r-loc{font-size:0.82rem;color:var(--ink-400);display:flex;align-items:center;gap:5px}
.review .r-loc svg{width:13px;height:13px;color:var(--blue-500)}
.review .r-src{margin-left:auto;width:24px;height:24px;opacity:.85}
@media(max-width:920px){.review-grid{grid-template-columns:1fr}.rbadges{margin-left:0;width:100%}}

/* =========================================================================
   CTA BAND
   ========================================================================= */
.cta-band{background:linear-gradient(135deg,var(--navy-800),var(--navy-950));color:#fff;position:relative;overflow:hidden;isolation:isolate}
.cta-band .cb-glow{position:absolute;top:-40%;right:-5%;width:50%;height:160%;background:radial-gradient(circle,rgba(59,122,240,0.28),transparent 60%);z-index:-1;filter:blur(10px)}
.cta-band .cb-plate{position:absolute;left:-60px;bottom:-80px;width:280px;height:280px;background:rgba(255,255,255,0.03);clip-path:var(--plate);z-index:-1}
.cta-inner{display:grid;grid-template-columns:1.2fr 0.8fr;gap:48px;align-items:center;padding:var(--s9) 0}
.cta-inner h2{font-size:clamp(2rem,4vw,3.2rem);color:#fff;letter-spacing:-0.03em}
.cta-inner .cb-sub{color:rgba(255,255,255,0.76);font-size:1.15rem;margin-top:16px;max-width:46ch}
.cta-inner .cb-fin{display:inline-flex;align-items:center;gap:10px;margin-top:22px;font-family:var(--font-mono);font-size:0.78rem;letter-spacing:0.08em;color:var(--blue-300);background:rgba(59,122,240,0.12);border:1px solid rgba(59,122,240,0.3);padding:8px 14px;border-radius:8px}
.cta-inner .cb-fin svg{width:16px;height:16px}
.cta-actions{display:flex;flex-direction:column;gap:14px}
@media(max-width:860px){.cta-inner{grid-template-columns:1fr;gap:34px;padding:var(--s8) 0}}

/* =========================================================================
   ESTIMATE FORM
   ========================================================================= */
.estimate{background:var(--paper)}
.est-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:0;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);background:#fff}
.est-aside{background:linear-gradient(160deg,var(--navy-800),var(--navy-950));color:#fff;padding:48px;position:relative;overflow:hidden}
.est-aside h2{color:#fff;font-size:clamp(1.7rem,2.6vw,2.3rem)}
.est-aside p{color:rgba(255,255,255,0.74);margin-top:14px;font-size:1.02rem}
.est-aside .ea-list{margin-top:28px;display:grid;gap:14px}
.est-aside .ea-list li{display:flex;align-items:flex-start;gap:12px;font-size:0.98rem;color:rgba(255,255,255,0.88)}
.est-aside .ea-list li svg{width:20px;height:20px;color:var(--blue-400);flex-shrink:0;margin-top:1px}
.est-aside .ea-call{margin-top:34px;padding-top:26px;border-top:1px solid var(--line-light)}
.est-aside .ea-call .ec-lab{font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.55)}
.est-aside .ea-call a{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:700;font-size:1.6rem;color:#fff;margin-top:8px}
.est-aside .ea-call a svg{width:24px;height:24px;color:var(--blue-400)}
.est-form{padding:48px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px;display:flex;flex-direction:column;gap:7px}
.field label{font-size:0.84rem;font-weight:600;color:var(--ink-700)}
.field label .req{color:var(--blue-500)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:0.98rem;padding:13px 14px;border:1px solid var(--line-2);border-radius:var(--r-sm);
  background:var(--paper);color:var(--ink-900);transition:border-color .2s,box-shadow .2s,background .2s;width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 4px rgba(59,122,240,0.12);background:#fff}
.field textarea{resize:vertical;min-height:90px}
.field.err input,.field.err select{border-color:var(--error,#e0564f)}
.field .ferr{font-size:0.78rem;color:#d4453d;display:none}
.field.err .ferr{display:block}
.form-foot{display:flex;align-items:center;gap:16px;margin-top:8px;flex-wrap:wrap}
.form-foot .ff-note{font-size:0.8rem;color:var(--ink-400);max-width:30ch}
.form-success{display:none;text-align:center;padding:30px 10px}
.form-success.show{display:block}
.form-success .fs-ico{width:64px;height:64px;border-radius:50%;background:rgba(46,165,107,0.12);color:var(--green-500);display:grid;place-items:center;margin:0 auto 18px}
.form-success .fs-ico svg{width:32px;height:32px}
.form-success h3{font-size:1.5rem}
.form-success p{color:var(--ink-500);margin-top:10px}
@media(max-width:860px){.est-grid{grid-template-columns:1fr}.est-aside,.est-form{padding:34px}.form-row{grid-template-columns:1fr}}

/* =========================================================================
   FAQ
   ========================================================================= */
.faq-grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:48px;align-items:start}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item:first-child{border-top:1px solid var(--line)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 4px;text-align:left;font-family:var(--font-display);font-weight:600;font-size:1.14rem;color:var(--ink-900)}
.faq-q .fq-ico{width:30px;height:30px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;flex-shrink:0;transition:background .25s,border-color .25s,transform .3s}
.faq-q .fq-ico svg{width:16px;height:16px;color:var(--blue-600);transition:transform .3s}
.faq-item.open .fq-ico{background:var(--blue-500);border-color:var(--blue-500)}
.faq-item.open .fq-ico svg{color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a-inner{padding:0 4px 24px;color:var(--ink-500);font-size:1rem;line-height:1.6;max-width:62ch}
.faq-a-inner a{color:var(--blue-600);font-weight:600;text-decoration:underline;text-underline-offset:2px}
@media(max-width:860px){.faq-grid{grid-template-columns:1fr;gap:28px}}

/* =========================================================================
   FOOTER
   ========================================================================= */
.footer{background:var(--navy-950);color:rgba(255,255,255,0.66);padding-top:var(--s9)}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:var(--s8);border-bottom:1px solid var(--line-light)}
.foot-brand .fb-logo{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.foot-brand .fb-logo img{height:50px}
.foot-brand .fb-logo .n{font-family:var(--font-display);font-weight:800;font-size:1.2rem;color:#fff}
.foot-brand .fb-logo .n b{color:var(--blue-400)}
.foot-brand p{font-size:0.92rem;line-height:1.6;max-width:34ch;margin-bottom:20px}
.foot-contact{display:grid;gap:10px}
.foot-contact a,.foot-contact div{display:flex;align-items:center;gap:10px;font-size:0.92rem;color:rgba(255,255,255,0.8)}
.foot-contact svg{width:16px;height:16px;color:var(--blue-400);flex-shrink:0}
.foot-col h4{font-family:var(--font-mono);font-size:0.7rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.45);margin-bottom:16px;font-weight:600}
.foot-col ul{display:grid;gap:9px}
.foot-col a{font-size:0.92rem;color:rgba(255,255,255,0.72);transition:color .2s,padding .2s}
.foot-col a:hover{color:#fff;padding-left:3px}
.foot-social{display:flex;gap:10px;margin-top:6px}
.foot-social a{width:40px;height:40px;border-radius:10px;border:1px solid var(--line-light-2);display:grid;place-items:center;color:rgba(255,255,255,0.8);transition:all .2s}
.foot-social a:hover{background:var(--blue-500);border-color:var(--blue-500);color:#fff}
.foot-social a svg{width:18px;height:18px}
.foot-bot{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:26px 0;flex-wrap:wrap;font-size:0.84rem;color:rgba(255,255,255,0.5)}
.foot-bot .fb-meta{font-family:var(--font-mono);font-size:0.74rem;letter-spacing:0.04em}
.foot-bot .fb-links{display:flex;gap:20px}
.foot-bot a:hover{color:#fff}
@media(max-width:1000px){.foot-top{grid-template-columns:1fr 1fr 1fr}.foot-brand{grid-column:1/-1}}
@media(max-width:600px){.foot-top{grid-template-columns:1fr 1fr}.foot-bot{flex-direction:column;align-items:flex-start;gap:12px}}

/* mobile sticky CTA */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:50;display:none;gap:10px;padding:12px 14px;background:rgba(10,20,38,0.96);backdrop-filter:blur(10px);border-top:1px solid var(--line-light)}
.mobile-cta .btn{flex:1;padding:14px}
@media(max-width:760px){.mobile-cta{display:flex}body{padding-bottom:74px}}

/* =========================================================================
   REVEAL ANIMATION
   ========================================================================= */
@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  .reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
}

/* =========================================================================
   BREADCRUMB + SERVICE PAGE (shared with category pages)
   ========================================================================= */
.crumb{font-size:0.84rem;color:var(--ink-400);display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-family:var(--font-body)}
.crumb a{color:var(--ink-500);transition:color .2s}
.crumb a:hover{color:var(--blue-600)}
.crumb .sep{color:var(--ink-300)}
.crumb .cur{color:var(--ink-700);font-weight:600}

/* ---- Category hero ---- */
.cat-hero{position:relative;background:var(--navy-950);color:#fff;overflow:hidden;isolation:isolate}
.cat-hero .ch-bg{position:absolute;inset:0;z-index:-2}
.cat-hero .ch-bg img{width:100%;height:100%;object-fit:cover}
.cat-hero .ch-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,16,32,0.97) 0%,rgba(8,16,32,0.88) 46%,rgba(8,16,32,0.62) 78%,rgba(8,16,32,0.5) 100%)}
.cat-hero-inner{max-width:var(--maxw);margin:0 auto;padding:28px 24px clamp(52px,6vw,84px)}
.cat-hero .crumb{padding:50px 0 34px}
@media(min-width:1081px){.cat-hero .crumb{padding:64px 0 34px}}
@media(max-width:1080px){.cat-hero .crumb{padding:46px 0 32px}}
@media(max-width:560px){.cat-hero .crumb{padding:20px 0 28px}}
.cat-hero .crumb a,.cat-hero .crumb .sep{color:rgba(255,255,255,0.55)}
.cat-hero .crumb a:hover{color:#fff}
.cat-hero .crumb .cur{color:var(--blue-300)}
.cat-hero h1{font-size:clamp(2.4rem,5vw,4.2rem);letter-spacing:-0.035em;line-height:1.0;color:#fff;max-width:18ch;text-wrap:balance}
.cat-hero h1 .accent{color:var(--blue-400)}
.cat-hero .ch-sub{font-size:clamp(1.05rem,1.6vw,1.28rem);color:rgba(255,255,255,0.78);max-width:58ch;margin-top:22px;line-height:1.5}
.cat-hero .ch-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.cat-hero .ch-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:34px}
.cat-hero .ch-chips a{font-size:0.86rem;font-weight:600;color:rgba(255,255,255,0.85);background:rgba(255,255,255,0.07);border:1px solid var(--line-light-2);padding:9px 16px;border-radius:99px;transition:all .2s}
.cat-hero .ch-chips a:hover{background:var(--blue-500);border-color:var(--blue-500);color:#fff}

/* ---- Service detail rows (alternating) ---- */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:var(--s8) 0;border-bottom:1px solid var(--line)}
.svc-row:last-of-type{border-bottom:none}
.svc-row .svc-media{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);aspect-ratio:4/3.1;position:relative}
.svc-row .svc-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.svc-row:hover .svc-media img{transform:scale(1.04)}
.svc-row .svc-media .sm-tag{position:absolute;top:16px;left:16px;font-family:var(--font-mono);font-size:0.66rem;letter-spacing:0.14em;text-transform:uppercase;background:rgba(8,16,32,0.72);color:#fff;padding:6px 12px;border-radius:6px;backdrop-filter:blur(4px)}
.svc-row.flip .svc-media{order:2}
.svc-num{font-family:var(--font-mono);font-size:0.78rem;letter-spacing:0.16em;color:var(--blue-600);font-weight:600}
.svc-row h2{font-size:clamp(1.7rem,2.8vw,2.4rem);margin:14px 0 16px;letter-spacing:-0.025em}
.svc-row p{color:var(--ink-500);font-size:1.06rem;margin-bottom:20px;max-width:52ch}
.svc-list{display:grid;grid-template-columns:1fr 1fr;gap:11px 22px;margin-bottom:26px}
.svc-list li{display:flex;align-items:flex-start;gap:10px;font-size:0.96rem;color:var(--ink-800);font-weight:500}
.svc-list li svg{width:19px;height:19px;color:var(--blue-500);flex-shrink:0;margin-top:2px}
@media(max-width:860px){.svc-row{grid-template-columns:1fr;gap:30px;padding:var(--s7) 0}.svc-row.flip .svc-media{order:0}.svc-list{grid-template-columns:1fr}}

/* ---- Related services grid ---- */
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rel{display:flex;align-items:center;gap:16px;padding:20px 22px;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);transition:border-color .2s,box-shadow .2s,transform .2s}
.rel:hover{border-color:var(--blue-300);box-shadow:var(--sh-md);transform:translateY(-3px)}
.rel .rel-ico{width:46px;height:46px;border-radius:11px;background:linear-gradient(150deg,var(--navy-700),var(--navy-900));display:grid;place-items:center;color:var(--blue-300);flex-shrink:0}
.rel .rel-ico svg{width:22px;height:22px}
.rel .rel-t{font-weight:700;color:var(--ink-900);font-size:1.04rem;display:block}
.rel .rel-d{font-size:0.84rem;color:var(--ink-400);margin-top:2px;display:block}
.rel .rel-arrow{margin-left:auto;color:var(--blue-500);flex-shrink:0}
.rel .rel-arrow svg{width:18px;height:18px;transition:transform .2s}
.rel:hover .rel-arrow svg{transform:translateX(3px)}
@media(max-width:860px){.rel-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.rel-grid{grid-template-columns:1fr}}

/* ---- compact area chips ---- */
.area-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.area-chips a{font-size:0.92rem;font-weight:600;color:var(--ink-700);background:#fff;border:1px solid var(--line);padding:10px 16px;border-radius:99px;transition:all .2s;display:inline-flex;align-items:center;gap:7px}
.area-chips a svg{width:14px;height:14px;color:var(--blue-500)}
.area-chips a:hover{border-color:var(--blue-400);color:var(--blue-600);box-shadow:var(--sh-sm)}
.area-chips a.more{background:var(--navy-800);color:#fff;border-color:var(--navy-800)}
.area-chips a.more svg{color:var(--blue-300)}

/* LOGO OVERHANG — large hanging logo (no wordmark text; logo art carries the name).
   Anchored to the top of the bar so it only hangs DOWNWARD over the hero — never
   up into the utility bar. Sized to clear the hero eyebrow/headline at every width. */
.header{overflow:visible}
.brand img.brand-logo{height:138px;width:auto;align-self:flex-start;margin-top:4px;margin-left:0;filter:drop-shadow(0 12px 22px rgba(10,20,38,0.32));position:relative;z-index:3;transition:transform .25s var(--ease)}
.brand{align-self:flex-start;align-items:flex-start}
/* tablet / mobile: scale the hanging logo down so it never overruns the bar */
@media(max-width:1140px){.brand img.brand-logo{height:118px;margin-left:0}}
@media(max-width:560px){.brand img.brand-logo{height:84px;margin-top:3px;margin-left:6px}}
@media(max-width:380px){.brand img.brand-logo{height:70px;margin-left:0}}

/* AREAS WE SERVE mega */
.mega.areas-mega .mega-inner{grid-template-columns:repeat(3,1fr) 1.05fr;gap:6px 30px}
.area-menu-col h4{font-size:0.74rem;font-family:var(--font-mono);letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-400);margin-bottom:12px;font-weight:600}
.area-menu-link{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;font-weight:600;font-size:0.92rem;color:var(--ink-700);transition:background .18s,color .18s}
.area-menu-link:hover{background:var(--paper);color:var(--blue-600)}
.area-menu-link svg{width:14px;height:14px;color:var(--blue-500);flex-shrink:0}
.area-menu-link.hq{color:var(--navy-800);font-weight:700}
.area-menu-link.hq .tag{font-family:var(--font-mono);font-size:0.6rem;letter-spacing:0.1em;color:var(--blue-600);background:var(--paper-2);padding:2px 6px;border-radius:5px;margin-left:auto}

/* HUB service cards */
.hub-intro{max-width:64ch}
.svc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:border-color .25s,box-shadow .3s,transform .3s}
.svc-card:hover{border-color:var(--blue-300);box-shadow:var(--sh-lg);transform:translateY(-5px)}
.svc-card .scd-img{aspect-ratio:16/10;overflow:hidden;position:relative}
.svc-card .scd-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.svc-card:hover .scd-img img{transform:scale(1.06)}
.svc-card .scd-ico{position:absolute;left:18px;bottom:-22px;width:48px;height:48px;border-radius:12px;background:linear-gradient(150deg,var(--navy-700),var(--navy-900));display:grid;place-items:center;color:var(--blue-300);box-shadow:var(--sh-md);border:2px solid #fff}
.svc-card .scd-ico svg{width:23px;height:23px}
.svc-card .scd-body{padding:34px 24px 24px;display:flex;flex-direction:column;flex:1}
.svc-card h3{font-size:1.3rem}
.svc-card .scd-desc{color:var(--ink-500);font-size:0.95rem;margin-top:8px}
.svc-card .scd-links{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px}
.svc-card .scd-links span{font-size:0.76rem;color:var(--ink-500);background:var(--paper);border:1px solid var(--line);padding:4px 10px;border-radius:99px}
.svc-card .scd-foot{margin-top:auto;padding-top:18px}
@media(max-width:920px){.svc-cards{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.svc-cards{grid-template-columns:1fr}}

/* ABOUT / FOUNDER */
.founder{display:grid;grid-template-columns:0.82fr 1.18fr;gap:60px;align-items:start}
.founder-photo{position:relative}
.founder-photo .fp-frame{border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(160deg,var(--navy-700),var(--navy-950));box-shadow:var(--sh-lg);aspect-ratio:1}
.founder-photo .fp-frame img{width:100%;height:100%;object-fit:cover}
.founder-photo .vet-badge{position:absolute;left:-18px;bottom:24px;background:var(--blue-500);color:#fff;border-radius:var(--r-md);padding:14px 18px;box-shadow:var(--sh-blue);display:flex;align-items:center;gap:12px;max-width:240px}
.founder-photo .vet-badge svg{width:30px;height:30px;flex-shrink:0}
.founder-photo .vet-badge .vb-t{font-family:var(--font-display);font-weight:700;font-size:1rem;line-height:1.15}
.founder-photo .vet-badge .vb-d{font-size:0.76rem;opacity:0.85;margin-top:2px}
.founder-name{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin:6px 0 4px}
.founder-name h2{font-size:clamp(1.9rem,3.2vw,2.6rem);letter-spacing:-0.03em}
.founder-name .role{font-family:var(--font-mono);font-size:0.78rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--blue-600)}
.founder-bio p{color:var(--ink-600,#4a5666);font-size:1.06rem;margin-bottom:16px;max-width:60ch}
.founder-bio p .hl{color:var(--navy-700);font-weight:600}
.cred-list{display:grid;grid-template-columns:1fr 1fr;gap:12px 22px;margin:24px 0 28px}
.cred-list li{display:flex;align-items:flex-start;gap:11px;font-size:0.96rem;color:var(--ink-800);font-weight:500}
.cred-list li svg{width:20px;height:20px;color:var(--blue-500);flex-shrink:0;margin-top:1px}
@media(max-width:860px){.founder{grid-template-columns:1fr;gap:44px}.founder-photo{max-width:380px}}
@media(max-width:480px){.cred-list{grid-template-columns:1fr}}

/* local service+city callout */
.local-note{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-md);font-size:0.96rem;color:var(--ink-700);margin-bottom:8px}
.local-note svg{width:22px;height:22px;color:var(--blue-500);flex-shrink:0}
.local-note b{color:var(--navy-800)}

/* founder signature (homepage intro) */
.founder-sig{display:flex;align-items:center;gap:14px;margin:4px 0 22px;padding:12px 16px 12px 12px;background:#fff;border:1px solid var(--line);border-radius:99px;box-shadow:var(--sh-sm);max-width:430px}
.founder-sig img{width:50px;height:50px;border-radius:50%;object-fit:cover;background:var(--steel-200);flex-shrink:0}
.founder-sig .fs-name{font-family:var(--font-display);font-weight:700;color:var(--navy-800);font-size:1rem;line-height:1.1}
.founder-sig .fs-role{font-size:0.78rem;color:var(--ink-400);margin-top:2px}
.founder-sig .link-arrow{font-size:0.86rem;white-space:nowrap}
@media(max-width:480px){.founder-sig{flex-wrap:wrap;border-radius:var(--r-md)}.founder-sig .link-arrow{margin-left:0!important}}

/* =========================================================================
   LEGAL PAGES (privacy / terms)
   ========================================================================= */
.legal-hero{background:var(--navy-950)}
.legal-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% -10%,rgba(59,122,240,0.18),transparent 60%);z-index:0}
.legal-hero .cat-hero-inner{position:relative;z-index:1;padding-top:34px;padding-bottom:clamp(40px,5vw,64px)}
.legal-hero h1{font-size:clamp(2.2rem,4.6vw,3.4rem)}
.legal-updated{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-family:var(--font-mono);font-size:0.78rem;letter-spacing:0.06em;color:rgba(255,255,255,0.6)}
.legal-updated svg{width:15px;height:15px;color:var(--blue-400)}

.legal-wrap{padding-top:var(--s8)}
.legal-grid{display:grid;grid-template-columns:240px 1fr;gap:56px;align-items:start}
.legal-toc{position:sticky;top:96px}
.ltoc-inner{display:flex;flex-direction:column;gap:2px;border-left:2px solid var(--line);padding-left:2px}
.ltoc-label{font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-400);padding:0 0 10px 14px}
.legal-toc a{font-size:0.86rem;color:var(--ink-500);padding:7px 14px;border-left:2px solid transparent;margin-left:-2px;transition:color .2s,border-color .2s}
.legal-toc a:hover{color:var(--blue-600);border-color:var(--blue-400)}

.legal-body{max-width:74ch}
.legal-lead{font-size:1.12rem;color:var(--ink-700);line-height:1.6;margin-bottom:var(--s6);padding-bottom:var(--s6);border-bottom:1px solid var(--line)}
.legal-sec{margin-bottom:var(--s7);scroll-margin-top:96px}
.legal-sec h2{font-size:1.4rem;letter-spacing:-0.02em;margin-bottom:14px}
.legal-sec p{color:var(--ink-600,#4a5666);font-size:1.02rem;line-height:1.65;margin-bottom:14px}
.legal-sec a{color:var(--blue-600);font-weight:600;text-decoration:underline;text-decoration-color:var(--blue-300);text-underline-offset:3px}
.legal-list{margin:0 0 14px;display:flex;flex-direction:column;gap:11px}
.legal-list li{position:relative;padding-left:26px;color:var(--ink-600,#4a5666);font-size:1.02rem;line-height:1.6}
.legal-list li::before{content:"";position:absolute;left:6px;top:10px;width:7px;height:7px;background:var(--blue-500);clip-path:var(--plate)}
.legal-list li strong{color:var(--navy-800)}
.legal-addr{color:var(--ink-600,#4a5666);line-height:1.8}
.legal-contact{display:flex;align-items:flex-start;gap:14px;margin-top:var(--s7);padding:24px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md)}
.legal-contact svg{width:22px;height:22px;color:var(--blue-500);flex-shrink:0;margin-top:2px}
.legal-contact strong{display:block;color:var(--navy-800);font-family:var(--font-display);font-size:1.05rem;margin-bottom:3px}
.legal-contact span{color:var(--ink-500);font-size:0.96rem}
.legal-contact a{color:var(--blue-600);font-weight:600}
@media(max-width:860px){.legal-grid{grid-template-columns:1fr;gap:32px}.legal-toc{position:static;border-left:none}.ltoc-inner{flex-direction:row;flex-wrap:wrap;border-left:none;padding-left:0;gap:8px}.ltoc-label{width:100%;padding-left:0}.legal-toc a{border:1px solid var(--line);border-radius:99px;margin-left:0;padding:6px 14px;font-size:0.8rem}.legal-toc a:hover{border-color:var(--blue-400)}}
