:root{
  --bg:#0A0C0E; --panel:#11151A; --panel2:#161C23; --line:#222B35;
  --text:#F0F4F8; --muted:#94A1AE; --accent:#29ABE2; --accent-dim:#177CA9;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:"Archivo",sans-serif;font-size:17px;line-height:1.6;}
h1,h2,h3{font-family:"Archivo Black",sans-serif;font-weight:400;text-transform:uppercase;line-height:1.05;text-wrap:balance;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
.wrap{max-width:1240px;margin:0 auto;padding:0 36px;}
section{padding:96px 0;}
.btn{display:inline-flex;align-items:center;gap:10px;white-space:nowrap;font-family:"Archivo Black",sans-serif;text-transform:uppercase;font-size:14px;letter-spacing:.05em;padding:17px 30px;cursor:pointer;border:none;transition:transform .12s,background .15s,color .15s;}
.btn-solid{background:var(--accent);color:#04131C;clip-path:polygon(0 0,100% 0,calc(100% - 14px) 100%,0 100%);}
.btn-solid:hover{background:#4FC1F2;}
.btn-line{box-shadow:inset 0 0 0 2px var(--line);color:var(--text);}
.btn-line:hover{box-shadow:inset 0 0 0 2px var(--accent);color:var(--accent);}
.kicker{display:inline-flex;align-items:center;gap:12px;font-family:"Archivo Black",sans-serif;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin-bottom:18px;}
.kicker::before{content:"";width:34px;height:3px;background:var(--accent);transform:skewX(-30deg);}

/* top strip */
.strip{background:var(--accent);color:#04131C;font-weight:600;font-size:14px;}
.strip .wrap{display:flex;justify-content:space-between;align-items:center;padding-top:7px;padding-bottom:7px;gap:16px;}
.strip a{white-space:nowrap;font-family:"Archivo Black",sans-serif;}
.strip b{font-family:"Archivo Black",sans-serif;letter-spacing:.02em;}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(10,12,14,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;}
.brand{display:flex;align-items:center;gap:14px;}
.brand img{height:56px;}
.brand .nm{font-family:"Archivo Black",sans-serif;font-size:17px;text-transform:uppercase;line-height:1.15;white-space:nowrap;}
.brand .nm small{display:block;font-family:"Archivo",sans-serif;font-weight:600;font-size:10.5px;letter-spacing:.24em;color:var(--accent);}
.navlinks{display:flex;gap:28px;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;}
.navlinks a{padding:6px 0;border-bottom:2px solid transparent;}
.navlinks a:hover{color:var(--accent);border-color:var(--accent);}
.navlinks a.nav-estimate{color:var(--accent);}
.navlinks a.nav-estimate:hover{border-color:var(--accent);}

/* hero (homepage) */
.hero{position:relative;padding:0;border-bottom:1px solid var(--line);overflow:hidden;}
.hero .bgslot{position:absolute;inset:0;}
.hero .bgslot image-slot{width:100%;height:100%;--is-radius:0;}
.hero .scrim{position:absolute;inset:0;background:linear-gradient(100deg,rgba(7,9,11,.96) 30%,rgba(7,9,11,.55) 65%,rgba(7,9,11,.25));pointer-events:none;}
.hero .slash{position:absolute;top:0;bottom:0;right:18%;width:90px;background:linear-gradient(180deg,var(--accent),var(--accent-dim));transform:skewX(-18deg);opacity:.18;pointer-events:none;}
.hero .inner{position:relative;padding-top:120px;padding-bottom:110px;pointer-events:none;}
.hero .inner a,.hero .inner .drop-hint{pointer-events:auto;}
.hero h1{font-size:74px;max-width:11ch;}
.hero h1 .cy{color:var(--accent);}
.hero p.sub{margin:26px 0 36px;font-size:19px;color:#C6D1DB;max-width:52ch;text-wrap:pretty;}
.hero .ctas{display:flex;gap:16px;flex-wrap:wrap;}
.hero .proof{display:flex;gap:34px;margin-top:54px;flex-wrap:wrap;}
.hero .proof div{font-size:13.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600;}
.hero .proof b{display:block;font-family:"Archivo Black",sans-serif;font-size:26px;color:var(--text);letter-spacing:0;}
.hero .proof b .st{color:#F5B83D;}
.drop-hint{position:absolute;right:36px;bottom:24px;font-family:ui-monospace,monospace;font-size:12px;color:#9fb3c2;background:rgba(7,9,11,.7);border:1px dashed #3a4a58;padding:8px 12px;}

/* page hero (subpages) */
.pagehero{position:relative;border-bottom:1px solid var(--line);overflow:hidden;padding:88px 0 76px;background:radial-gradient(760px 380px at 85% -20%, rgba(41,171,226,.13), transparent 60%);}
.pagehero .slash{position:absolute;top:0;bottom:0;right:12%;width:70px;background:linear-gradient(180deg,var(--accent),var(--accent-dim));transform:skewX(-18deg);opacity:.12;pointer-events:none;}
.crumb{display:flex;gap:10px;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:22px;flex-wrap:wrap;}
.crumb a:hover{color:var(--accent);}
.crumb span{color:var(--accent);}
.pagehero h1{font-size:52px;max-width:20ch;}
.pagehero p.sub{margin:24px 0 34px;font-size:18.5px;color:#C6D1DB;max-width:58ch;text-wrap:pretty;}
.pagehero .ctas{display:flex;gap:16px;flex-wrap:wrap;}
.pagehero .proof{display:flex;gap:34px;margin-top:48px;flex-wrap:wrap;}
.pagehero .proof div{font-size:13.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600;}
.pagehero .proof b{display:block;font-family:"Archivo Black",sans-serif;font-size:24px;color:var(--text);letter-spacing:0;}
.pagehero .proof b .st{color:#F5B83D;}

/* marquee band */
.band{background:var(--accent);color:#04131C;padding:18px 0;overflow:hidden;border-bottom:1px solid var(--line);}
.band .track{display:flex;gap:48px;white-space:nowrap;font-family:"Archivo Black",sans-serif;font-size:16px;text-transform:uppercase;letter-spacing:.08em;}
.band span{display:inline-flex;align-items:center;gap:48px;}
.band span::after{content:"◆";font-size:10px;}

/* services rows */
.svchead{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:54px;flex-wrap:wrap;}
.svchead h2{font-size:52px;}
.svchead p{color:var(--muted);max-width:42ch;text-wrap:pretty;}
.svcrows{border-top:1px solid var(--line);}
.svcrow{display:grid;grid-template-columns:90px 1.1fr 1.6fr auto;gap:28px;align-items:center;padding:30px 8px;border-bottom:1px solid var(--line);transition:background .15s;}
.svcrow:hover{background:var(--panel);}
.svcrow .num{font-family:"Archivo Black",sans-serif;font-size:30px;color:transparent;-webkit-text-stroke:1.5px var(--accent-dim);}
.svcrow:hover .num{color:var(--accent);-webkit-text-stroke:0;}
.svcrow h3{font-size:23px;}
.svcrow p{color:var(--muted);font-size:15.5px;}
.svcrow .go{font-family:"Archivo Black",sans-serif;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);white-space:nowrap;}

/* why + stats */
.why{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.why .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:72px;align-items:center;}
.why h2{font-size:46px;}
.why .lead{color:var(--muted);margin:20px 0 34px;text-wrap:pretty;}
.bigstats{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--line);border:1px solid var(--line);}
.bigstats div{background:var(--panel2);padding:30px 26px;}
.bigstats b{display:block;font-family:"Archivo Black",sans-serif;font-size:38px;color:var(--accent);line-height:1;}
.bigstats span{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600;}
.whypoints{display:grid;gap:0;border:1px solid var(--line);}
.whypoints > div{display:flex;gap:18px;padding:24px 26px;border-bottom:1px solid var(--line);background:var(--panel2);}
.whypoints > div:last-child{border-bottom:none;}
.whypoints .bar{flex:none;width:5px;background:var(--accent);transform:skewY(-12deg);}
.whypoints b{display:block;font-family:"Archivo Black",sans-serif;font-size:16px;text-transform:uppercase;letter-spacing:.03em;}
.whypoints span{color:var(--muted);font-size:15px;}

/* gallery */
.work .wrap > h2{font-size:52px;margin-bottom:14px;}
.work .wrap > p{color:var(--muted);margin-bottom:44px;}
.workgrid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:14px;}
.workgrid image-slot{width:100%;height:100%;}
.workgrid .big{grid-column:span 2;grid-row:span 2;}

/* reviews */
.reviews{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.reviews .head{display:flex;align-items:baseline;gap:26px;margin-bottom:48px;flex-wrap:wrap;}
.reviews .score{font-family:"Archivo Black",sans-serif;font-size:96px;line-height:1;color:var(--accent);}
.reviews .head .meta .st{color:#F5B83D;font-size:24px;letter-spacing:4px;}
.reviews .head .meta p{color:var(--muted);font-size:15px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;}
.revgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.rev{background:var(--panel2);border:1px solid var(--line);padding:30px;position:relative;}
.rev::before{content:"";position:absolute;top:0;left:0;width:46px;height:5px;background:var(--accent);transform:skewX(-30deg);transform-origin:left;}
.rev .st{color:#F5B83D;letter-spacing:2px;font-size:14px;}
.rev p{margin:16px 0 20px;font-size:15.5px;}
.rev footer{font-weight:600;font-size:13.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;}
.ph-note{margin-top:22px;font-family:ui-monospace,monospace;font-size:12.5px;color:var(--muted);}

/* areas */
.areas h2{font-size:52px;margin-bottom:14px;}
.areas > .wrap > p{color:var(--muted);margin-bottom:40px;max-width:60ch;}
.areagrid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-right:none;border-bottom:none;}
.areagrid a{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px 20px;font-weight:600;font-size:15px;color:var(--muted);transition:all .12s;}
.areagrid a:hover{background:var(--panel);color:var(--accent);}

/* faq */
.faq{background:var(--panel);border-top:1px solid var(--line);}
.faq h2{font-size:52px;margin-bottom:44px;}
.faqlist{display:grid;gap:10px;max-width:880px;}
details{background:var(--panel2);border:1px solid var(--line);}
summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:22px 26px;font-family:"Archivo Black",sans-serif;font-size:15.5px;text-transform:uppercase;letter-spacing:.02em;}
summary::-webkit-details-marker{display:none;}
summary .pm{flex:none;color:var(--accent);font-size:22px;line-height:1;}
details[open]{border-color:var(--accent-dim);}
details .body{padding:0 26px 24px;color:var(--muted);font-size:15.5px;max-width:70ch;}

/* quote */
.quote{position:relative;overflow:hidden;}
.quote .slash{position:absolute;top:-10%;bottom:-10%;left:55%;width:110px;background:var(--accent);opacity:.07;transform:skewX(-18deg);}
.quote .wrap{display:grid;grid-template-columns:1fr 1fr;gap:72px;position:relative;}
.quote h2{font-size:52px;}
.quote .lead{color:var(--muted);margin:20px 0 36px;text-wrap:pretty;}
.callblock{border:1px solid var(--line);background:var(--panel);padding:30px;}
.callblock .lb{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.callblock a.ph{display:block;font-family:"Archivo Black",sans-serif;font-size:42px;color:var(--accent);margin:8px 0 4px;}
.callblock .em{color:var(--muted);font-size:15px;}
.scheduler-embed{background:var(--panel);border:1px solid var(--line);padding:14px;border-radius:4px;}
.scheduler-embed[hidden]{display:none;}
.sched-intro{font-weight:600;color:var(--text);padding:6px 6px 14px;font-size:16px;}
.leadform[hidden]{display:none;}
.formnote{grid-column:1/-1;color:var(--muted);font-size:13px;text-align:center;margin-top:-4px;}
.scheduler-embed iframe{width:100%;height:620px;border:0;display:block;border-radius:2px;background:#fff;}
@media (max-width:900px){.scheduler-embed iframe{height:560px;}}
form{background:var(--panel);border:1px solid var(--line);padding:36px;display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{display:grid;gap:7px;}
.field.full{grid-column:1/-1;}
label{font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
input,select,textarea{background:var(--bg);border:1px solid var(--line);padding:14px;color:var(--text);font-family:inherit;font-size:15.5px;width:100%;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);}
textarea{min-height:110px;resize:vertical;}
form .btn{grid-column:1/-1;justify-content:center;}
.formok{grid-column:1/-1;display:none;background:rgba(41,171,226,.1);border:1px solid var(--accent);padding:16px;font-size:15px;}
form.sent .formok{display:block;}

/* subpage content */
.contentgrid{display:grid;grid-template-columns:1.25fr .75fr;gap:64px;align-items:start;}
.prose h2{font-size:30px;margin:40px 0 16px;}
.prose h2:first-child{margin-top:0;}
.prose p{color:var(--muted);margin-bottom:16px;max-width:68ch;text-wrap:pretty;}
.prose ul{list-style:none;margin:20px 0 8px;display:grid;gap:12px;}
.prose ul li{display:flex;gap:14px;align-items:flex-start;color:var(--muted);font-size:16px;}
.prose ul li::before{content:"";flex:none;width:14px;height:14px;margin-top:6px;background:var(--accent);clip-path:polygon(0 0,100% 0,70% 100%,0 100%);}
.prose ul li b{color:var(--text);}
.sidecol{display:grid;gap:22px;position:sticky;top:104px;}
.sidecol image-slot{width:100%;height:280px;}
.sidecard{background:var(--panel);border:1px solid var(--line);padding:28px;}
.sidecard h3{font-size:17px;letter-spacing:.04em;margin-bottom:16px;}
.sidecard ul{list-style:none;display:grid;gap:11px;font-size:15px;color:var(--muted);}
.sidecard ul a{display:flex;justify-content:space-between;gap:12px;}
.sidecard ul a:hover{color:var(--accent);}
.sidecard ul a::after{content:"→";color:var(--accent);}
.sidecard .ph{display:block;font-family:"Archivo Black",sans-serif;font-size:30px;color:var(--accent);margin:6px 0 2px;}
.sidecard .lb{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.sidecard .em{color:var(--muted);font-size:14px;}

@media (max-width: 980px){
  .hero h1{font-size:48px;}
  .pagehero h1{font-size:38px;}
  .why .wrap,.quote .wrap,.contentgrid{grid-template-columns:1fr;}
  .sidecol{position:static;}
  .svcrow{grid-template-columns:60px 1fr;}
  .svcrow p{grid-column:2;}
  .svcrow .go{grid-column:2;}
  .workgrid{grid-template-columns:1fr 1fr;}
  .areagrid{grid-template-columns:1fr 1fr;}
  .revgrid{grid-template-columns:1fr;}
  .navlinks{display:none;}
  .footgrid{grid-template-columns:1fr 1fr;}
}

/* Empty photo slots stay hidden until a photo is added */
image-slot:not([data-filled]){display:none;}

/* footer */
footer.site{border-top:1px solid var(--line);padding:64px 0 36px;font-size:15px;background:#07090B;}
.footgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footgrid h4{font-family:"Archivo Black",sans-serif;font-size:13px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;}
.footgrid ul{list-style:none;display:grid;gap:9px;}
.footgrid a{color:var(--muted);}
.footgrid a:hover{color:var(--accent);}
.footbrand img{height:66px;margin-bottom:16px;}
.footbrand p{color:var(--muted);max-width:36ch;}
.legal{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;color:var(--muted);font-size:13.5px;flex-wrap:wrap;gap:10px;}

/* ===== PHONE BREAKPOINT (≤600px) ===== */
@media (max-width: 600px){
  html,body{overflow-x:hidden;}
  .wrap{padding:0 18px;}
  section{padding:58px 0;}

  /* top utility strip */
  .strip{font-size:11.5px;}
  .strip .wrap{flex-wrap:wrap;justify-content:center;text-align:center;gap:3px 12px;}

  /* nav */
  .nav .wrap{gap:10px;}
  .brand{gap:10px;}
  .brand img{height:40px;}
  .brand .nm{font-size:13.5px;}
  .brand .nm small{font-size:9px;letter-spacing:.16em;}
  .nav .btn-solid{padding:11px 15px;font-size:12px;}

  /* homepage hero */
  .hero .inner{padding-top:80px;padding-bottom:68px;}
  .hero h1{font-size:37px;}
  .hero p.sub{font-size:16.5px;margin:20px 0 26px;}
  .hero .ctas{gap:12px;}
  .hero .ctas .btn{flex:1 1 100%;justify-content:center;}
  .hero .proof{gap:20px 26px;margin-top:36px;}
  .hero .proof b{font-size:22px;}

  /* subpage hero */
  .pagehero{padding:60px 0 50px;}
  .pagehero h1{font-size:29px;}
  .pagehero p.sub{font-size:16.5px;margin:18px 0 26px;}
  .pagehero .ctas{gap:12px;}
  .pagehero .ctas .btn{flex:1 1 100%;justify-content:center;}

  /* section headings */
  .svchead h2,.work .wrap > h2,.areas h2,.faq h2,.quote h2{font-size:34px;}
  .why h2{font-size:30px;}
  .reviews .score{font-size:68px;}

  /* grids */
  .workgrid{grid-template-columns:1fr;grid-auto-rows:200px;}
  .workgrid .big{grid-column:auto;grid-row:auto;}
  .areagrid{grid-template-columns:1fr 1fr;}
  .bigstats{grid-template-columns:1fr 1fr;}
  .footgrid{grid-template-columns:1fr;gap:30px;}

  /* services list rows */
  .svcrow{grid-template-columns:44px 1fr;gap:12px;padding:22px 4px;}
  .svcrow h3{font-size:19px;}
  .svcrow .num{font-size:24px;}

  /* contact + forms */
  .callblock{padding:24px;}
  .callblock a.ph{font-size:32px;}
  form{padding:24px;}
  .legal{flex-direction:column;}
  summary{font-size:14px;padding:18px 20px;}
}
