/* =====================================================================
   Standard Exteriors & Roofing — main stylesheet
   Ported from the approved homepage prototype. Palette lives in :root
   below AND in theme.json (editor). Keep them in sync.
   ===================================================================== */
:root{
  --storm-900:#0F1D2E;   /* navy deep */
  --storm-800:#16293D;   /* navy */
  --storm-700:#22384F;   /* lighter navy surface */
  --slate:#3A4856;
  --slate-light:#6B7682;
  --orange:#E27B4C;
  --orange-dark:#C25E2E;
  --orange-deep:#A84B22;
  --orange-soft:#FBEEE6;
  --blue:#3E7CB1;
  --blue-light:#9FC5E0;
  --paper:#F7F7F5;
  --white:#ffffff;
  --ink:#2E353B;
  --line:#E4E7EA;
  --good:#1f8a4c;
  --bad:#c0392b;
  --shadow-lg:0 24px 60px -18px rgba(15,29,46,.42);
  --shadow-md:0 10px 30px -12px rgba(15,29,46,.22);
  --font-display:'Saira Condensed',system-ui,sans-serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.02;letter-spacing:-.01em;text-transform:uppercase;font-weight:700}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:min(1200px,92%);margin-inline:auto}
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.03em;font-weight:700;font-size:1.05rem;padding:.95rem 1.6rem;border-radius:8px;cursor:pointer;border:none;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;line-height:1}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 8px 20px -8px rgba(226,123,76,.7)}
.btn-primary:hover{background:var(--orange-dark);transform:translateY(-2px)}
.btn-primary[disabled]{opacity:.6;cursor:wait;transform:none}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.35)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-lg{font-size:1.2rem;padding:1.15rem 1.9rem}
.eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.22em;font-weight:600;font-size:.82rem;color:var(--orange)}

