/* Foothills Facility Services — shared styles (landing + city pages) */
:root{
  --ink:#0F3C39;--ink2:#16514C;--accent:#1FB89E;--accent-deep:#0E8C78;
  --paper:#FFFFFF;--panel:#F1F6F5;--line:#D5E2DF;--text:#27322F;--muted:#5E6F6B;
  --shadow:0 18px 50px rgba(15,60,57,.12);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:74px;}
body{font-family:'IBM Plex Sans',system-ui,sans-serif;color:var(--text);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,.font-display{font-family:'Archivo',sans-serif;}
a{color:inherit;text-decoration:none;}
img,svg{display:block;}
.wrap{width:100%;max-width:1120px;margin:0 auto;padding:0 24px;}
.accent{color:var(--accent-deep);}
em{font-style:normal;color:var(--accent-deep);}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:'Archivo';font-weight:700;font-size:15px;letter-spacing:.2px;padding:14px 26px;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;white-space:nowrap;}
.btn-primary{background:var(--accent);color:#06302a;box-shadow:0 8px 22px rgba(31,184,158,.35);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(31,184,158,.45);}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{transform:translateY(-2px);background:var(--ink2);}

/* ---------- Header ---------- */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand svg,.brand .brandmark{width:46px;height:46px;flex:0 0 auto;}
.brand .bnamewrap{display:flex;flex-direction:column;line-height:1;}
.brand .bname{display:block;font-family:'Archivo';font-weight:900;font-size:18px;color:var(--ink);letter-spacing:-.4px;line-height:1;}
.brand .btag{display:block;font-size:9.5px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;color:var(--accent-deep);margin-top:4px;}
.navlinks{display:flex;align-items:center;gap:30px;}
.navlinks a{font-weight:500;font-size:15px;color:var(--ink2);transition:color .15s;}
.navlinks a:hover{color:var(--accent-deep);}
.navphone{font-family:'Archivo';font-weight:800;font-size:16px;color:var(--ink);}
.menu-btn{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.menu-btn span{display:block;width:24px;height:2.5px;background:var(--ink);border-radius:2px;margin:5px 0;transition:.2s;}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;}
.hero::before{content:"";position:absolute;right:-12%;top:-30%;width:55vw;height:120%;border-radius:50%;background:radial-gradient(circle at center,rgba(31,184,158,.20),transparent 62%);}
.hero-inner{position:relative;z-index:2;padding-top:84px;}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Archivo';font-weight:700;text-transform:uppercase;letter-spacing:2.5px;font-size:12px;color:var(--accent);margin-bottom:22px;}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--accent);}
.hero h1{font-weight:800;font-size:clamp(34px,5.2vw,58px);line-height:1.02;letter-spacing:-1px;}
.hero .lede{font-size:clamp(16px,2vw,19px);color:#CFE6E1;margin-top:22px;max-width:560px;line-height:1.55;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;align-items:center;}
.hero-trust{display:flex;flex-wrap:wrap;gap:8px 22px;margin-top:34px;padding-top:26px;border-top:1px solid rgba(255,255,255,.12);}
.hero-trust span{font-size:13.5px;color:#9FC4BD;display:flex;align-items:center;gap:8px;}
.hero-trust span::before{content:"✓";color:var(--accent);font-weight:800;}
.hero-art{position:relative;display:flex;justify-content:center;}
.hero-badge{width:min(360px,80%);filter:drop-shadow(0 24px 50px rgba(0,0,0,.4));}
.hero-ridge{display:block;width:100%;height:60px;margin-top:48px;}

/* offer chip floating on hero */
.offer-chip{position:absolute;bottom:84px;left:-14px;background:var(--accent);color:#06302a;border-radius:14px;padding:14px 18px;box-shadow:0 14px 30px rgba(0,0,0,.35);transform:rotate(-3deg);}
.offer-chip b{font-family:'Archivo';font-weight:900;font-size:20px;display:block;line-height:1;}
.offer-chip span{font-family:'Archivo';font-weight:700;font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;}

/* ---------- Section scaffolding ---------- */
section{padding:84px 0;}
.sec-eyebrow{font-family:'Archivo';font-weight:700;text-transform:uppercase;letter-spacing:2.5px;font-size:12px;color:var(--accent-deep);margin-bottom:14px;}
.sec-title{font-weight:800;font-size:clamp(27px,3.6vw,40px);line-height:1.08;letter-spacing:-.6px;color:var(--ink);max-width:760px;}
.sec-sub{font-size:17px;color:var(--muted);margin-top:16px;max-width:640px;}
.center{text-align:center;}.center .sec-title,.center .sec-sub{margin-left:auto;margin-right:auto;}

/* ---------- Pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px;}
.pillar{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:34px 28px;transition:transform .18s ease,box-shadow .18s ease;}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.pillar .pico{width:54px;height:54px;border-radius:14px;background:var(--ink);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.pillar .pico svg{width:28px;height:28px;}
.pillar h3{font-weight:800;font-size:20px;color:var(--ink);margin-bottom:10px;}
.pillar p{font-size:15px;color:var(--muted);line-height:1.55;}

/* ---------- Scope / what's included ---------- */
.scope-sec{background:var(--panel);}
.scope-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px;}
.scard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 24px;}
.scard h4{font-weight:800;font-size:15px;text-transform:uppercase;letter-spacing:.6px;color:var(--ink);padding-bottom:12px;margin-bottom:14px;border-bottom:2px solid var(--accent);}
.scard ul{list-style:none;}
.scard li{font-size:14px;line-height:1.5;color:var(--text);padding-left:22px;position:relative;margin-bottom:9px;}
.scard li::before{content:"✓";position:absolute;left:0;top:0;color:var(--accent-deep);font-weight:800;}
.scope-note{margin-top:32px;font-size:15px;color:var(--muted);text-align:center;}

/* ---------- Guarantee band ---------- */
.guar{background:var(--ink);color:#fff;position:relative;overflow:hidden;}
.guar::after{content:"";position:absolute;right:-6%;bottom:-40%;width:38vw;height:120%;border-radius:50%;background:rgba(31,184,158,.12);}
.guar-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center;position:relative;z-index:2;}
.seal{width:120px;height:120px;border-radius:50%;border:3px solid var(--accent);color:var(--accent);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;margin-bottom:26px;}
.seal b{font-family:'Archivo';font-weight:900;font-size:38px;line-height:1;}
.seal span{font-family:'Archivo';font-weight:700;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;margin-top:4px;}
.guar h2{font-weight:800;font-size:clamp(26px,3.4vw,38px);line-height:1.08;letter-spacing:-.5px;}
.guar p{font-size:16.5px;color:#CFE6E1;margin-top:18px;line-height:1.6;}
.guar p b{color:#fff;}
.guar .gtag{margin-top:22px;font-family:'Archivo';font-weight:700;letter-spacing:1px;text-transform:uppercase;font-size:13px;color:var(--accent);}

/* ---------- Who it's for ---------- */
.tags{display:flex;flex-wrap:wrap;gap:12px;margin-top:40px;justify-content:center;}
.tag{background:#fff;border:1px solid var(--line);border-radius:999px;padding:12px 22px;font-size:15px;font-weight:500;color:var(--ink2);box-shadow:0 4px 14px rgba(15,60,57,.05);}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:52px;counter-reset:step;}
.step{position:relative;padding-top:14px;}
.step .snum{font-family:'Archivo';font-weight:900;font-size:46px;color:var(--accent);line-height:1;opacity:.5;}
.step h3{font-weight:800;font-size:20px;color:var(--ink);margin:10px 0 8px;}
.step p{font-size:15px;color:var(--muted);}

/* ---------- Local content (city pages) ---------- */
.local-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start;}
.prose p{font-size:16px;color:var(--text);line-height:1.7;margin-bottom:16px;}
.prose p:last-child{margin-bottom:0;}
.local-aside{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:30px 28px;}
.local-aside h3{font-weight:800;font-size:17px;color:var(--ink);margin-bottom:14px;}
.local-aside ul{list-style:none;}
.local-aside li{font-size:15px;color:var(--text);line-height:1.5;padding-left:24px;position:relative;margin-bottom:11px;}
.local-aside li::before{content:"✓";position:absolute;left:0;top:0;color:var(--accent-deep);font-weight:800;}

/* ---------- Contact / CTA ---------- */
.contact{background:var(--ink);color:#fff;position:relative;overflow:hidden;}
.contact::before{content:"";position:absolute;left:-10%;top:-50%;width:40vw;height:140%;border-radius:50%;background:rgba(31,184,158,.10);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;position:relative;z-index:2;}
.contact h2{font-weight:800;font-size:clamp(28px,3.6vw,42px);line-height:1.05;letter-spacing:-.6px;}
.contact .lede{color:#CFE6E1;font-size:17px;margin-top:16px;max-width:440px;}
.callbox{margin-top:32px;display:flex;flex-direction:column;gap:6px;}
.callbox .lbl{font-family:'Archivo';font-weight:700;text-transform:uppercase;letter-spacing:2px;font-size:12px;color:var(--accent);}
.callbox .num{font-family:'Archivo';font-weight:900;font-size:clamp(32px,4.5vw,44px);color:#fff;letter-spacing:-1px;}
.callbox .num a:hover{color:var(--accent);}
.contact-meta{margin-top:30px;font-size:14.5px;color:#9FC4BD;display:flex;flex-direction:column;gap:7px;}
.contact-meta b{color:#fff;font-weight:600;}
.lic{margin-top:26px;font-size:12.5px;color:#8FB3AC;letter-spacing:.3px;}

/* form */
.form-card{background:#fff;border-radius:20px;padding:34px;box-shadow:0 24px 60px rgba(0,0,0,.3);}
.form-card h3{font-weight:800;font-size:21px;color:var(--ink);margin-bottom:4px;}
.form-card .fsub{font-size:14.5px;color:var(--muted);margin-bottom:22px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink2);margin-bottom:6px;}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:15px;color:var(--text);padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;background:#fff;transition:border-color .15s,box-shadow .15s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,184,158,.16);}
.field textarea{resize:vertical;min-height:92px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-card .btn{width:100%;margin-top:8px;}
.form-note{font-size:12.5px;color:var(--muted);text-align:center;margin-top:14px;}
.form-success{display:none;text-align:center;padding:30px 10px;}
.form-success.show{display:block;}
.form-success .chk{width:64px;height:64px;border-radius:50%;background:var(--accent);color:#06302a;font-size:32px;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;}
.form-success h3{font-size:22px;color:var(--ink);margin-bottom:8px;}
.form-success p{color:var(--muted);font-size:15px;}

/* ---------- Footer ---------- */
footer{background:#0a2c2a;color:#9FC4BD;padding:40px 0;}
.foot-grid{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;}
.foot-brand{display:flex;align-items:center;gap:12px;}
.foot-brand svg,.foot-brand .brandmark{width:42px;height:42px;flex:0 0 auto;}
.foot-brand .fn{font-family:'Archivo';font-weight:900;color:#fff;font-size:16px;}
.foot-brand .ft{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-top:2px;}
.foot-links{display:flex;gap:24px;flex-wrap:wrap;}
.foot-links a{font-size:14px;}.foot-links a:hover{color:var(--accent);}
.foot-areas{margin-top:24px;padding-top:22px;border-top:1px solid rgba(255,255,255,.10);font-size:13.5px;display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;}
.foot-areas b{color:#fff;font-weight:600;font-family:'Archivo';}
.foot-areas a:hover{color:var(--accent);}
.foot-bottom{margin-top:24px;padding-top:22px;border-top:1px solid rgba(255,255,255,.10);font-size:12.5px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:10px;}
  .hero-art{display:none;}
  .hero-inner{padding-top:60px;}
  .guar-grid,.contact-grid,.local-grid{grid-template-columns:1fr;gap:36px;}
  .seal{margin-left:0;}
  .pillars,.scope-grid,.steps{grid-template-columns:1fr;}
  .scope-grid{gap:16px;}
}
@media (max-width:760px){
  .navlinks{position:fixed;top:72px;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;gap:0;padding:0 24px;border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .25s ease;box-shadow:0 14px 24px rgba(0,0,0,.08);}
  .navlinks.open{max-height:340px;}
  .navlinks a,.navlinks .navphone{padding:16px 0;width:100%;border-bottom:1px solid var(--line);}
  .navlinks .btn{margin:14px 0;}
  .menu-btn{display:block;}
  .desktop-phone{display:none;}
  section{padding:60px 0;}
  .frow{grid-template-columns:1fr;}
  .hero-actions{flex-direction:column;align-items:stretch;}
  .hero-actions .btn{width:100%;}
  .hero h1{font-size:32px;}
  .hero-inner{padding-top:52px;}
}
