/* ============================================================================
   Southeast Floors — styles.css
   The Multifamily Flooring Partner
   ----------------------------------------------------------------------------
   This is the single stylesheet for the custom-hosted homepage (index.html).
   It is intentionally one file: the site is a single page and keeping the CSS
   together makes it easy to scan and maintain. Sections are labeled below.

   Design tokens live in :root. Squarespace pages should mirror these same
   tokens — see /squarespace-custom-css-starter.css for the matching values.
   ========================================================================= */

:root{
  --blue:#006CA8;
  --blue-bright:#0E86C9;
  --blue-deep:#00598C;
  --blue-dark:#084C77;
  --navy:#063A5A;
  --navy-2:#08527F;
  --ink:#111418;
  --gray:#54565A;
  --paper:#FAFBFC;
  --paper-2:#EAF1F6;
  --slate:#5E6B75;
  --line:rgba(17,20,24,.12);
  --seam:#006CA8;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}

/* ---------- Type ---------- */
.display{font-family:'Archivo Expanded','Archivo',sans-serif;font-weight:800;line-height:.96;letter-spacing:-.02em;color:var(--navy)}
h1.display{font-size:clamp(2.8rem,7vw,6rem)}
h2.display{font-size:clamp(2rem,4.2vw,3.6rem)}
.eyebrow{font-family:'Archivo',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--blue-deep);display:inline-flex;align-items:center;gap:.7rem}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;opacity:.8}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--slate);line-height:1.55;max-width:60ch}

/* ---------- Buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.6rem;font-family:'Archivo',sans-serif;
  font-weight:600;font-size:.95rem;padding:16px 30px;border-radius:2px;cursor:pointer;border:none;
  overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease);z-index:0}
.btn span{position:relative;z-index:2}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn::before{content:"";position:absolute;inset:0;z-index:1;transition:transform .45s var(--ease)}
.btn-amber{background:#fff;color:var(--blue)}
.btn-amber::before{background:var(--navy);transform:translateY(101%)}
.btn-amber:hover{color:#fff}
.btn-amber:hover::before{transform:translateY(0)}
.btn-ghost{background:transparent;color:var(--paper);border:1.5px solid rgba(250,247,242,.4)}
.btn-ghost::before{background:var(--paper);transform:translateY(101%)}
.btn-ghost:hover{color:var(--navy)}
.btn-ghost:hover::before{transform:translateY(0)}
.btn-dark{background:var(--navy);color:var(--paper)}
.btn-dark::before{background:var(--blue);transform:translateY(101%)}
.btn-dark:hover{color:#fff}
.btn-dark:hover::before{transform:translateY(0)}

/* ---------- Nav ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s var(--ease),box-shadow .4s var(--ease)}
header.scrolled{background:rgba(250,247,242,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px;transition:height .4s var(--ease)}
header.scrolled .nav{height:66px}
.brand{display:flex;align-items:center;transition:opacity .4s var(--ease)}
/* Full horizontal logo: white at top (over dark hero), navy when scrolled (white bar) */
.brand .logo-full{height:46px;width:auto;flex-shrink:0;display:block;transition:height .4s var(--ease)}
header.scrolled .brand .logo-full{height:40px}
.brand .logo-full.navy{display:none}
header.scrolled .brand .logo-full.white{display:none}
header.scrolled .brand .logo-full.navy{display:block}
.menu{display:flex;align-items:center;gap:34px}
.menu a.nav-link{font-family:'Archivo',sans-serif;font-weight:600;font-size:.9rem;color:#fff;position:relative;padding:4px 0;transition:color .4s var(--ease)}
header.scrolled .menu a.nav-link{color:var(--navy)}
.menu a.nav-link::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.menu a.nav-link:hover::after{transform:scaleX(1)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav-burger span{width:24px;height:2px;background:#fff;transition:.3s}
header.scrolled .nav-burger span{background:var(--navy)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:var(--blue);overflow:hidden}
.hero-planks{position:absolute;inset:0;z-index:0}
.hero-planks .plank{position:absolute;left:0;right:0;background:linear-gradient(90deg,var(--blue),var(--blue-deep));
  border-top:1px solid rgba(201,154,91,.08);transform:translateX(-100%);}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse at 25% 35%,rgba(14,134,201,.45),transparent 60%),
             linear-gradient(120deg,rgba(6,40,62,.55),rgba(0,108,168,.15))}
.hero-inner{position:relative;z-index:3;width:100%;padding:120px 0 80px}
.hero h1{color:var(--paper)}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line>span{display:block;transform:translateY(110%);transition:transform .9s var(--ease)}
.hero.in h1 .line>span{transform:translateY(0)}
.hero h1 .line:nth-child(2)>span{transition-delay:.12s}
.hero h1 .line:nth-child(3)>span{transition-delay:.24s}
.hero h1 .accent{color:#BFE3F5}
.hero-sub{max-width:52ch;color:#C9D6DF;font-size:1.18rem;margin-top:1.8rem;opacity:0;transform:translateY(20px);
  transition:opacity .8s var(--ease) .5s,transform .8s var(--ease) .5s}
.hero.in .hero-sub{opacity:1;transform:none}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:2.4rem;opacity:0;transform:translateY(20px);
  transition:opacity .8s var(--ease) .65s,transform .8s var(--ease) .65s}
.hero.in .hero-cta{opacity:1;transform:none}
.hero-meta{position:absolute;bottom:38px;left:0;right:0;z-index:3}
.hero-meta .wrap{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}
.hero-since{font-family:'Archivo Expanded',sans-serif;font-weight:700;color:rgba(250,247,242,.5);font-size:.8rem;letter-spacing:.2em}
.hero-scroll{display:flex;align-items:center;gap:10px;color:rgba(250,247,242,.55);font-family:'Archivo',sans-serif;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase}
.hero-scroll .dot{width:22px;height:34px;border:1.5px solid rgba(250,247,242,.4);border-radius:12px;position:relative}
.hero-scroll .dot::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:2px;background:var(--blue);transform:translateX(-50%);animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}}