/* IMAGE SLOTS — replace with client-supplied images */
.imgslot{position:relative;background:repeating-linear-gradient(45deg,#ECEEF0,#ECEEF0 12px,#F2F3F5 12px,#F2F3F5 24px);border:1px dashed #C2C9D0;border-radius:10px;display:flex;align-items:center;justify-content:center;text-align:center;color:#8A929B;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;padding:1rem;min-height:160px}
.imgslot span{max-width:80%}

/* TOP UTILITY BAR */
.util{background:var(--storm-900);color:#cdd6e0;font-size:.85rem;border-top:3px solid var(--blue)}
.util .wrap{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;gap:1rem;flex-wrap:wrap}
.util a{color:#cdd6e0}
.util .util-r{display:flex;gap:1.4rem;align-items:center}
.util .stars{color:#ffc24a;letter-spacing:1px}

/* HEADER */
.site-header{position:sticky;top:0;z-index:50;background:rgba(15,29,46,.97);backdrop-filter:blur(8px);box-shadow:0 1px 0 rgba(255,255,255,.06);transition:padding .25s ease}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;padding:.85rem 0;transition:padding .25s ease}
.site-header.shrink .wrap{padding:.5rem 0}
.logo{font-family:var(--font-display);font-weight:800;color:#fff;font-size:1.45rem;letter-spacing:.01em;line-height:.95;text-transform:uppercase}
.logo small{display:block;font-size:.62rem;letter-spacing:.34em;color:var(--orange);font-weight:600}
.logo img{max-height:54px;width:auto}
nav.main{display:flex;gap:1.6rem;align-items:center}
nav.main a{color:#dbe3ec;font-weight:600;font-size:.95rem;letter-spacing:.01em;transition:color .15s}
nav.main a:hover{color:#fff}
.header-cta{display:flex;align-items:center;gap:1rem}
.header-phone{color:#fff;font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:.01em;white-space:nowrap}
.header-phone small{display:block;font-family:var(--font-body);font-size:.62rem;letter-spacing:.18em;color:#8fa0b3;text-transform:uppercase;font-weight:600}
.menu-btn{display:none;background:none;border:none;color:#fff;cursor:pointer}

/* HERO */
.hero{position:relative;background:
    radial-gradient(120% 90% at 18% 0%,rgba(226,123,76,.18),transparent 55%),
    radial-gradient(120% 120% at 90% 10%,rgba(62,124,177,.30),transparent 60%),
    linear-gradient(180deg,var(--storm-800),var(--storm-900));
  color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");pointer-events:none}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:3.2rem;align-items:center;padding:3.6rem 0 4rem}
.hero-copy{max-width:600px}
.storm-tag{display:inline-flex;align-items:center;gap:.5rem;background:rgba(226,123,76,.16);border:1px solid rgba(226,123,76,.45);color:#F0B493;padding:.4rem .85rem;border-radius:100px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;font-weight:600;margin-bottom:1.3rem}
.storm-tag .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 0 rgba(226,123,76,.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(226,123,76,.6)}70%{box-shadow:0 0 0 10px rgba(226,123,76,0)}100%{box-shadow:0 0 0 0 rgba(226,123,76,0)}}
.hero h1{font-size:clamp(2.6rem,5.4vw,4.4rem);font-weight:800}
.hero h1 em{font-style:normal;color:var(--orange)}
.hero p.sub{font-size:1.18rem;color:#c8d3df;margin:1.2rem 0 1.7rem;max-width:32em}
.hero-actions{display:flex;align-items:center;gap:1.3rem;flex-wrap:wrap}
.call-block{display:flex;flex-direction:column}
.call-block .lbl{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#8fa0b3;font-weight:600;margin-bottom:.15rem}
.call-block a{font-family:var(--font-display);font-weight:800;font-size:2rem;color:#fff;letter-spacing:.01em}
.hero-trust{display:flex;gap:1.6rem;margin-top:2rem;flex-wrap:wrap}
.hero-trust div{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#c8d3df;font-weight:500}
.hero-trust svg{flex:none;color:var(--blue-light)}

/* HERO FORM */
.quote-card{background:var(--white);color:var(--ink);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid rgba(0,0,0,.04)}
.quote-head{background:linear-gradient(120deg,var(--storm-700),var(--slate));color:#fff;padding:1.2rem 1.5rem}
.quote-head h3{font-size:1.5rem;font-weight:700}
.quote-head p{font-size:.86rem;color:#cdd6e0;text-transform:none;font-family:var(--font-body);margin-top:.15rem}
.quote-body{padding:1.4rem 1.5rem 1.6rem}
.steps{display:flex;gap:.4rem;margin-bottom:1.1rem}
.steps .s{flex:1;height:5px;border-radius:100px;background:var(--line)}
.steps .s.active{background:var(--orange)}
.field{margin-bottom:.9rem}
.field label{display:block;font-weight:600;font-size:.82rem;margin-bottom:.35rem;color:var(--slate)}
.field input,.field select{width:100%;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:8px;font-family:var(--font-body);font-size:1rem;background:#fcfbf9;transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(226,123,76,.16)}
.chips{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
.chip{position:relative}
.chip input{position:absolute;opacity:0;pointer-events:none}
.chip label{display:flex;align-items:center;justify-content:center;text-align:center;gap:.4rem;padding:.7rem .5rem;border:1.5px solid var(--line);border-radius:8px;cursor:pointer;font-weight:600;font-size:.9rem;margin:0;color:var(--slate);transition:all .15s;background:#fcfbf9}
.chip input:checked+label{border-color:var(--orange);background:var(--orange-soft);color:var(--orange-dark)}
.form-step{display:none;animation:fade .3s ease}
.form-step.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.quote-foot{font-size:.74rem;color:var(--slate-light);text-align:center;margin-top:.9rem;line-height:1.4}
.quote-foot strong{color:var(--good)}
.btn-full{width:100%;justify-content:center}
.back-link{background:none;border:none;color:var(--slate-light);font-weight:600;cursor:pointer;font-size:.85rem;margin-top:.7rem;display:block;width:100%;text-align:center;font-family:var(--font-body)}
.success{text-align:center;padding:1.5rem .5rem}
.success svg{color:var(--good);margin-bottom:.6rem}
.success h3{color:var(--ink);font-size:1.6rem}
.form-error{background:#fdecea;border:1px solid #f5c6c0;color:var(--bad);font-size:.82rem;padding:.6rem .8rem;border-radius:8px;margin-bottom:.8rem;display:none}
.form-error.show{display:block}
/* Honeypot — keep off-screen, never display:none (bots skip hidden) */
.hp-field{position:absolute!important;left:-9999px!important;top:-9999px!important;height:0;width:0;overflow:hidden}

/* TRUST STRIP */
.trust-strip{background:var(--ink);color:#fff}
.trust-strip .wrap{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.1rem 0;flex-wrap:wrap}
.trust-strip .ti{display:flex;align-items:center;gap:.7rem}
.trust-strip .ti b{font-family:var(--font-display);font-size:1.7rem;font-weight:800;color:#fff;line-height:1}
.trust-strip .ti span{font-size:.82rem;color:#aeb9c4;line-height:1.2}
.trust-strip .stars{color:#ffc24a;font-size:1.1rem;letter-spacing:1px}

/* SECTION BASICS */
.section{padding:4.5rem 0}
.sec-head{max-width:680px;margin-bottom:2.6rem}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,3rem);margin:.5rem 0 .6rem;color:var(--ink)}
.sec-head p{color:var(--slate);font-size:1.08rem}
.eyebrow{display:inline-block}
.eyebrow::after{content:"";display:block;width:44px;height:3px;border-radius:2px;background:var(--blue);margin-top:.55rem}
.sec-head.center .eyebrow::after{margin-inline:auto}

/* STORM / INSURANCE */
.storm{background:linear-gradient(180deg,var(--storm-800),var(--storm-900));color:#fff}
.storm .grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.storm h2{color:#fff;font-size:clamp(2rem,3.8vw,3.1rem)}
.storm .eyebrow{color:#ffb48f}
.storm p{color:#c8d3df;font-size:1.08rem;margin:1rem 0}
.claim-list{list-style:none;margin:1.4rem 0}
.claim-list li{display:flex;gap:.8rem;align-items:flex-start;margin-bottom:.9rem;font-size:1.02rem}
.claim-list svg{flex:none;color:var(--orange);margin-top:3px}
.storm-visual{position:relative}
.storm-visual .imgslot{min-height:380px;background:repeating-linear-gradient(45deg,#1a3149,#1a3149 12px,#20394f 12px,#20394f 24px);border-color:#35536f;color:#88a6c2}
.storm-badge{position:absolute;bottom:-22px;left:-22px;background:var(--orange);color:#fff;border-radius:12px;padding:1rem 1.3rem;box-shadow:var(--shadow-lg);max-width:230px}
.storm-badge b{font-family:var(--font-display);font-size:1.3rem;display:block;line-height:1}
.storm-badge span{font-size:.84rem}

/* SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.svc{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:transform .2s,box-shadow .2s}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.svc .imgslot{border:none;border-radius:0;min-height:190px}
.svc-body{padding:1.3rem 1.4rem 1.5rem}
.svc-body h3{font-size:1.5rem;color:var(--ink);margin-bottom:.4rem}
.svc-body p{color:var(--slate);font-size:.95rem;margin-bottom:.9rem}
.svc-body a{color:var(--orange-dark);font-weight:700;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em;font-size:.95rem;display:inline-flex;align-items:center;gap:.35rem}
.svc-body a:hover{gap:.6rem;transition:gap .15s}

/* PROOF / PROJECTS */
.proj{background:#fff}
.proj-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.proj-grid .imgslot:nth-child(1){grid-column:span 2;grid-row:span 2}
.proj-grid .imgslot:nth-child(4){grid-row:span 2}

/* PROCESS */
.process{background:var(--paper)}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step}
.pstep{position:relative;padding-top:1rem}
.pstep .num{font-family:var(--font-display);font-weight:800;font-size:3.2rem;color:var(--orange);line-height:1;opacity:.9}
.pstep h3{font-size:1.4rem;color:var(--ink);margin:.3rem 0 .5rem}
.pstep p{color:var(--slate);font-size:.96rem}

/* REVIEWS */
.reviews{background:var(--storm-900);color:#fff}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.rev{background:var(--storm-700);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1.6rem}
.rev .stars{color:#ffc24a;letter-spacing:2px;font-size:1.05rem;margin-bottom:.7rem}
.rev p{color:#dbe3ec;font-size:1rem;margin-bottom:1rem}
.rev .who{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.95rem}
.rev .who span{display:block;font-family:var(--font-body);text-transform:none;letter-spacing:0;color:#8fa0b3;font-size:.8rem;font-weight:500}

/* SERVICE AREA */
.area{background:#fff}
.area .grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.towns{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.2rem}
.towns span{background:var(--orange-soft);color:var(--orange-dark);padding:.45rem .9rem;border-radius:100px;font-weight:600;font-size:.92rem}
.area .imgslot{min-height:340px}

/* FAQ */
.faq{background:var(--paper)}
.faq-list{max-width:820px;margin-inline:auto}
details{background:#fff;border:1px solid var(--line);border-radius:10px;margin-bottom:.8rem;overflow:hidden}
details summary{padding:1.1rem 1.3rem;font-family:var(--font-display);font-weight:600;font-size:1.18rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;color:var(--ink);text-transform:none}
details summary::-webkit-details-marker{display:none}
details summary .ic{color:var(--orange);transition:transform .2s;flex:none;font-size:1.5rem;font-family:var(--font-body)}
details[open] summary .ic{transform:rotate(45deg)}
details .ans{padding:0 1.3rem 1.2rem;color:var(--slate);font-size:1rem}

/* FINAL CTA */
.final{background:linear-gradient(120deg,var(--orange),var(--orange-dark));color:#fff;text-align:center}
.final h2{color:#fff;font-size:clamp(2.2rem,4vw,3.4rem)}
.final p{font-size:1.2rem;max-width:34em;margin:1rem auto 1.8rem;color:#ffe6d8}
.final .actions{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap;align-items:center}
.final .btn-primary{background:#fff;color:var(--orange-dark)}
.final .btn-primary:hover{background:#fff7f2}
.final a.callbig{font-family:var(--font-display);font-weight:800;color:#fff;font-size:2rem;letter-spacing:.01em}

/* FOOTER */
.site-footer{background:var(--storm-900);color:#aeb9c4;padding:3.5rem 0 6.5rem}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:2.4rem;padding-bottom:2.4rem;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-grid h4{color:#fff;font-size:1.05rem;letter-spacing:.05em;margin-bottom:1rem}
.foot-grid a{color:#aeb9c4;display:block;margin-bottom:.5rem;font-size:.94rem}
.foot-grid a:hover{color:#fff}
.foot-logo{font-family:var(--font-display);font-weight:800;color:#fff;font-size:1.5rem;text-transform:uppercase}
.foot-logo small{display:block;font-size:.6rem;letter-spacing:.32em;color:var(--orange)}
.foot-bottom{padding-top:1.5rem;font-size:.84rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}

/* STICKY MOBILE BAR */
.mobilebar{position:fixed;bottom:0;left:0;right:0;z-index:60;display:none;grid-template-columns:1fr 1fr;background:var(--storm-900);box-shadow:0 -6px 20px rgba(0,0,0,.3)}
.mobilebar a{padding:1rem;text-align:center;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#fff;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1.02rem}
.mobilebar a.call{background:var(--storm-700)}
.mobilebar a.quote{background:var(--orange)}

/* RESPONSIVE */
@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:2.4rem}
  .quote-card{max-width:520px}
  .storm .grid,.area .grid{grid-template-columns:1fr;gap:2rem}
  .svc-grid,.rev-grid,.steps-grid{grid-template-columns:1fr 1fr}
  .proj-grid{grid-template-columns:1fr 1fr}
  .proj-grid .imgslot:nth-child(1){grid-column:span 2}
  nav.main,.header-cta .header-phone{display:none}
}
@media(max-width:640px){
  .util .util-r{display:none}
  .svc-grid,.rev-grid,.steps-grid,.proj-grid{grid-template-columns:1fr}
  .proj-grid .imgslot:nth-child(1){grid-column:span 1}
  .menu-btn{display:block}
  .mobilebar{display:grid}
  .site-footer{padding-bottom:7rem}
  .foot-grid{grid-template-columns:1fr 1fr}
  .hero-trust{gap:1rem}
}
