/* ===== New Smart Signs — brand stylesheet ===== */
:root{
  --navy:#0A1A2F;        /* primary dark */
  --navy-2:#0E2440;      /* raised dark surface */
  --blue:#1466D6;        /* Smart Blue accent */
  --blue-bright:#2B86FF; /* hover/glow */
  --silver:#C7CDD4;      /* metallic secondary */
  --steel:#5B6573;       /* muted text */
  --mist:#F4F6F8;        /* light section bg */
  --white:#FFFFFF;
  --ink:#0A1A2F;
  --success:#1E9E5A;
  --ring:rgba(20,102,214,.35);
  --shadow:0 10px 30px rgba(10,26,47,.12);
  --shadow-lg:0 24px 60px rgba(10,26,47,.18);
  --radius:14px;
  --maxw:1200px;
  --font-display:"Sora",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-body:"Inter Tight",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*{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);background:var(--white);line-height:1.6;font-size:17px;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:var(--blue);text-decoration:none}
a:hover{color:var(--blue-bright)}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.12;font-weight:700;letter-spacing:-.02em;color:var(--navy)}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin-bottom:1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section--mist{background:var(--mist)}
.section--navy{background:var(--navy);color:var(--silver)}
.section--navy h2,.section--navy h3{color:var(--white)}
.eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:600;color:var(--blue)}
.lead{font-size:1.18rem;color:var(--steel)}
.center{text-align:center}

