/* ============================================================
   Bluehawk Construction — marketing site
   Tokens lifted from the Flutter app (app_colors / app_typography / app_tokens)
   ============================================================ */

@font-face { font-family:'Geist'; src:url('assets/fonts/Geist-Regular.ttf') format('truetype'); font-weight:400; font-display:swap; }
@font-face { font-family:'Geist'; src:url('assets/fonts/Geist-Medium.ttf') format('truetype'); font-weight:500; font-display:swap; }
@font-face { font-family:'Geist'; src:url('assets/fonts/Geist-SemiBold.ttf') format('truetype'); font-weight:600; font-display:swap; }
@font-face { font-family:'GeistMono'; src:url('assets/fonts/GeistMono-Regular.ttf') format('truetype'); font-weight:400; font-display:swap; }
@font-face { font-family:'GeistMono'; src:url('assets/fonts/GeistMono-Medium.ttf') format('truetype'); font-weight:500; font-display:swap; }

:root{
  /* brand */
  --navy:#082744; --navy2:#0A3764; --royal:#2D63D9; --royal700:#1F4FB8;
  --royal100:#E8EEFB; --royal50:#F3F6FD; --sky:#6B9CFE;
  /* ink */
  --ink900:#0B1426; --ink800:#14213B; --ink700:#1F2E47; --ink500:#4A5A77;
  --ink400:#7A8AA3; --ink300:#A9B4C6; --ink200:#C8D0DD; --ink100:#E6EBF2;
  /* surface */
  --bg:#FFFFFF; --surface:#FFFFFF; --surface2:#F6F8FB;
  --divider:#ECEFF4; --dividerStrong:#DEE3EC;
  /* radii */
  --r-xs:6px; --r-sm:10px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-pill:999px;
  /* shadow */
  --sh1:0 1px 2px rgba(11,20,38,.05);
  --sh2:0 1px 2px rgba(11,20,38,.05), 0 4px 12px rgba(11,20,38,.05);
  --sh3:0 2px 4px rgba(11,20,38,.06), 0 12px 32px rgba(11,20,38,.08);
  --sh-lift:0 18px 50px rgba(8,39,68,.16);
  /* page tone (tweakable) */
  --page:#FFFFFF;
  --maxw:1200px;
  --ease:cubic-bezier(.2,.7,.3,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
html,body{overflow-x:hidden;}
body{
  margin:0; background:var(--page); color:var(--ink900);
  font-family:'Geist',system-ui,sans-serif; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-size:17px; line-height:1.5;
}
img{display:block; max-width:100%;}
a{color:inherit; text-decoration:none;}
h1,h2,h3,h4,p{margin:0;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 32px;}

/* type helpers */
.eyebrow{
  font-family:'GeistMono',monospace; font-weight:500; font-size:12px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--royal);
}
.mono{font-family:'GeistMono',monospace; font-feature-settings:"tnum";}
.lead{font-size:21px; line-height:1.55; color:var(--ink500); font-weight:400; text-wrap:pretty;}
h2.section-title{
  font-weight:600; font-size:clamp(30px,4vw,46px); line-height:1.05;
  letter-spacing:-.022em; color:var(--ink900); text-wrap:balance;
}
h3{font-weight:600; letter-spacing:-.01em; color:var(--ink900);}

/* ── buttons ── */
.btn{
  display:inline-flex; align-items:center; gap:9px; font-family:'Geist';
  font-weight:500; font-size:15px; letter-spacing:-.01em; cursor:pointer;
  padding:13px 22px; border-radius:var(--r-pill); border:1px solid transparent;
  transition:transform .18s var(--ease), background .18s var(--ease), box-shadow .18s var(--ease), color .18s var(--ease), border-color .18s var(--ease);
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--royal); color:#fff; box-shadow:0 1px 2px rgba(31,79,184,.4);}
.btn-primary:hover{background:var(--royal700);}
.btn-ghost{background:transparent; color:var(--ink900); border-color:var(--dividerStrong);}
.btn-ghost:hover{border-color:var(--ink400); background:var(--surface2);}
.btn-light{background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.32); backdrop-filter:blur(8px);}
.btn-light:hover{background:rgba(255,255,255,.22);}
.btn-on-dark{background:#fff; color:var(--navy);}
.btn-on-dark:hover{background:#eef2f8;}
.arrow{transition:transform .18s var(--ease);}
.btn:hover .arrow{transform:translateX(3px);}

/* ── header ── */
header{
  position:fixed; top:0; left:0; right:0; z-index:60;
  transition:background .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
  border-bottom:1px solid transparent;
}
header .wrap{display:flex; align-items:center; justify-content:space-between; height:74px;}
.brand{display:flex; align-items:center; gap:11px;}
.brand .mark{height:26px; width:auto; transition:filter .3s var(--ease);}
.brand .wordmark{
  font-weight:600; font-size:20px; letter-spacing:.02em; color:#fff;
  transition:color .3s var(--ease);
}
nav.main{display:flex; align-items:center; gap:38px;}
nav.main a{
  font-size:15px; font-weight:500; letter-spacing:.005em; color:rgba(255,255,255,.82); position:relative; padding:6px 2px;
  transition:color .2s var(--ease);
}
nav.main a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:1.5px; background:currentColor;
  transform:scaleX(0); transform-origin:left; transition:transform .22s var(--ease); opacity:.7;
}
nav.main a:hover{color:#fff;}
nav.main a:hover::after{transform:scaleX(1);}
.header-cta{margin-left:12px;}

/* scrolled state — solid white header */
header.solid{background:rgba(255,255,255,.86); backdrop-filter:saturate(140%) blur(14px); border-bottom-color:var(--divider); box-shadow:var(--sh1);}
header.solid .brand .mark{filter:none;}
header.solid .brand .wordmark{color:var(--ink900);}
header.solid nav.main a{color:var(--ink500);}
header.solid nav.main a:hover{color:var(--ink900);}
header.solid .btn-light{background:var(--royal); color:#fff; border-color:transparent; backdrop-filter:none;}
header.solid .btn-light:hover{background:var(--royal700);}

.menu-toggle{display:none; background:none; border:0; cursor:pointer; padding:8px; color:#fff;}
header.solid .menu-toggle{color:var(--ink900);}

/* ── hero ── */
.hero{position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden;}
.hero .bg{position:absolute; inset:0; z-index:0;}
.hero image-slot{width:100%; height:100%;}
.hero .scrim{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(8,39,68,.5) 0%, rgba(8,39,68,.34) 38%, rgba(8,39,68,.34) 60%, rgba(8,39,68,.6) 100%);
}
.hero .hero-inner{position:relative; z-index:2; width:100%; padding-bottom:64px; padding-top:104px;}
.hero-eyebrow{color:#fff; opacity:.9; margin-bottom:20px; display:flex; align-items:center; gap:12px;}
.hero-eyebrow::before{content:""; width:30px; height:1.5px; background:var(--sky);}
.hero h1{
  color:#fff; font-weight:600; letter-spacing:-.03em; line-height:.98;
  font-size:clamp(44px,7.4vw,98px); max-width:16ch; text-wrap:balance;
  text-shadow:0 2px 40px rgba(8,39,68,.4);
}
.hero .sub{color:rgba(255,255,255,.9); font-size:clamp(17px,1.6vw,21px); max-width:50ch; margin-top:24px; line-height:1.5; text-wrap:pretty;}
.hero .cta-row{display:flex; gap:14px; margin-top:36px; flex-wrap:wrap;}
.hero-stats{
  display:flex; gap:0; margin-top:56px; border-top:1px solid rgba(255,255,255,.22);
  padding-top:26px; max-width:680px; flex-wrap:wrap;
}
.hero-stats .stat{padding-right:48px; margin-right:48px; border-right:1px solid rgba(255,255,255,.18);}
.hero-stats .stat:last-child{border-right:0; margin-right:0; padding-right:0;}
.hero-stats .num{font-family:'GeistMono'; font-weight:500; font-size:38px; color:#fff; letter-spacing:-.02em; line-height:1;}
.hero-stats .lbl{color:rgba(255,255,255,.72); font-size:13px; margin-top:8px; letter-spacing:.01em;}

/* hero variant: centered */
[data-hero="center"] .hero{align-items:center; text-align:center;}
[data-hero="center"] .hero .scrim{background:linear-gradient(180deg, rgba(8,39,68,.5) 0%, rgba(8,39,68,.3) 50%, rgba(8,39,68,.62) 100%);}
[data-hero="center"] .hero .hero-inner{padding-bottom:0; padding-top:0; display:flex; flex-direction:column; align-items:center;}
[data-hero="center"] .hero-eyebrow{justify-content:center;}
[data-hero="center"] .hero-eyebrow::after{content:""; width:30px; height:1.5px; background:var(--sky);}
[data-hero="center"] .hero h1{max-width:18ch;}
[data-hero="center"] .hero .sub{margin-left:auto; margin-right:auto;}
[data-hero="center"] .hero .cta-row{justify-content:center;}
[data-hero="center"] .hero-stats{margin-left:auto; margin-right:auto; justify-content:center;}

/* hero variant: split — keeps content vertically centered (default) */
[data-hero="split"] .hero{align-items:stretch; min-height:100svh;}
[data-hero="split"] .hero .bg{left:auto; right:0; width:46%;}
[data-hero="split"] .hero .scrim{left:auto; right:0; width:46%; background:linear-gradient(90deg, var(--page) 0%, rgba(8,39,68,0) 40%);}
[data-hero="split"] .hero .hero-inner{display:flex; align-items:center; padding-top:120px; padding-bottom:64px;}
[data-hero="split"] .hero .hero-text{max-width:60%;}
[data-hero="split"] .hero h1{color:var(--ink900); text-shadow:none; font-size:clamp(40px,5.4vw,76px);}
[data-hero="split"] .hero-eyebrow{color:var(--royal); opacity:1;}
[data-hero="split"] .hero .sub{color:var(--ink500);}
[data-hero="split"] .hero-stats{border-top-color:var(--divider);}
[data-hero="split"] .hero-stats .stat{border-right-color:var(--dividerStrong);}
[data-hero="split"] .hero-stats .num{color:var(--ink900);}
[data-hero="split"] .hero-stats .lbl{color:var(--ink400);}
@media (max-width:880px){
  /* split collapses to a full-bleed dark hero so white text stays legible */
  [data-hero="split"] .hero .bg{left:0; right:0; width:100%;}
  [data-hero="split"] .hero .scrim{left:0; right:0; width:100%; background:linear-gradient(180deg, rgba(8,39,68,.5) 0%, rgba(8,39,68,.34) 38%, rgba(8,39,68,.34) 60%, rgba(8,39,68,.6) 100%);}
  [data-hero="split"] .hero .hero-inner{align-items:flex-end;}
  [data-hero="split"] .hero .hero-text{max-width:100%;}
  [data-hero="split"] .hero h1{color:#fff; text-shadow:0 2px 40px rgba(8,39,68,.4);}
  [data-hero="split"] .hero-eyebrow{color:#fff; opacity:.9;}
  [data-hero="split"] .hero .sub{color:rgba(255,255,255,.9);}
  [data-hero="split"] .hero-stats{border-top-color:rgba(255,255,255,.22);}
  [data-hero="split"] .hero-stats .num{color:#fff;}
  [data-hero="split"] .hero-stats .lbl{color:rgba(255,255,255,.72);}
  [data-hero="split"] .hero-stats .stat{border-right-color:rgba(255,255,255,.18);}
}

/* ── generic section ── */
section{position:relative;}
.band{padding:120px 0;}
.band-tight{padding:88px 0;}
.section-head{max-width:760px; margin-bottom:56px;}
.section-head .eyebrow{margin-bottom:18px; display:block;}
.section-head .lead{margin-top:22px;}

/* ── intro / statement ── */
.statement{display:grid; grid-template-columns:1.1fr .9fr; gap:64px; align-items:start;}
.statement .big{font-weight:600; font-size:clamp(26px,2.8vw,36px); line-height:1.28; letter-spacing:-.018em; color:var(--ink800); text-wrap:pretty;}
.statement .big em{font-style:normal; color:var(--royal);}
.statement .aside p{color:var(--ink500); font-size:16px; line-height:1.6;}
.statement .aside p + p{margin-top:18px;}
.stat-strip{display:grid; grid-template-columns:repeat(4,1fr); gap:0; margin-top:8px; border:1px solid var(--divider); border-radius:var(--r-lg); overflow:hidden; background:var(--surface);}
.stat-strip .cell{padding:32px 28px; border-right:1px solid var(--divider);}
.stat-strip .cell:last-child{border-right:0;}
.stat-strip .num{font-family:'GeistMono'; font-weight:500; font-size:42px; letter-spacing:-.02em; color:var(--navy); line-height:1;}
.stat-strip .lbl{color:var(--ink400); font-size:13.5px; margin-top:10px; line-height:1.4;}

/* ── services ── */
.svc-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.svc{
  background:var(--surface); border:1px solid var(--divider); border-radius:var(--r-lg);
  padding:30px; transition:border-color .2s var(--ease), box-shadow .25s var(--ease), transform .25s var(--ease);
  position:relative;
}
.svc:hover{border-color:var(--dividerStrong); box-shadow:var(--sh2); transform:translateY(-3px);}
.svc .ico{width:46px; height:46px; border-radius:var(--r-md); background:var(--royal50); display:flex; align-items:center; justify-content:center; color:var(--royal); margin-bottom:22px;}
.svc .ico svg{width:23px; height:23px;}
.svc h3{font-size:20px; margin-bottom:10px;}
.svc p{color:var(--ink500); font-size:15.5px; line-height:1.55;}
.svc .num-tag{position:absolute; top:26px; right:28px; font-family:'GeistMono'; font-size:12px; color:var(--ink300);}

/* ── work / editorial rows ── */
.work-row{display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; padding:64px 0; border-top:1px solid var(--divider);}
.work-row:first-of-type{border-top:0;}
.work-row.flip .work-media{order:2;}
.work-media{position:relative; cursor:pointer;}
.work-media image-slot{width:100%; aspect-ratio:4/3; box-shadow:var(--sh2);}
.work-media .badge{
  position:absolute; left:18px; top:18px; z-index:5; background:rgba(8,39,68,.82); color:#fff;
  font-family:'GeistMono'; font-size:11px; letter-spacing:.08em; text-transform:uppercase;
  padding:7px 12px; border-radius:var(--r-pill); backdrop-filter:blur(6px); pointer-events:none;
}
.work-media .expand{
  position:absolute; right:16px; bottom:16px; z-index:5; width:42px; height:42px; border-radius:var(--r-pill);
  background:rgba(255,255,255,.9); display:flex; align-items:center; justify-content:center; color:var(--navy);
  opacity:0; transform:scale(.85); transition:opacity .2s var(--ease), transform .2s var(--ease); pointer-events:none;
}
.work-media:hover .expand{opacity:1; transform:scale(1);}
.work-info .idx{font-family:'GeistMono'; font-size:13px; color:var(--royal); margin-bottom:18px;}
.work-info h3{font-size:clamp(26px,2.6vw,34px); letter-spacing:-.02em; line-height:1.06; margin-bottom:16px;}
.work-info .desc{color:var(--ink500); font-size:16.5px; line-height:1.6; max-width:46ch; text-wrap:pretty;}
.work-meta{display:flex; gap:40px; margin-top:28px; padding-top:24px; border-top:1px solid var(--divider);}
.work-meta .k{font-family:'GeistMono'; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink400); margin-bottom:7px;}
.work-meta .v{font-size:15px; color:var(--ink800); font-weight:500;}

/* ── portal / app teaser ── */
.portal{background:var(--navy); color:#fff; border-radius:var(--r-xl); overflow:hidden; position:relative;}
.portal::before{content:""; position:absolute; inset:0; background:radial-gradient(120% 120% at 88% 8%, rgba(45,99,217,.42), transparent 56%); pointer-events:none;}
.portal-inner{display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; padding:64px 64px 64px 64px; position:relative; z-index:2;}
.portal .eyebrow{color:var(--sky);}
.portal h2{color:#fff; font-weight:600; font-size:clamp(28px,3.2vw,42px); letter-spacing:-.022em; line-height:1.06; margin:16px 0 18px;}
.portal p{color:rgba(255,255,255,.78); font-size:17px; line-height:1.6; max-width:44ch;}
.portal-feats{list-style:none; padding:0; margin:30px 0 34px; display:grid; gap:14px;}
.portal-feats li{display:flex; align-items:flex-start; gap:13px; color:rgba(255,255,255,.92); font-size:15.5px;}
.portal-feats .dot{flex:none; width:22px; height:22px; border-radius:50%; background:rgba(45,99,217,.3); color:var(--sky); display:flex; align-items:center; justify-content:center; margin-top:1px;}
.portal-feats .dot svg{width:13px; height:13px;}
.portal-visual{display:flex; justify-content:center; align-items:center;}
.phone{
  width:280px; aspect-ratio:9/19; background:#05192c; border-radius:40px; padding:11px;
  box-shadow:var(--sh-lift), 0 0 0 1px rgba(255,255,255,.06) inset; position:relative;
}
.phone .screen{width:100%; height:100%; border-radius:30px; overflow:hidden; background:#fff; position:relative;}
.phone .notch{position:absolute; top:11px; left:50%; transform:translateX(-50%); width:96px; height:26px; background:#05192c; border-radius:var(--r-pill); z-index:6;}
.phone image-slot{width:100%; height:100%;}

/* ── contact ── */
.contact{display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start;}
.contact .ci-list{margin-top:34px; display:grid; gap:2px;}
.contact .ci{display:flex; gap:18px; padding:22px 0; border-top:1px solid var(--divider); align-items:center;}
.contact .ci:last-child{border-bottom:1px solid var(--divider);}
.contact .ci .ci-ico{flex:none; width:44px; height:44px; border-radius:var(--r-md); background:var(--surface2); display:flex; align-items:center; justify-content:center; color:var(--navy);}
.contact .ci .ci-ico svg{width:20px; height:20px;}
.contact .ci .k{font-family:'GeistMono'; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink400); margin-bottom:4px;}
.contact .ci .v{font-size:17px; color:var(--ink900); font-weight:500;}
.form{background:var(--surface); border:1px solid var(--divider); border-radius:var(--r-lg); padding:36px; box-shadow:var(--sh2);}
.form .row{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.field{display:flex; flex-direction:column; margin-bottom:18px;}
.field label{font-size:13px; font-weight:500; color:var(--ink700); margin-bottom:8px;}
.field input,.field select,.field textarea{
  font-family:'Geist'; font-size:15px; color:var(--ink900); padding:13px 15px;
  border:1px solid var(--dividerStrong); border-radius:var(--r-sm); background:var(--surface); transition:border-color .18s var(--ease), box-shadow .18s var(--ease);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--royal); box-shadow:0 0 0 3px var(--royal100);}
.field textarea{resize:vertical; min-height:110px;}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--error,#C13B3B); box-shadow:0 0 0 3px #FBE9E9;}
.field .err{font-size:12px; color:#C13B3B; margin-top:6px; display:none;}
.field.invalid .err{display:block;}
.form .btn-primary{width:100%; justify-content:center; margin-top:6px;}
.form-success{text-align:center; padding:40px 20px; display:none;}
.form-success.show{display:block;}
.form-success .check{width:60px; height:60px; border-radius:50%; background:#E3F2EA; color:#1F7A4D; display:flex; align-items:center; justify-content:center; margin:0 auto 22px;}
.form-success h3{font-size:24px; margin-bottom:10px;}
.form-success p{color:var(--ink500);}

/* ── footer ── */
footer{background:var(--navy); color:#fff; padding:72px 0 40px;}
footer .ft-top{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.12);}
footer .brand .mark{height:28px;}
footer .brand .wordmark{color:#fff;}
footer .ft-blurb{color:rgba(255,255,255,.6); font-size:15px; line-height:1.6; max-width:34ch; margin-top:20px;}
footer .ft-col h4{font-family:'GeistMono'; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--sky); margin-bottom:20px; font-weight:500;}
footer .ft-col a,footer .ft-col p{display:block; color:rgba(255,255,255,.74); font-size:15px; margin-bottom:13px; transition:color .18s var(--ease);}
footer .ft-col a:hover{color:#fff;}
footer .ft-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:28px; flex-wrap:wrap; gap:14px;}
footer .ft-bottom p{color:rgba(255,255,255,.5); font-size:13.5px;}
footer .ft-bottom .mono{color:rgba(255,255,255,.5);}

/* ── reveal animation ── */
.reveal{opacity:0; transform:translateY(22px); 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;}

/* ── lightbox ── */
.lightbox{position:fixed; inset:0; z-index:120; background:rgba(8,39,68,.86); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; padding:40px; opacity:0; pointer-events:none; transition:opacity .26s var(--ease);}
.lightbox.open{opacity:1; pointer-events:auto;}
.lightbox img{max-width:90vw; max-height:84vh; border-radius:var(--r-md); box-shadow:var(--sh-lift); transform:scale(.96); transition:transform .26s var(--ease);}
.lightbox.open img{transform:scale(1);}
.lightbox .lb-cap{position:absolute; bottom:32px; left:0; right:0; text-align:center; color:#fff; font-family:'GeistMono'; font-size:13px; letter-spacing:.06em;}
.lightbox .lb-close{position:absolute; top:26px; right:30px; width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.14); border:0; color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center;}
.lightbox .lb-close:hover{background:rgba(255,255,255,.26);}
.lb-empty{color:#fff;}

/* ── mobile menu ── */
.mnav{position:fixed; inset:0; z-index:55; background:var(--navy); transform:translateY(-100%); transition:transform .34s var(--ease); display:flex; flex-direction:column; padding:96px 32px 40px;}
.mnav.open{transform:none;}
.mnav a{color:#fff; font-size:30px; font-weight:600; letter-spacing:-.02em; padding:16px 0; border-bottom:1px solid rgba(255,255,255,.1);}
.mnav .btn{margin-top:28px; justify-content:center;}

/* ── responsive ── */
@media (max-width:1080px){
  .portal-inner{grid-template-columns:1fr; gap:40px;}
  .stat-strip{grid-template-columns:repeat(2,1fr);}
  .stat-strip .cell:nth-child(2){border-right:0;}
  .stat-strip .cell:nth-child(1),.stat-strip .cell:nth-child(2){border-bottom:1px solid var(--divider);}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:880px){
  .wrap{padding:0 22px;}
  .band{padding:80px 0;} .band-tight{padding:64px 0;}
  nav.main,.header-cta{display:none;}
  .menu-toggle{display:flex;}
  .statement{grid-template-columns:1fr; gap:36px;}
  .svc-grid{grid-template-columns:1fr;}
  .work-row{grid-template-columns:1fr; gap:30px; padding:48px 0;}
  .work-row.flip .work-media{order:0;}
  .contact{grid-template-columns:1fr; gap:44px;}
  .portal-inner{padding:44px 28px;}
  footer .ft-top{grid-template-columns:1fr; gap:36px;}
  .hero-stats .stat{padding-right:30px; margin-right:30px;}
  .work-meta{gap:26px; flex-wrap:wrap;}
  .lightbox{padding:20px;}
  .lightbox .lb-close{top:14px; right:16px;}
  .mnav .btn{align-self:stretch;}
}
@media (max-width:520px){
  .wrap{padding:0 18px;}
  .form .row{grid-template-columns:1fr;}
  .form{padding:26px 22px;}
  .hero-stats{gap:0;}
  .hero-stats .stat{border-right:0; margin-right:0; padding-right:0; width:50%; margin-bottom:18px;}
  .stat-strip{grid-template-columns:1fr;}
  .stat-strip .cell{border-right:0; border-bottom:1px solid var(--divider);}
  .stat-strip .cell:last-child{border-bottom:0;}
  .work-meta{gap:20px;}
  .work-meta > div{min-width:42%;}
  .portal-inner{padding:36px 22px;}
  .phone{width:240px;}
  header .wrap{height:64px;}
}