/* ---------- Marquee ---------- */
.marquee{background:var(--blue);overflow:hidden;padding:14px 0;border-top:3px solid var(--navy);border-bottom:3px solid var(--navy)}
.marquee-track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:marq 32s linear infinite}
.marquee-track span{font-family:'Archivo Expanded',sans-serif;font-weight:800;font-size:1.05rem;color:#fff;
  text-transform:uppercase;letter-spacing:.04em;padding:0 26px;display:inline-flex;align-items:center;gap:26px}
.marquee-track span::after{content:"◆";font-size:.6rem;color:rgba(255,255,255,.55)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- Section scaffolding ---------- */
section{position:relative}
.pad{padding:120px 0}
.seam{position:absolute;left:50%;top:0;bottom:0;width:1px;background:repeating-linear-gradient(to bottom,var(--seam) 0 8px,transparent 8px 18px);opacity:.25;z-index:0}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-plank{clip-path:inset(0 100% 0 0);transition:clip-path 1s var(--ease)}
.reveal-plank.in{clip-path:inset(0 0 0 0)}
.sec-head{max-width:760px;margin-bottom:64px}
.sec-head h2{margin-top:18px}
.sec-head .lead{margin-top:20px}

/* ---------- Value cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.vcard{background:var(--paper);padding:38px 30px;position:relative;transition:background .4s var(--ease);overflow:hidden}
.vcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease)}
.vcard:hover{background:var(--blue)}
.vcard:hover::before{transform:scaleY(1)}
.vcard:hover .vc-num,.vcard:hover h3,.vcard:hover p{color:var(--paper)}
.vcard:hover .vc-num{color:#BFE3F5}
.vc-num{font-family:'Archivo Expanded',sans-serif;font-weight:800;font-size:.85rem;color:var(--blue-deep);letter-spacing:.1em;transition:color .4s var(--ease)}
.vcard h3{font-family:'Archivo',sans-serif;font-weight:700;font-size:1.22rem;color:var(--navy);margin:18px 0 12px;transition:color .4s var(--ease)}
.vcard p{font-size:.95rem;color:var(--slate);transition:color .4s var(--ease)}

/* ---------- Services / plank list ---------- */
.svc-sec{background:var(--blue);color:var(--paper)}
.svc-sec .eyebrow{color:#BFE3F5}
.svc-sec h2{color:var(--paper)}
.svc-list{margin-top:20px;border-top:1px solid rgba(250,247,242,.14)}
.svc-row{display:grid;grid-template-columns:80px 1fr auto;gap:24px;align-items:center;padding:30px 16px;
  border-bottom:1px solid rgba(250,247,242,.14);position:relative;cursor:default;transition:padding .4s var(--ease)}
.svc-row::before{content:"";position:absolute;inset:0;background:var(--blue-deep);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);z-index:0}
.svc-row:hover::before{transform:scaleX(1)}
.svc-row:hover{padding-left:30px}
.svc-row>*{position:relative;z-index:1}
.svc-row .n{font-family:'Archivo Expanded',sans-serif;font-weight:700;color:#BFE3F5;font-size:.9rem}
.svc-row h3{font-family:'Archivo',sans-serif;font-weight:600;font-size:clamp(1.3rem,2.4vw,1.9rem);color:var(--paper)}
.svc-row p{color:#A9BAC5;font-size:.95rem;max-width:46ch;margin-top:4px}
.svc-row .plus{width:42px;height:42px;border:1px solid rgba(250,247,242,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--blue);transition:.4s var(--ease)}
.svc-row:hover .plus{background:#fff;color:var(--blue);border-color:var(--blue);transform:rotate(90deg)}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-since{font-family:'Archivo Expanded',sans-serif;font-weight:900;font-size:clamp(4rem,9vw,7rem);line-height:.9;color:var(--blue);letter-spacing:-.02em}
.about-since small{display:block;font-family:'Archivo',sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.24em;color:var(--slate);margin-top:8px;text-transform:uppercase}
.values{margin-top:40px;display:grid;gap:0}
.value{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;padding:26px 0;border-top:1px solid var(--line)}
.value:last-child{border-bottom:1px solid var(--line)}
.value .vk{font-family:'Archivo Expanded',sans-serif;font-weight:800;font-size:1.1rem;color:var(--blue)}
.value h4{font-family:'Archivo',sans-serif;font-weight:700;font-size:1.15rem;color:var(--navy);margin-bottom:4px}
.value p{font-size:.96rem;color:var(--slate)}

/* ---------- Team ---------- */
.team-sec{background:var(--paper-2)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.tmember{background:var(--paper);border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:.4s var(--ease)}
.tmember:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(6,58,90,.12)}
.tmember .photo{aspect-ratio:1/1;background:linear-gradient(150deg,var(--blue),var(--blue-deep));position:relative;display:flex;align-items:center;justify-content:center}
.tmember .photo .initials{font-family:'Archivo Expanded',sans-serif;font-weight:800;font-size:2.4rem;color:rgba(255,255,255,.85)}
.tmember .photo .pseam{position:absolute;left:0;right:0;bottom:0;height:4px;background:repeating-linear-gradient(90deg,#fff 0 10px,transparent 10px 20px);opacity:.4}
.tmember .meta{padding:22px 22px 26px}
.tmember h4{font-family:'Archivo',sans-serif;font-weight:700;font-size:1.1rem;color:var(--navy)}
.tmember .role{font-size:.88rem;color:var(--blue-deep);font-weight:600;margin-top:2px}
.tmember .bio{font-size:.9rem;color:var(--slate);margin-top:12px}

/* ---------- Projects gallery ---------- */
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.gal-item{position:relative;aspect-ratio:4/3;border-radius:4px;overflow:hidden;cursor:pointer;background:var(--navy)}
.gal-item .ph{position:absolute;inset:0;background:linear-gradient(150deg,var(--blue),var(--blue-deep));transition:transform .6s var(--ease)}
.gal-item .ph.alt{background:linear-gradient(150deg,var(--blue-deep),var(--navy))}
.gal-item .ph .planks{position:absolute;inset:0;opacity:.5;background:repeating-linear-gradient(0deg,transparent 0 22px,rgba(255,255,255,.05) 22px 23px)}
.gal-item .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,40,62,.85),transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:22px;transition:.4s var(--ease)}
.gal-item .ov .ptype{font-family:'Archivo',sans-serif;font-weight:700;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:#BFE3F5;margin-bottom:6px}
.gal-item .ov h4{font-family:'Archivo',sans-serif;font-weight:700;font-size:1.1rem;color:#fff}
.gal-item .ov .loc{font-size:.85rem;color:#DCEEF8;margin-top:2px}
.gal-item:hover .ph{transform:scale(1.06)}
.gal-cta{text-align:center;margin-top:44px}

/* ---------- Products & Partners ---------- */
.prod-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}
.prod-card{position:relative;border-radius:4px;padding:44px 40px;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;min-height:320px}
.prod-card.national{background:var(--paper-2);border:1px solid var(--line)}
.prod-card.house{background:var(--blue);color:#fff}
.prod-card .pc-eyebrow{font-family:'Archivo',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-deep)}
.prod-card.house .pc-eyebrow{color:#BFE3F5}
.prod-card h3{font-family:'Archivo Expanded',sans-serif;font-weight:800;font-size:1.7rem;color:var(--navy);margin:16px 0 12px;line-height:1.05}
.prod-card.house h3{color:#fff}
.prod-card p{font-size:1rem;color:var(--slate);max-width:46ch}
.prod-card.house p{color:#DCEEF8}
.mills{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.mill{font-family:'Archivo Expanded',sans-serif;font-weight:700;font-size:.95rem;letter-spacing:.02em;color:var(--navy);
  background:#fff;border:1px solid var(--line);border-radius:3px;padding:12px 20px}
.rebate-tag{display:inline-flex;align-items:center;gap:8px;margin-top:24px;font-family:'Archivo',sans-serif;font-weight:600;font-size:.9rem;color:var(--blue-deep)}
.rebate-tag::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 4px rgba(0,108,168,.18)}
.house-badge{align-self:flex-start;margin-top:26px;font-family:'Archivo',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);border-radius:2px;padding:10px 18px;color:#fff}
.grow-note{display:flex;gap:20px;align-items:flex-start;max-width:840px;margin:32px auto 0;padding:26px 30px;background:var(--paper-2);border:1px solid var(--line);border-radius:4px}
.grow-note .grow-ic{flex-shrink:0;width:44px;height:44px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;color:#fff}
.grow-note .grow-ic svg{width:22px;height:22px}
.grow-note p{font-size:.98rem;color:var(--slate);line-height:1.6}
.grow-note p strong{color:var(--navy);font-weight:700}
.ptl{position:relative;max-width:820px;margin:60px auto 0;padding-left:20px}
.ptl-line{position:absolute;left:51px;top:14px;bottom:60px;width:2px;
  background:repeating-linear-gradient(to bottom,var(--blue) 0 8px,transparent 8px 18px);opacity:.4}
.pstage{display:grid;grid-template-columns:64px 1fr;gap:30px;align-items:start;padding-bottom:48px;position:relative}
.pstage:last-child{padding-bottom:0}
.pstage-num{width:64px;height:64px;border-radius:50%;background:var(--paper);border:2px solid var(--blue);
  display:flex;align-items:center;justify-content:center;font-family:'Archivo Expanded',sans-serif;
  font-weight:800;font-size:1.05rem;color:var(--blue);position:relative;z-index:2;transition:.4s var(--ease)}
.pstage:hover .pstage-num{background:var(--blue);color:#fff;transform:scale(1.06)}
.pstage-body{padding-top:8px}
.pstage-body h3{font-family:'Archivo',sans-serif;font-weight:700;font-size:clamp(1.2rem,2vw,1.5rem);color:var(--navy);margin-bottom:10px}
.pstage-body p{font-size:1rem;color:var(--slate);max-width:60ch}

/* ---------- Stats counter ---------- */
.stats-sec{background:var(--blue);position:relative;overflow:hidden}
.stats-sec .plankbg{position:absolute;inset:0;opacity:.4;
  background:repeating-linear-gradient(0deg,transparent 0 58px,rgba(201,154,91,.06) 58px 59px)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;position:relative;z-index:2}
.stat{text-align:center}
.stat .num{font-family:'Archivo Expanded',sans-serif;font-weight:900;font-size:clamp(3rem,6vw,5rem);color:var(--paper);line-height:1}
.stat .num .suf{color:#BFE3F5}
.stat .lbl{font-family:'Archivo',sans-serif;font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:#8CA0AC;margin-top:14px}

/* ---------- Difference / split ---------- */
.diff{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center}
.diff-list{margin-top:30px;display:grid;gap:2px}
.ditem{display:flex;gap:20px;padding:22px 0;border-top:1px solid var(--line);align-items:flex-start}
.ditem:last-child{border-bottom:1px solid var(--line)}
.ditem .ic{width:46px;height:46px;flex-shrink:0;border-radius:3px;background:var(--paper-2);display:flex;align-items:center;justify-content:center;color:var(--blue-deep)}
.ditem .ic svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8}
.ditem h4{font-family:'Archivo',sans-serif;font-weight:700;font-size:1.08rem;color:var(--navy);margin-bottom:4px}
.ditem p{font-size:.93rem;color:var(--slate)}
.diff-visual{position:relative;aspect-ratio:4/5;border-radius:4px;overflow:hidden;background:var(--navy)}
.diff-visual .planks{position:absolute;inset:0}
.diff-visual .pl{position:absolute;left:0;right:0;height:12.5%;background:linear-gradient(100deg,#16384d,var(--navy-2),var(--navy));border-bottom:1px solid rgba(201,154,91,.1)}
.diff-visual .badge{position:absolute;bottom:26px;left:26px;right:26px;background:rgba(250,247,242,.95);backdrop-filter:blur(6px);padding:24px;border-radius:3px;z-index:2}
.diff-visual .badge .big{font-family:'Archivo Expanded',sans-serif;font-weight:800;font-size:2.6rem;color:var(--navy);line-height:1}
.diff-visual .badge .small{font-size:.85rem;color:var(--slate);margin-top:6px}

/* ---------- Map / coverage ---------- */
.cov{background:var(--paper-2)}
.cov-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.markets{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.mchip{font-family:'Archivo',sans-serif;font-weight:600;font-size:.9rem;color:var(--navy);background:var(--paper);
  border:1px solid var(--line);padding:11px 20px;border-radius:2px;transition:.3s var(--ease);cursor:default}
.mchip:hover{background:var(--navy);color:var(--paper);transform:translateY(-3px)}
.map-frame{aspect-ratio:1/1;background:var(--navy);border-radius:4px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.leaflet-map{position:absolute;inset:0;width:100%;height:100%;background:#E8EDF1;z-index:1;border-radius:4px}
/* Tame Leaflet attribution (the flag emoji was rendering oversized) */
.map-frame .leaflet-control-attribution{font-size:10px;background:rgba(255,255,255,.85)}
.map-frame .leaflet-control-attribution img,.map-frame .leaflet-attribution-flag{display:none!important;width:0!important;height:0!important}
.svc-map-fallback{position:absolute;width:92%;height:92%;z-index:0}
.leaflet-map.failed{display:none}
.sef-marker{background:var(--blue-bright);width:18px;height:18px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.35)}
.sef-pop{font-family:'Inter',sans-serif}
.sef-pop b{font-family:'Archivo',sans-serif;font-weight:700;color:var(--navy);font-size:.92rem}
.sef-pop span{display:block;color:var(--slate);font-size:.82rem;margin-top:2px}
.sef-pop a{display:inline-block;margin-top:6px;color:var(--blue);font-weight:600;font-size:.8rem}
.leaflet-popup-content-wrapper{border-radius:4px}
.map-frame svg{width:92%;height:92%}
.map-frame .mlabel{position:absolute;top:18px;right:18px;left:auto;font-family:'Archivo',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-deep);z-index:500;background:rgba(255,255,255,.82);padding:6px 12px;border-radius:3px;backdrop-filter:blur(4px)}
.svc-map .state{fill:#0A5276;stroke:#1E6FA0;stroke-width:.8;stroke-linejoin:round}
.mdot{fill:var(--blue-bright);cursor:pointer;transition:.3s;stroke:#fff;stroke-width:1}
.mdot:hover{fill:#fff;r:8}
.mpulse{fill:var(--blue-bright);opacity:.5;animation:mpulse 2.4s infinite}
.mcity{font-family:'Archivo',sans-serif;font-weight:600;font-size:7px;fill:#DCEEF8;letter-spacing:.02em;pointer-events:none}
@keyframes mpulse{0%{r:6;opacity:.5}100%{r:20;opacity:0}}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.qcard{background:var(--paper);border:1px solid var(--line);padding:36px 32px;border-radius:3px;position:relative;transition:.4s var(--ease)}
.qcard:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(12,36,51,.1)}
.qcard .mk{font-family:'Archivo Expanded',sans-serif;font-weight:900;font-size:3.4rem;color:var(--blue);line-height:.6;height:34px}
.qcard p{color:var(--ink);font-size:1.02rem;margin:14px 0 20px}
.qcard .who{font-family:'Archivo',sans-serif;font-weight:700;color:var(--navy);font-size:.92rem}
.qcard .who span{display:block;font-weight:500;color:var(--slate);font-size:.82rem;margin-top:2px}

/* ---------- CTA ---------- */
.cta{background:var(--blue);position:relative;overflow:hidden;text-align:center}
.cta .glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(201,154,91,.18),transparent 70%);top:-200px;left:50%;transform:translateX(-50%)}
.cta h2{color:var(--paper);position:relative}
.cta .lead{color:#B6C5CF;margin:20px auto 0;text-align:center}
.cta .btn-row{display:flex;gap:14px;justify-content:center;margin-top:36px;position:relative;flex-wrap:wrap}

/* ---------- Footer ---------- */
footer{background:#08161F;color:#8CA0AC;padding:80px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;padding-bottom:50px;border-bottom:1px solid rgba(250,247,242,.1)}
footer h4{font-family:'Archivo',sans-serif;color:var(--paper);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}
footer a{display:block;padding:6px 0;color:#8CA0AC;font-size:.92rem;transition:color .2s,padding-left .2s}
footer a:hover{color:var(--blue);padding-left:5px}
.foot-brand .display{color:var(--paper);font-size:1.4rem;margin-bottom:14px}
.foot-brand p{font-size:.92rem;max-width:32ch;color:#8CA0AC}
.foot-brand .mission{color:var(--blue);font-style:italic;margin-top:14px;font-size:.95rem}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:28px;font-size:.82rem;color:#5C7080}

/* ---------- Modal (contact) ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(8,22,31,.7);backdrop-filter:blur(6px);z-index:200;
  display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .35s}
.modal-bg.open{opacity:1;pointer-events:auto}
.modal{background:var(--paper);max-width:560px;width:100%;border-radius:4px;padding:44px;position:relative;
  max-height:90vh;overflow-y:auto;transform:translateY(30px) scale(.98);transition:transform .4s var(--ease)}
.modal-bg.open .modal{transform:none}
.modal .x{position:absolute;top:20px;right:20px;width:38px;height:38px;border:none;background:var(--paper-2);border-radius:50%;cursor:pointer;font-size:1.2rem;color:var(--navy)}
.modal h3{font-family:'Archivo Expanded',sans-serif;font-weight:800;font-size:1.6rem;color:var(--navy);margin-bottom:8px}
.modal .fgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}
.fld{display:flex;flex-direction:column;gap:6px}
.fld.full{grid-column:1/-1}
.fld label{font-family:'Archivo',sans-serif;font-weight:600;font-size:.78rem;color:var(--navy)}
.fld input,.fld select,.fld textarea{font-family:'Inter',sans-serif;font-size:.95rem;padding:12px 14px;border:1px solid var(--line);border-radius:3px;background:#fff;color:var(--ink)}
.fld textarea{min-height:90px;resize:vertical}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:2px solid var(--blue);border-color:var(--blue)}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal,.reveal-plank{opacity:1!important;transform:none!important;clip-path:none!important}
  .hero h1 .line>span{transform:none!important}
  .hero-sub,.hero-cta{opacity:1!important;transform:none!important}
}

/* ===========================================================================
   INNER-PAGE HERO (compact header band for About/Services/Coverage/etc.)
   Home keeps the full-height .hero; inner pages use .page-hero.
   ======================================================================== */
.page-hero{position:relative;background:var(--blue);overflow:hidden;
  padding:150px 0 70px;color:var(--paper)}
.page-hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse at 25% 35%,rgba(14,134,201,.40),transparent 60%),
             linear-gradient(120deg,rgba(6,40,62,.55),rgba(0,108,168,.12))}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .eyebrow{color:#BFE3F5}
.page-hero h1{color:var(--paper);margin-top:18px;font-size:clamp(2.4rem,5.2vw,4rem)}
.page-hero .lead{color:#C9D6DF;margin-top:18px;max-width:62ch}
.page-hero .crumbs{font-family:'Archivo',sans-serif;font-weight:600;font-size:.82rem;
  letter-spacing:.04em;color:rgba(250,247,242,.7);margin-top:22px}
.page-hero .crumbs a{color:#BFE3F5}
.page-hero .crumbs a:hover{text-decoration:underline}

/* Active nav link (current page) */
.menu a.nav-link.active{color:#BFE3F5}
header.scrolled .menu a.nav-link.active{color:var(--blue)}
.menu a.nav-link.active::after{transform:scaleX(1)}

/* ===========================================================================
   RESPONSIVE — layered breakpoints so every grid stacks gracefully
   ======================================================================== */

/* --- Tablet / small laptop --- */
@media (max-width:1000px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .diff,.cov-grid,.about-grid{grid-template-columns:1fr;gap:48px}
  .quotes{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr);gap:40px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .prod-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
}

/* --- Show the burger / hide the inline menu earlier (nav has many items) --- */
@media (max-width:860px){
  .menu{position:fixed;inset:0;width:100%;height:100%;min-height:100vh;
    background:var(--navy);background-color:#063A5A;
    flex-direction:column;align-items:center;justify-content:center;gap:30px;
    transform:translateX(100%);transition:transform .4s var(--ease);
    z-index:1000;padding:80px 24px 40px;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .menu.open{transform:none}
  /* Mobile menu links are ALWAYS white — beat header.scrolled .nav-link (navy),
     which would otherwise render navy-on-navy and vanish on inner pages. */
  header .menu a.nav-link,
  header.scrolled .menu a.nav-link{color:var(--paper);font-size:1.4rem}
  header.scrolled .menu a.nav-link.active{color:#BFE3F5}
  .menu .btn{font-size:1.05rem}
  .nav-burger{display:flex;z-index:1001;position:relative}
  .nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);background:var(--paper)}
  .nav-burger.open span:nth-child(2){opacity:0}
  .nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:var(--paper)}
  /* When the menu is open, keep the header bar from painting a translucent strip over it */
  body.menu-open header.scrolled{background:transparent;box-shadow:none;backdrop-filter:none}
}

/* --- Phones --- */
@media (max-width:680px){
  .wrap{padding:0 20px}
  .pad{padding:72px 0}
  .page-hero{padding:120px 0 52px}
  .cards{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr;gap:32px}
  .team-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr}
  .svc-row{grid-template-columns:44px 1fr;gap:14px;padding:24px 12px}
  .svc-row .plus{display:none}
  .svc-row:hover{padding-left:12px}
  .foot-grid{grid-template-columns:1fr;gap:32px}
  .modal .fgrid{grid-template-columns:1fr}
  .about-since{font-size:clamp(3.2rem,16vw,5rem)}
  .hero-cta,.cta .btn-row,.btn-row{flex-direction:column;align-items:stretch}
  .hero-cta .btn,.cta .btn-row .btn,.btn-row .btn{justify-content:center;width:100%}
  .hero-meta .wrap{flex-direction:column;align-items:flex-start;gap:10px}
  .sec-head{margin-bottom:44px}
  .prod-card{padding:32px 26px;min-height:auto}
  .grow-note{flex-direction:column;gap:14px}
  .mills{gap:8px}
}

/* --- Very small phones --- */
@media (max-width:380px){
  .wrap{padding:0 16px}
  .brand .logo-full{height:38px}
}

/* ---------- Request Service modal: submit + status states ---------- */
/* (Base modal styles are defined above under "Modal (contact)".) */
.modal .modal-foot{display:flex;align-items:center;gap:14px;margin-top:26px;flex-wrap:wrap}
.modal .modal-foot .btn{min-width:170px;justify-content:center}
.modal .form-note{font-size:.82rem;color:var(--slate);margin-top:6px}

/* Inline status banner shown after a submit attempt */
.form-status{display:none;margin-top:18px;padding:14px 16px;border-radius:3px;font-size:.92rem;line-height:1.5;
  font-family:'Inter',sans-serif}
.form-status.show{display:block}
.form-status.success{background:#E7F5EC;border:1px solid #B7E0C5;color:#1B5E33}
.form-status.error{background:#FBEBEC;border:1px solid #F0C2C5;color:#8A2A2F}

/* Busy state — applied to the form while a submit is in flight */
.modal form.is-submitting{opacity:.6;pointer-events:none}
.btn[disabled]{opacity:.55;cursor:not-allowed}

/* A tiny spinner for the submit button while sending */
.btn .spin{width:15px;height:15px;border:2px solid currentColor;border-right-color:transparent;
  border-radius:50%;display:none;animation:btnspin .7s linear infinite}
.btn.is-loading .spin{display:inline-block}
.btn.is-loading .arr{display:none}
@keyframes btnspin{to{transform:rotate(360deg)}}

/* Required-field marker */
.fld label .req{color:var(--blue-deep);margin-left:2px}

/* ---------- Logo images (now real files, not base64) ---------- */
/* The brand mark swaps white <-> blue when the header gains .scrolled.
   The display rules for .brand .logo-full.navy / .white live in the Nav section
   above; these images just need a sensible default object-fit, already set. */
@media (prefers-reduced-motion:reduce){
  .btn .spin{animation:none!important}
}