/* Skip link */
.skip{position:absolute;left:-999px;top:0;background:var(--blue);color:#fff;padding:10px 16px;z-index:999}
.skip:focus{left:8px;top:8px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:600;font-size:1rem;
  padding:14px 26px;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:.18s ease;white-space:nowrap}
.btn--primary{background:var(--blue);color:#fff;box-shadow:0 8px 22px var(--ring)}
.btn--primary:hover{background:var(--blue-bright);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}
.btn--dark{background:var(--navy);color:#fff}
.btn--dark:hover{background:var(--navy-2);color:#fff;transform:translateY(-2px)}
.btn--lg{padding:17px 34px;font-size:1.08rem}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(10,26,47,.96);backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,255,255,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;max-width:1320px;margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brand img{height:46px;width:auto}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text .bt-main{font-family:var(--font-display);font-weight:700;font-size:1.12rem;letter-spacing:.02em}
.brand-text .bt-sub{font-size:.62rem;letter-spacing:.28em;color:var(--blue-bright);text-transform:uppercase;margin-top:3px}
.nav{display:flex;align-items:center;gap:6px}
.nav a{color:var(--silver);font-weight:500;padding:9px 12px;border-radius:8px;font-size:.95rem}
.nav a:hover{color:#fff;background:rgba(255,255,255,.06)}
.header-cta{display:flex;align-items:center;gap:10px}
.tel-link{color:#fff;font-family:var(--font-display);font-weight:600;display:flex;align-items:center;gap:7px;font-size:.98rem}
.tel-link:hover{color:var(--blue-bright)}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.menu-toggle span{display:block;width:26px;height:2.5px;background:#fff;margin:5px 0;border-radius:2px;transition:.2s}

/* ===== Hero ===== */
.hero{position:relative;background:
   radial-gradient(1200px 500px at 80% -10%,rgba(20,102,214,.45),transparent 60%),
   linear-gradient(160deg,var(--navy) 0%,#06101e 100%);
  color:#fff;overflow:hidden;padding:84px 0 92px}
.hero::after{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:48px 48px;mask-image:radial-gradient(circle at 70% 30%,#000,transparent 75%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;position:relative;z-index:2}
.hero h1{color:#fff;margin-bottom:18px}
.hero h1 .accent{color:var(--blue-bright)}
.hero p.lead{color:#cdd6e0;max-width:560px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-trust{display:flex;gap:28px;margin-top:36px;flex-wrap:wrap}
.hero-trust .ht{display:flex;flex-direction:column}
.hero-trust .ht b{font-family:var(--font-display);font-size:1.6rem;color:#fff}
.hero-trust .ht span{font-size:.82rem;color:var(--silver);text-transform:uppercase;letter-spacing:.08em}
.hero-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:8px;box-shadow:var(--shadow-lg)}
.hero-card img{border-radius:12px;aspect-ratio:4/3;object-fit:cover;width:100%}

/* ===== Cards / grids ===== */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid #e7eaee;border-radius:var(--radius);overflow:hidden;transition:.2s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#d3dae3}
.card img{aspect-ratio:3/2;object-fit:cover;width:100%}
.card-body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-body h3{font-size:1.18rem}
.card-body p{color:var(--steel);font-size:.96rem;margin:0;flex:1}
.card-link{font-family:var(--font-display);font-weight:600;color:var(--blue);font-size:.92rem;margin-top:8px}

/* feature/check lists */
.checklist{list-style:none;display:grid;gap:12px}
.checklist li{position:relative;padding-left:34px;color:var(--steel)}
.checklist li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:6px;
  background:var(--blue);box-shadow:0 4px 10px var(--ring)}
.checklist li::after{content:"";position:absolute;left:7px;top:8px;width:6px;height:10px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;counter-reset:s}
.step{background:#fff;border:1px solid #e7eaee;border-radius:var(--radius);padding:24px 18px;position:relative}
.step::before{counter-increment:s;content:counter(s);font-family:var(--font-display);font-weight:700;font-size:1.1rem;
  display:grid;place-items:center;width:40px;height:40px;border-radius:50%;background:var(--navy);color:#fff;margin-bottom:14px}
.step h3{font-size:1.05rem;margin-bottom:6px}
.step p{font-size:.9rem;color:var(--steel);margin:0}

/* ===== FAQ ===== */
.faq details{background:#fff;border:1px solid #e7eaee;border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq summary{font-family:var(--font-display);font-weight:600;padding:18px 20px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--blue);transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 20px 20px;color:var(--steel);margin:0}

/* ===== Forms ===== */
.quote-form{display:grid;gap:14px}
.quote-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px;color:var(--navy)}
.field input,.field select,.field textarea{width:100%;padding:13px 14px;border:1.5px solid #d7dde4;border-radius:10px;font:inherit;background:#fff;transition:.15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px var(--ring)}
.field textarea{min-height:120px;resize:vertical}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.86rem;color:var(--steel)}
.consent input{width:auto;margin-top:4px}
.form-card{background:#fff;border:1px solid #e7eaee;border-radius:18px;padding:28px;box-shadow:var(--shadow)}

/* ===== CTA band ===== */
.cta-band{background:linear-gradient(135deg,var(--blue),#0c4ba3);color:#fff;border-radius:20px;padding:48px;text-align:center}
.cta-band h2{color:#fff;margin-bottom:10px}
.cta-band p{color:#dbe7f7;max-width:560px;margin:0 auto 24px}

/* ===== Breadcrumbs ===== */
.crumbs{font-size:.85rem;color:var(--steel);padding:16px 0}
.crumbs a{color:var(--steel)}
.crumbs a:hover{color:var(--blue)}
.crumbs span{margin:0 6px;color:#b6bec8}

/* ===== Footer ===== */
.site-footer{background:var(--navy);color:var(--silver);padding:56px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:32px;margin-bottom:36px}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:14px;text-transform:uppercase;letter-spacing:.1em}
.site-footer a{color:var(--silver);display:block;padding:4px 0;font-size:.93rem}
.site-footer a:hover{color:var(--blue-bright)}
.footer-brand p{font-size:.92rem;color:#9aa6b4;margin-top:14px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;font-size:.84rem;color:#8694a4;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* tag pills (location links) */
.pills{display:flex;flex-wrap:wrap;gap:8px}
.pills a{background:#fff;border:1px solid #dde3ea;border-radius:999px;padding:7px 14px;font-size:.86rem;color:var(--navy)}
.pills a:hover{border-color:var(--blue);color:var(--blue)}
.section--navy .pills a{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.14);color:var(--silver)}
.section--navy .pills a:hover{color:#fff;border-color:var(--blue-bright)}

/* mobile floating action */
.fab{position:fixed;right:16px;bottom:16px;z-index:90;display:none;flex-direction:column;gap:10px}
.fab a{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-lg);font-size:1.4rem}
.fab .wa{background:#25D366}
.fab .call{background:var(--blue)}

/* reveal animation */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-card{order:-1;max-width:520px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--navy);padding:14px;gap:2px;border-bottom:1px solid rgba(255,255,255,.1)}
  .nav.open{display:flex}
  .nav a{padding:12px;width:100%}
  .menu-toggle{display:block}
  .header-cta .tel-text{display:none}
  .fab{display:flex}
}
@media(max-width:620px){
  .grid-3,.grid-4,.grid-2{grid-template-columns:1fr}
  .quote-form .row{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .section{padding:52px 0}
  .cta-band{padding:32px 22px}
  .hero-trust{gap:18px}
  .footer-grid{grid-template-columns:1fr}
  body{font-size:16px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
