  :root{
    --bg:#000000;
    --bg-2:#0a0a0a;
    --bg-3:#141414;
    --line:#252525;
    --line-strong:#404040;
    --ink:#ffffff;
    --ink-mute:#c8c8c8;
    --ink-dim:#8a8a8a;
    --accent:#e8451f;      /* logo orange */
    --accent-2:#ff6a3d;    /* lighter orange */
    --accent-deep:#8c2710;
    --ok:#7fbf7f;
    --r:4px;
    --maxw:1320px;
    --pad:clamp(20px, 3vw, 48px);
    --font-display:"Oswald", "Inter", system-ui, sans-serif;
    --font-sans:"Inter", system-ui, -apple-system, Segoe UI, sans-serif;
    --font-brand:"Oswald", "Inter", system-ui, sans-serif;
    --t-fast:180ms cubic-bezier(.2,.7,.2,1);
    --t-norm:380ms cubic-bezier(.16,1,.3,1);
  }
  *,*::before,*::after{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;background:var(--bg);color:var(--ink);
    font-family:var(--font-sans);font-size:16px;line-height:1.55;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}
  button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
  ::selection{background:var(--accent);color:#0e1014}

  .container{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
  .eyebrow{
    font-family:var(--font-display);font-size:12px;font-weight:600;
    letter-spacing:.22em;text-transform:uppercase;color:var(--accent);
    display:inline-block;
  }
  h1,h2,h3,h4{
    font-family:var(--font-display);font-weight:700;letter-spacing:.005em;line-height:1.04;margin:0;
    text-transform:uppercase;color:#fff;
  }
  h2{font-size:clamp(2.1rem, 1.3rem + 3.4vw, 4.4rem);line-height:1.02}
  h3{font-size:clamp(1.35rem, 1rem + 1.2vw, 1.9rem);line-height:1.08;font-weight:600}
  p{margin:0}

  /* ---------- NAV ---------- */
  .nav{
    position:fixed;inset:0 0 auto 0;z-index:50;
    background:rgba(14,16,20,.6);backdrop-filter:saturate(140%) blur(14px);
    border-bottom:1px solid transparent;transition:border-color var(--t-fast), background var(--t-fast);
  }
  .nav{background:rgba(0,0,0,.55)}
  .nav.scrolled{background:rgba(0,0,0,.92);border-bottom-color:var(--line)}
  .nav-inner{display:flex;align-items:center;gap:32px;height:92px}
  .brand{display:inline-flex;align-items:center;line-height:0}
  .brand img{height:72px;width:auto;display:block;user-select:none;-webkit-user-drag:none}
  .foot-brand .brand img{height:96px}
  @media(max-width:880px){
    .nav-inner{height:76px}
    .brand img{height:56px}
  }
  .nav-links{display:flex;gap:30px;margin-left:auto;font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#d0d0d0}
  .nav-links a{position:relative;padding:6px 0;transition:color var(--t-fast)}
  .nav-links a:hover{color:#fff}
  .nav-links a::after{
    content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--accent);
    transition:width var(--t-norm);
  }
  .nav-links a:hover::after{width:100%}
  .nav-cta{display:flex;align-items:center;gap:12px}
  .nav-social{display:none;gap:8px;align-items:center;margin-right:4px}
  .nav-social a{
    width:32px;height:32px;display:grid;place-items:center;border-radius:50%;
    border:1px solid var(--line-strong);color:#c8c8c8;
    transition:color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
  }
  .nav-social a:hover{color:#0a0a0a;background:var(--accent);border-color:var(--accent)}
  @media(min-width:980px){.nav-social{display:inline-flex}}
  .phone{font-family:var(--font-display);font-variant-numeric:tabular-nums;font-size:13px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:#c8c8c8;display:none}
  .phone strong{color:#fff;font-weight:700}
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    padding:14px 22px;border-radius:var(--r);
    font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
    transition:transform var(--t-fast), background var(--t-fast), color var(--t-fast), box-shadow var(--t-fast);
    will-change:transform;
  }
  .btn .arrow{transition:transform var(--t-norm)}
  .btn:hover .arrow{transform:translateX(4px)}
  .btn-primary{background:var(--accent);color:#0a0a0a}
  .btn-primary:hover{background:var(--accent-2);box-shadow:0 10px 32px -8px var(--accent)}
  .btn-ghost{border:1px solid var(--line-strong);color:var(--ink)}
  .btn-ghost:hover{border-color:var(--accent-2);color:var(--accent-2)}
  .btn-lg{padding:18px 26px;font-size:14px}
  .menu-btn{display:none;width:40px;height:40px;border:1px solid var(--line-strong);border-radius:4px;align-items:center;justify-content:center}

  @media(min-width:780px){.phone{display:block}}
  @media(max-width:880px){
    .nav-links{display:none}
    .menu-btn{display:flex}
  }

  /* ---------- HERO ---------- */
  .hero{
    position:relative;padding:180px 0 100px;overflow:hidden;isolation:isolate;
    background:#000 url("arndt-hero.jpg?v=3") center right / cover no-repeat;
  }
  .hero-bg{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    z-index:0;pointer-events:none;
  }
  .hero::before{
    content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
    background:linear-gradient(95deg, rgba(0,0,0,.94) 0%, rgba(0,0,0,.82) 28%, rgba(0,0,0,.55) 55%, rgba(0,0,0,.3) 80%, rgba(0,0,0,.45) 100%);
  }
  .hero::after{
    content:"";position:absolute;left:0;right:0;bottom:0;height:40%;z-index:1;
    background:linear-gradient(180deg, rgba(0,0,0,0), #000 90%);
    pointer-events:none;
  }
  .hero .container{position:relative;z-index:2}
  @media (prefers-reduced-motion: reduce){.hero-bg{display:none}}
  .hero-grid{display:block;max-width:760px}
  .hero h1{
    font-family:var(--font-display);font-weight:700;font-size:clamp(2.4rem, 1.2rem + 4.2vw, 5.4rem);
    line-height:1;letter-spacing:0;text-transform:uppercase;
    text-shadow:0 2px 30px rgba(0,0,0,.7);
  }
  .hero h1 em{font-style:normal;color:var(--accent);font-weight:700}
  .hero-lead{
    margin-top:28px;max-width:48ch;font-size:clamp(1rem, .95rem + .25vw, 1.18rem);
    color:#e2e2e2;line-height:1.55;text-shadow:0 1px 16px rgba(0,0,0,.7);
  }
  .hero-actions{margin-top:40px;display:flex;flex-wrap:wrap;gap:14px;align-items:center}
  .hero-meta{
    margin-top:56px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;max-width:560px;
    border-top:1px solid rgba(255,255,255,.18);padding-top:24px;
  }
  .hero-meta .k{font-family:var(--font-display);font-size:2.2rem;font-weight:700;letter-spacing:0;color:#fff;line-height:1}
  .hero-meta .v{font-family:var(--font-sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#c8c8c8;margin-top:10px;font-weight:600}

  @media(max-width:880px){
    .hero{
      padding:140px 0 80px;
      background-image:url("arndt-hero.jpg?v=3");
      background-position:center center;
    }
    .hero-bg{display:none}
    .hero::before{
      background:linear-gradient(180deg, rgba(0,0,0,.88) 0%, rgba(0,0,0,.7) 40%, rgba(0,0,0,.85) 100%);
    }
  }

  .marquee{
    position:relative;z-index:2;margin-top:80px;
    background:#000;
    border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);
    overflow:hidden;
  }
  .marquee-track{
    display:flex;gap:56px;padding:22px 0;white-space:nowrap;
    animation:scroll 38s linear infinite;
  }
  .marquee span{
    font-family:var(--font-display);font-style:normal;font-size:22px;font-weight:600;
    color:#fff;display:inline-flex;align-items:center;gap:56px;
    letter-spacing:.16em;text-transform:uppercase;
  }
  .marquee span::after{content:"✦";color:var(--accent);font-size:16px;letter-spacing:0}
  @keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* ---------- SECTION SCAFFOLD ---------- */
  section{padding:120px 0;position:relative}
  .sec-head{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:end;margin-bottom:64px}
  @media(max-width:880px){.sec-head{grid-template-columns:1fr;gap:24px}}
  .sec-head .lede{color:#d4d4d4;max-width:50ch;font-size:17.5px;line-height:1.6;font-weight:400}

  /* ---------- SERVICES ---------- */
  #services{background:var(--bg-2)}
  .svc-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
  .svc{
    grid-column:span 6;position:relative;border:1px solid var(--line);border-radius:8px;overflow:hidden;
    background:var(--bg-3);min-height:420px;display:flex;flex-direction:column;justify-content:flex-end;
    transition:transform var(--t-norm), border-color var(--t-norm);
  }
  .svc:hover{transform:translateY(-4px);border-color:var(--line-strong)}
  .svc-img{position:absolute;inset:0;z-index:0}
  .svc-img img{width:100%;height:100%;object-fit:cover;opacity:.55;transition:transform 800ms ease, opacity var(--t-norm)}
  .svc:hover .svc-img img{transform:scale(1.04);opacity:.65}
  .svc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.85) 70%, rgba(0,0,0,.96))}
  .svc-body{position:relative;z-index:1;padding:32px}
  .svc-num{font-family:var(--font-display);font-size:13px;color:var(--accent);letter-spacing:.18em;text-transform:uppercase;font-weight:600}
  .svc h3{margin-top:10px}
  .svc p{margin-top:16px;color:#d4d4d4;max-width:46ch;font-size:15.5px;line-height:1.6}
  .svc-link{margin-top:24px;display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);font-weight:600}
  .svc-link svg{transition:transform var(--t-norm)}
  .svc:hover .svc-link svg{transform:translateX(4px)}
  .svc:nth-child(1){grid-column:span 7}
  .svc:nth-child(2){grid-column:span 5}
  .svc:nth-child(3){grid-column:span 5}
  .svc:nth-child(4){grid-column:span 7}
  @media(max-width:880px){.svc,.svc:nth-child(n){grid-column:span 12;min-height:360px}}

  /* ---------- INSURANCE ---------- */
  #insurance{padding:140px 0}
  .ins-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:start}
  @media(max-width:1024px){.ins-grid{grid-template-columns:1fr;gap:48px}}
  .ins-lead{font-size:18px;color:#d4d4d4;margin-top:28px;max-width:54ch;line-height:1.6}
  .ins-steps{display:flex;flex-direction:column;gap:0}
  .step{display:grid;grid-template-columns:auto 1fr;gap:28px;padding:32px 0;border-top:1px solid var(--line)}
  .step:last-child{border-bottom:1px solid var(--line)}
  .step-label{
    font-family:var(--font-display);font-size:64px;font-weight:700;line-height:1;color:var(--accent);letter-spacing:0;
    width:80px;
  }
  .step h4{font-family:var(--font-display);font-size:22px;font-weight:700;margin:0;letter-spacing:.01em;text-transform:uppercase;color:#fff}
  .step p{margin-top:10px;color:var(--ink-mute);font-size:15.5px;max-width:52ch;line-height:1.6}

  .ins-card{
    margin-top:36px;padding:28px;border:1px solid var(--line);border-radius:8px;background:var(--bg-2);
    display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  }
  .ins-card .big{font-family:var(--font-display);font-size:54px;font-weight:700;letter-spacing:0;color:var(--accent);line-height:1}
  .ins-card .sub{font-size:14px;color:var(--ink-mute);margin-top:8px;line-height:1.5}

  .badges{margin-top:40px;display:flex;flex-wrap:wrap;gap:10px}
  .badge{
    padding:10px 16px;border:1px solid var(--line-strong);border-radius:999px;
    font-family:var(--font-display);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#c8c8c8;font-weight:500;
  }
  .badge strong{color:var(--accent);font-weight:600}

  /* ---------- WORK ---------- */
  #work{background:var(--bg-2);padding:140px 0}
  .work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
  .tile{position:relative;overflow:hidden;border-radius:6px;background:#000;aspect-ratio:1/1;border:1px solid rgba(255,255,255,.04)}
  .tile img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s ease, filter var(--t-norm);filter:saturate(90%)}
  .tile:hover img{transform:scale(1.05);filter:saturate(115%)}
  .tile-cap{position:absolute;left:18px;bottom:18px;right:18px;font-family:var(--font-display);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#fff;display:flex;justify-content:space-between;gap:12px;z-index:1;font-weight:600}
  .tile-cap .tag{color:var(--accent)}
  .tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.82))}
  @media(max-width:880px){.work-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:560px){.work-grid{grid-template-columns:1fr}}

  /* ---------- TESTIMONIALS ---------- */
  #voices{padding:140px 0}
  .voices{margin-top:56px;column-count:2;column-gap:28px}
  @media(max-width:720px){.voices{column-count:1}}
  .voice{
    display:block;break-inside:avoid;margin:0 0 28px;
    border-radius:10px;overflow:hidden;background:#fff;
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 30px 60px -28px rgba(0,0,0,.7);
    transition:transform var(--t-norm), box-shadow var(--t-norm);
  }
  .voice:hover{transform:translateY(-3px);box-shadow:0 36px 70px -24px rgba(232,69,31,.25)}
  .voice img{width:100%;height:auto;display:block}
  .voice .meta{
    display:flex;align-items:center;gap:10px;
    padding:12px 18px;background:#fafafa;
    border-top:1px solid #ececec;
    font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    color:#6f6f6f;font-weight:600;
  }
  .voice .meta svg{flex-shrink:0;color:#1877f2}
  .voice .meta .who{color:#1a1a1a;letter-spacing:.04em}
  .voice .meta .when{margin-left:auto;color:#8a8a8a;letter-spacing:.06em;font-weight:500}

  .voices-foot{margin-top:8px;display:flex;justify-content:center}
  .voices-foot a{
    display:inline-flex;align-items:center;gap:12px;
    padding:16px 26px;border:1px solid var(--line-strong);border-radius:6px;
    color:#fff;font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
    transition:border-color var(--t-fast), background var(--t-fast), color var(--t-fast), transform var(--t-fast);
  }
  .voices-foot a:hover{border-color:var(--accent);background:var(--accent);color:#0a0a0a;transform:translateY(-2px)}
  .voices-foot svg{flex-shrink:0}

  /* ---------- AREAS ---------- */
  #areas{padding:140px 0;background:var(--bg-2)}
  .areas-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;margin-top:48px;align-items:stretch}
  @media(max-width:1024px){.areas-grid{grid-template-columns:1fr;gap:32px}}
  .areas-list h4{
    font-family:var(--font-display);font-size:13px;font-weight:600;
    letter-spacing:.2em;text-transform:uppercase;color:var(--accent);
    margin:0 0 16px;
  }
  .areas-list h4:not(:first-child){margin-top:36px}
  .areas-list ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}
  .areas-list ul.full{grid-template-columns:1fr 1fr 1fr}
  @media(max-width:560px){.areas-list ul, .areas-list ul.full{grid-template-columns:1fr 1fr}}
  .areas-list li{
    font-family:var(--font-display);font-size:15px;font-weight:500;
    letter-spacing:.04em;text-transform:uppercase;color:#fff;
    padding:6px 0;border-bottom:1px solid var(--line);
  }
  .areas-cta{
    margin-top:36px;padding:22px;border:1px solid var(--line-strong);border-radius:8px;
    color:#d4d4d4;font-size:15px;line-height:1.55;
  }
  .areas-cta strong{color:#fff;font-weight:600}
  .map-wrap{
    position:relative;min-height:480px;border-radius:8px;overflow:hidden;
    border:1px solid var(--line);background:var(--bg-3);
  }
  .map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:invert(92%) hue-rotate(180deg) brightness(.95)}

  /* ---------- BLOG ---------- */
  #blog{padding:140px 0}
  .posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
  @media(max-width:880px){.posts{grid-template-columns:1fr}}
  .post{
    display:flex;flex-direction:column;
    padding:32px;border:1px solid var(--line);border-radius:8px;background:var(--bg-2);
    transition:border-color var(--t-norm), transform var(--t-norm), background var(--t-norm);
    min-height:300px;
  }
  .post:hover{border-color:var(--line-strong);transform:translateY(-3px);background:var(--bg-3)}
  .post-meta{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--ink-dim)}
  .post-meta .cat{color:var(--accent)}
  .post-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-dim)}
  .post-meta .soon{margin-left:auto;padding:4px 10px;border:1px solid var(--accent);border-radius:999px;color:var(--accent);font-size:10px;letter-spacing:.16em}
  .post h3{margin-top:18px;font-size:1.4rem;line-height:1.15;color:#fff}
  .post p{margin-top:14px;color:#c8c8c8;font-size:15px;line-height:1.6}
  .post-link{margin-top:auto;padding-top:24px;display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);font-weight:600}

  /* ---------- FAQ ---------- */
  #faq{background:var(--bg-2);padding:140px 0}
  .faq-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
  .faq{border-bottom:1px solid var(--line)}
  .faq summary{
    list-style:none;cursor:pointer;padding:30px 0;display:flex;justify-content:space-between;align-items:center;gap:24px;
    font-family:var(--font-display);font-size:clamp(1.1rem, .9rem + .9vw, 1.7rem);font-weight:600;letter-spacing:.01em;
    text-transform:uppercase;color:#fff;
    transition:color var(--t-fast);
  }
  .faq summary::-webkit-details-marker{display:none}
  .faq summary:hover{color:var(--accent-2)}
  .faq .ic{
    width:36px;height:36px;border:1px solid var(--line-strong);border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;
    color:var(--ink);flex-shrink:0;transition:transform var(--t-norm), background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
  }
  .faq .ic svg{width:14px;height:14px;display:block}
  .faq[open] .ic{transform:rotate(45deg);background:var(--accent);color:#0a0a0a;border-color:var(--accent)}
  .faq .a{padding:0 60px 32px 0;color:#d4d4d4;font-size:16.5px;max-width:78ch;line-height:1.7;font-weight:400}

  /* ---------- CONTACT ---------- */
  #contact{padding:140px 0 80px}
  .contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px}
  @media(max-width:1024px){.contact-grid{grid-template-columns:1fr;gap:48px}}
  .contact-side h2{margin-bottom:24px}
  .contact-side .lede{color:#d4d4d4;font-size:17.5px;max-width:44ch;line-height:1.6}
  .contact-meta{margin-top:48px;display:flex;flex-direction:column;gap:22px}
  .meta-row{display:grid;grid-template-columns:120px 1fr;gap:24px;align-items:baseline;padding:18px 0;border-top:1px solid var(--line)}
  .meta-row:last-child{border-bottom:1px solid var(--line)}
  .meta-row .k{font-family:var(--font-display);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-2);font-weight:600}
  .meta-row .v{font-family:var(--font-display);font-size:22px;letter-spacing:.01em;font-weight:600;text-transform:uppercase;color:#fff}

  form.estimate{
    background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:40px;
    display:grid;grid-template-columns:1fr 1fr;gap:18px;
  }
  form.estimate .full{grid-column:span 2}
  .field{display:flex;flex-direction:column;gap:8px}
  .field label{font-family:var(--font-display);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);font-weight:600}
  .field input,.field select,.field textarea{
    background:transparent;border:0;border-bottom:1px solid var(--line-strong);
    padding:10px 0;color:var(--ink);font:inherit;font-size:15px;border-radius:0;
    transition:border-color var(--t-fast);
  }
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-bottom-color:var(--accent)}
  .field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23a8a89e' fill='none' stroke-width='1.4' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center;padding-right:24px}
  .field select option{background:var(--bg-2);color:var(--ink)}
  .field textarea{resize:vertical;min-height:90px}
  form.estimate .submit-row{grid-column:span 2;margin-top:12px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
  .fineprint{font-size:12px;color:var(--ink-dim);max-width:48ch}

  /* ---------- FOOTER ---------- */
  footer{border-top:1px solid var(--line);padding:60px 0 36px;background:var(--bg)}
  .foot-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:40px}
  @media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
  .foot-brand p{color:#c8c8c8;font-size:14.5px;max-width:36ch;margin-top:18px;line-height:1.6}
  .foot-col h5{font-family:var(--font-display);font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin:0 0 18px;font-weight:600}
  .foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;font-size:14px;color:#c8c8c8;font-weight:500}
  .foot-col a:hover{color:var(--accent-2)}
  .social{margin-top:18px;display:flex;gap:10px}
  .social a{
    width:36px;height:36px;border:1px solid var(--line);border-radius:50%;
    display:grid;place-items:center;color:var(--ink-mute);
    transition:color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
  }
  .social a:hover{color:#0a0a0a;background:var(--accent);border-color:var(--accent)}
  .foot-bottom{margin-top:56px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;font-size:12px;color:var(--ink-dim);flex-wrap:wrap}

  /* ---------- MOBILE OVERRIDES ---------- */
  @media(max-width:880px){
    section,
    #services, #insurance, #work, #voices, #faq, #contact{padding:72px 0}
    .sec-head{margin-bottom:40px}
    .nav-inner{gap:14px}

    /* mobile menu */
    .menu-btn{display:flex;color:#fff;background:transparent}
    .menu-btn.open{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}
    .nav-links{
      display:flex;flex-direction:column;
      position:absolute;top:100%;left:0;right:0;
      background:#000;border-bottom:1px solid var(--line);
      gap:0;padding:0;margin:0;
      opacity:0;visibility:hidden;pointer-events:none;
      transform:translateY(-10px);
      transition:opacity 220ms ease, transform 220ms ease, visibility 220ms;
    }
    .nav-links.open{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}
    .nav-links a{padding:18px 28px;font-size:14px;border-top:1px solid var(--line)}
    .nav-links a::after{display:none}

    /* hero */
    .hero{padding:130px 0 64px}
    .hero h1{font-size:clamp(2.1rem, 1rem + 6vw, 3.2rem)}
    .hero-lead{margin-top:22px;font-size:16px}
    .hero-actions{margin-top:30px}
    .hero-actions .btn{flex:1 1 calc(50% - 7px);justify-content:center;text-align:center}
    .hero-meta{margin-top:40px;gap:14px;padding-top:20px}
    .hero-meta .k{font-size:1.5rem}
    .hero-meta .v{font-size:10px;letter-spacing:.14em}

    .marquee-track{padding:16px 0;gap:36px}
    .marquee span{font-size:18px;gap:36px;letter-spacing:.12em}

    /* services */
    .svc{min-height:340px}
    .svc-body{padding:24px}

    /* insurance */
    .step-label{font-size:44px;width:56px}
    .step{padding:22px 0;gap:18px}
    .step h4{font-size:18px}
    .ins-card{padding:22px;gap:18px}
    .ins-card .big{font-size:42px}
    .ins-card .btn{width:100%;justify-content:center}

    /* faq */
    .faq summary{padding:22px 0;gap:14px}
    .faq .ic{width:32px;height:32px}
    .faq .a{padding:0 0 24px;font-size:15.5px}

    /* contact */
    .meta-row{grid-template-columns:1fr;gap:6px;padding:14px 0}
    .meta-row .v{font-size:18px}
    form.estimate{grid-template-columns:1fr;padding:26px;gap:16px}
    form.estimate .full{grid-column:span 1}
    form.estimate .submit-row{grid-column:span 1;flex-direction:column;align-items:stretch;gap:14px}
    form.estimate .submit-row .btn{width:100%;justify-content:center}
    .fineprint{text-align:left}

    /* footer */
    .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
    .foot-brand{grid-column:span 2}
    .foot-bottom{flex-direction:column;gap:8px;text-align:left}
  }

  @media(max-width:560px){
    section,
    #services, #insurance, #work, #voices, #faq, #contact{padding:56px 0}
    .container{padding:0 18px}

    .hero{padding:120px 0 56px}
    .hero h1{font-size:clamp(2rem, 1rem + 7vw, 2.8rem);letter-spacing:-.01em}
    .hero h1 br{display:none}
    .hero-actions{flex-direction:column;align-items:stretch}
    .hero-actions .btn{width:100%;flex:none}

    .hero-meta{grid-template-columns:1fr 1fr}
    .hero-meta > div:last-child{grid-column:span 2;text-align:center}

    h2{font-size:clamp(1.8rem, 1.2rem + 3vw, 2.4rem)}
    .sec-head{grid-template-columns:1fr;gap:18px}

    .svc{min-height:300px}
    .svc h3{font-size:1.3rem}

    .step-label{font-size:36px;width:46px}

    .ins-card{flex-direction:column;align-items:stretch}
    .badges{gap:8px}
    .badge{font-size:11px;padding:8px 12px}

    .foot-grid{grid-template-columns:1fr}
    .foot-brand{grid-column:span 1}
  }

  /* ---------- REVIEW MODAL ---------- */
  .review-trigger{
    display:inline-flex;align-items:center;gap:10px;
    padding:14px 22px;border:1px solid var(--accent);border-radius:6px;background:transparent;
    color:var(--accent);font-family:var(--font-display);font-size:13px;font-weight:600;
    letter-spacing:.14em;text-transform:uppercase;cursor:pointer;
    transition:background var(--t-fast), color var(--t-fast), transform var(--t-fast);
  }
  .review-trigger:hover{background:var(--accent);color:#0a0a0a;transform:translateY(-2px)}
  .review-trigger svg{flex-shrink:0}

  .sec-head-row{display:flex;justify-content:flex-end;margin-top:24px}
  @media(min-width:881px){.sec-head-row{margin-top:-40px;justify-content:flex-end}}

  .modal-back{
    position:fixed;inset:0;z-index:100;
    background:rgba(0,0,0,.78);backdrop-filter:blur(8px);
    display:none;align-items:center;justify-content:center;
    padding:20px;opacity:0;transition:opacity 220ms ease;
  }
  .modal-back.open{display:flex;opacity:1}
  .modal{
    background:var(--bg-2);border:1px solid var(--line-strong);border-radius:12px;
    max-width:560px;width:100%;padding:36px;position:relative;
    transform:scale(.96);transition:transform 220ms cubic-bezier(.16,1,.3,1);
    box-shadow:0 40px 80px -20px rgba(0,0,0,.8);
  }
  .modal-back.open .modal{transform:scale(1)}
  .modal-close{
    position:absolute;top:18px;right:18px;
    width:36px;height:36px;border-radius:50%;border:1px solid var(--line-strong);
    background:transparent;color:#fff;cursor:pointer;display:grid;place-items:center;
    transition:background var(--t-fast), color var(--t-fast);
  }
  .modal-close:hover{background:var(--accent);border-color:var(--accent);color:#0a0a0a}
  .modal h3{font-size:1.8rem;margin:0 0 8px;letter-spacing:.005em}
  .modal p{color:#d4d4d4;font-size:15px;line-height:1.55;margin:0 0 24px;max-width:46ch}
  .review-options{display:flex;flex-direction:column;gap:12px}
  .review-opt{
    display:flex;align-items:center;gap:16px;
    padding:18px 20px;border:1px solid var(--line);border-radius:8px;
    background:var(--bg-3);color:#fff;text-decoration:none;
    transition:border-color var(--t-fast), background var(--t-fast), transform var(--t-fast);
  }
  .review-opt:hover{border-color:var(--accent);background:#1a1a1a;transform:translateX(4px)}
  .review-opt .icon{
    width:44px;height:44px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;
    background:#1a1a1a;
  }
  .review-opt .icon.g{background:#fff;color:#4285f4}
  .review-opt .icon.f{background:#1877f2;color:#fff}
  .review-opt .icon.y{background:#d32323;color:#fff}
  .review-opt .body{flex:1;min-width:0}
  .review-opt .name{font-family:var(--font-display);font-size:14px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff}
  .review-opt .desc{font-size:13px;color:#a8a8a8;margin-top:3px;line-height:1.4}
  .review-opt .arrow{color:var(--accent);flex-shrink:0;transition:transform var(--t-fast)}
  .review-opt:hover .arrow{transform:translateX(4px)}
  .modal-note{margin-top:22px;padding-top:18px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-dim);line-height:1.5}

  /* ---------- ANIM ---------- */
  .reveal{opacity:0;transform:translateY(20px);transition:opacity 800ms ease, transform 800ms cubic-bezier(.16,1,.3,1)}
  .reveal.in{opacity:1;transform:none}
  @media (prefers-reduced-motion: reduce){
    .reveal{opacity:1;transform:none;transition:none}
    .marquee-track{animation:none}
    *{transition:none!important}
  }

/* ============================================================
   MULTI-PAGE ADDITIONS
   ============================================================ */

/* nav dropdown */
.nav-dropdown{position:relative}
.nav-dropdown-toggle{
  position:relative;
  display:inline-flex;align-items:center;gap:8px;
  background:none;border:0;padding:6px 0;margin:0;cursor:pointer;
  font-family:var(--font-display);
  font-size:13px;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#d0d0d0;
  line-height:1.2;
  transition:color var(--t-fast);
}
.nav-dropdown-toggle::before{
  content:"";position:absolute;top:100%;left:-20px;right:-20px;height:24px;
  background:transparent;
}
.nav-dropdown-toggle .caret{transition:transform var(--t-fast);opacity:.8}
.nav-dropdown:hover .nav-dropdown-toggle .caret,
.nav-dropdown.open .nav-dropdown-toggle .caret{transform:rotate(180deg);opacity:1}
.nav-dropdown-toggle:hover{color:#fff}
.nav-dropdown-toggle::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--accent);
  transition:width var(--t-norm);
}
.nav-dropdown:hover .nav-dropdown-toggle::after,
.nav-dropdown.open .nav-dropdown-toggle::after{width:100%}
.nav-dropdown-menu{
  position:absolute;top:calc(100% + 14px);left:-12px;min-width:220px;
  background:#0a0a0a;border:1px solid var(--line);border-radius:6px;
  padding:8px 0;
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(-6px);
  transition:opacity 180ms ease, transform 180ms ease, visibility 180ms;
  box-shadow:0 24px 50px -20px rgba(0,0,0,.8);
  z-index:60;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu,
.nav-dropdown.open .nav-dropdown-menu{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);
}
.nav-dropdown-menu a{
  display:block;padding:12px 18px;font-size:13px;letter-spacing:.1em;
  text-transform:uppercase;font-weight:600;color:#c8c8c8;
  transition:color var(--t-fast), background var(--t-fast);
}
.nav-dropdown-menu a:hover{color:#fff;background:var(--bg-3)}
.nav-dropdown-menu a::after{display:none}
@media(max-width:880px){
  .nav-dropdown-menu{
    position:static;opacity:1;visibility:visible;pointer-events:auto;
    transform:none;box-shadow:none;border:0;background:transparent;
    margin:0;padding:0;
  }
  .nav-dropdown-toggle .caret{display:none}
  .nav-dropdown-toggle::before{display:none}
  .nav-dropdown-menu a{padding:14px 44px;font-size:13px;color:#9a9a9a}
}

/* breadcrumbs */
.crumbs{
  padding:120px 0 0;font-family:var(--font-display);font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:#8a8a8a;
}
.crumbs a{color:#c8c8c8;transition:color var(--t-fast)}
.crumbs a:hover{color:var(--accent)}
.crumbs [aria-current="page"]{color:#fff}
@media(max-width:880px){.crumbs{padding:96px 0 0}}

/* page hero (used on all sub-pages — text left, image right) */
.page-hero{
  position:relative;
  padding:120px 0 96px;
  background:#000;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.page-hero .container{position:relative;z-index:2}
.page-hero-content{max-width:52%}
.page-hero .eyebrow{margin-bottom:18px;display:inline-block}
.page-hero h1{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(2rem, 1.2rem + 3vw, 4.2rem);
  line-height:1.02;letter-spacing:0;text-transform:uppercase;color:#fff;
}
.page-hero-lede{
  margin-top:24px;
  font-size:clamp(1rem, .95rem + .3vw, 1.2rem);
  color:#d4d4d4;line-height:1.6;
}

/* The media slot — image on right half, dark-fade overlay on its left edge */
.page-hero-media{
  position:absolute;
  top:0;bottom:0;right:0;
  width:50%;
  z-index:0;
  background-color:#0a0a0a;
  background-size:cover;
  background-position:center right;
  background-repeat:no-repeat;
}
/* Soft gradient seam on the photo's left edge so it fades into the dark text area */
.page-hero.has-bg .page-hero-media::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, #000 0%, rgba(0,0,0,.55) 18%, rgba(0,0,0,0) 45%);
  pointer-events:none;
}
/* Placeholder when no image is set */
.page-hero-media.is-placeholder{
  background:
    repeating-linear-gradient(45deg, transparent 0, transparent 18px, rgba(255,255,255,.018) 18px, rgba(255,255,255,.018) 36px),
    linear-gradient(135deg, #141414 0%, #0a0a0a 100%);
  border-left:1px dashed var(--line-strong);
}
.page-hero-media.is-placeholder::after{
  content:"Image area";
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:.24em;text-transform:uppercase;color:#3a3a3a;
}

/* Tablet/mobile: text full-width, hide the side media slot */
@media(max-width:1024px){
  .page-hero{padding:96px 0 72px}
  .page-hero-content{max-width:100%}
  .page-hero-media{display:none}
}
@media(max-width:880px){
  .page-hero{padding:80px 0 56px}
}

/* prose layout (used on most content pages) */
.prose{padding:80px 0}
.prose-grid{
  display:grid;grid-template-columns:minmax(0, 1.7fr) minmax(0, 1fr);
  gap:64px;align-items:start;
}
@media(max-width:1024px){.prose-grid{grid-template-columns:1fr;gap:40px}}
.prose-main h2{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.6rem, 1.1rem + 1.8vw, 2.4rem);
  line-height:1.1;letter-spacing:.005em;text-transform:uppercase;color:#fff;
  margin-top:48px;
}
.prose-main h2:first-child{margin-top:0}
.prose-main h3{
  font-family:var(--font-display);font-weight:600;font-size:1.35rem;
  letter-spacing:.005em;text-transform:uppercase;color:#fff;
  margin-top:32px;
}
.prose-main p{color:#d0d0d0;font-size:16px;line-height:1.7;margin:14px 0}
.prose-main p strong{color:#fff;font-weight:600}
.prose-main a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose-main a:hover{color:#fff}
.prose-main ul, .prose-main ol{padding-left:24px;margin:18px 0;color:#d0d0d0;line-height:1.7}
.prose-main ul li, .prose-main ol li{margin:8px 0}
.prose-main ul.checks{list-style:none;padding-left:0}
.prose-main ul.checks li{position:relative;padding-left:28px;margin:10px 0}
.prose-main ul.checks li::before{
  content:"\2713";position:absolute;left:0;top:0;
  color:var(--accent);font-weight:700;font-size:14px;
  font-family:var(--font-display);line-height:1.7;
}
.prose-main ul.checks.bad li::before{content:"\2717";color:#d97878}
.prose-main ul.related li{margin:6px 0}
.prose-main ol.numbered{counter-reset:item;list-style:none;padding-left:0}
.prose-main ol.numbered li{
  counter-increment:item;position:relative;padding-left:48px;margin:14px 0;
}
.prose-main ol.numbered li::before{
  content:counter(item, decimal-leading-zero);
  position:absolute;left:0;top:0;
  font-family:var(--font-display);font-weight:700;font-size:14px;
  color:var(--accent);letter-spacing:.04em;line-height:1.7;
}
.prose-main ol.numbered.big li{padding-left:64px;margin:32px 0}
.prose-main ol.numbered.big li h3{margin:0 0 8px;font-size:1.25rem;text-transform:uppercase}
.prose-main ol.numbered.big li p{margin:0;color:#c8c8c8}
.prose-main ol.numbered.big li::before{
  font-size:32px;line-height:1;color:var(--accent);
}

.prose-aside{position:sticky;top:120px}
@media(max-width:1024px){.prose-aside{position:static}}
.aside-card{
  background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  padding:24px;margin-bottom:18px;
}
.aside-card.urgent{border-color:var(--accent)}
.aside-card h4{
  font-family:var(--font-display);font-weight:700;font-size:14px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent);
  margin:0 0 12px;
}
.aside-card p{color:#d0d0d0;font-size:14px;margin:0 0 14px;line-height:1.55}
.aside-card .btn{display:inline-flex;font-size:12px;padding:11px 16px}
.aside-card ul{list-style:none;padding:0;margin:0;font-size:14px}
.aside-card ul li{padding:6px 0;border-bottom:1px solid var(--line);color:#c8c8c8}
.aside-card ul li:last-child{border-bottom:0}
.aside-card ul a{color:#c8c8c8}
.aside-card ul a:hover{color:var(--accent-2)}

.prose-block{max-width:760px;margin:0 auto}
.prose-block h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.6rem,1.1rem+1.8vw,2.4rem);line-height:1.1;text-transform:uppercase;color:#fff}
.prose-block p{color:#d0d0d0;font-size:16px;line-height:1.7;margin:14px 0}

/* article body (learn articles) */
.article{padding:60px 0}
.article-head{max-width:760px;margin:0 auto 48px}
.article-meta{
  display:flex;gap:12px;align-items:center;flex-wrap:wrap;
  font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:#8a8a8a;
}
.article-meta .cat{color:var(--accent)}
.article-head h1{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(2rem, 1.4rem + 2.8vw, 3.6rem);
  line-height:1.08;letter-spacing:0;text-transform:uppercase;color:#fff;
  margin:20px 0 24px;
}
.article-lede{
  font-size:clamp(1.1rem, 1rem + .35vw, 1.32rem);
  color:#d4d4d4;line-height:1.55;font-weight:400;
}
.article-body{max-width:720px;margin:0 auto;color:#d0d0d0}
.article-body h2{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.5rem, 1.1rem + 1.4vw, 2rem);
  line-height:1.15;text-transform:uppercase;color:#fff;
  margin:48px 0 18px;letter-spacing:.005em;
}
.article-body h3{
  font-family:var(--font-display);font-weight:600;
  font-size:1.25rem;text-transform:uppercase;color:#fff;
  margin:32px 0 14px;
}
.article-body p{font-size:17px;line-height:1.75;margin:14px 0;color:#d0d0d0}
.article-body p strong{color:#fff;font-weight:600}
.article-body p em{color:var(--accent-2);font-style:italic}
.article-body a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px}
.article-body ul, .article-body ol{padding-left:24px;margin:18px 0;line-height:1.75}
.article-body ul.checks{list-style:none;padding-left:0}
.article-body ul.checks li{position:relative;padding-left:28px;margin:10px 0}
.article-body ul.checks li::before{
  content:"\2713";position:absolute;left:0;top:0;
  color:var(--accent);font-weight:700;font-size:14px;line-height:1.75;
}
.article-body ul.checks.bad li::before{content:"\2717";color:#d97878}
.article-body ol.numbered{counter-reset:item;list-style:none;padding-left:0}
.article-body ol.numbered li{counter-increment:item;position:relative;padding-left:48px;margin:14px 0}
.article-body ol.numbered li::before{
  content:counter(item, decimal-leading-zero);
  position:absolute;left:0;top:0;
  font-family:var(--font-display);font-weight:700;font-size:14px;
  color:var(--accent);letter-spacing:.04em;line-height:1.75;
}

/* CTA band (used at bottom of most pages) */
.cta-band{padding:88px 0;background:var(--bg-2);border-top:1px solid var(--line)}
.cta-band-inner{
  display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;
}
@media(max-width:880px){.cta-band-inner{grid-template-columns:1fr;gap:24px}}
.cta-band h2{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.8rem, 1.2rem + 2.4vw, 3rem);
  line-height:1.05;text-transform:uppercase;color:#fff;letter-spacing:0;
  margin:0;
}
.cta-band p{color:#d0d0d0;font-size:16px;line-height:1.55;margin:14px 0 0;max-width:48ch}
.cta-band-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-end}
@media(max-width:880px){.cta-band-actions{justify-content:flex-start}}

/* Local partners grid */
.partner-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:24px}
@media(max-width:720px){.partner-grid{grid-template-columns:1fr}}
.partner-card{
  padding:28px;border:1px solid var(--line);border-radius:8px;background:var(--bg-2);
  transition:border-color var(--t-fast), transform var(--t-fast);
}
.partner-card:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.partner-cat{
  font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
  margin-bottom:10px;
}
.partner-card h3{
  font-family:var(--font-display);font-weight:700;font-size:1.4rem;
  text-transform:uppercase;color:#fff;margin:0 0 8px;letter-spacing:.005em;
}
.partner-card p{color:#c8c8c8;font-size:14px;line-height:1.55;margin:0 0 18px}
.partner-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-size:12px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);
}
.partner-link:hover{color:#fff}

/* contact page tweaks */
#contact-page{padding:60px 0 80px}

/* ============================================================
   STORM CHECKLIST — printable, brand-themed
   ============================================================ */
.checklist-page{padding:140px 0 80px;background:#0a0a0a;color:#e8e8e8;font-family:var(--font-sans);position:relative}
.checklist-page::before{
  content:"";position:absolute;top:0;left:0;right:0;height:8px;background:var(--accent);z-index:5;
}
.cl-header{padding-bottom:36px;border-bottom:1px solid #2a2a2a;margin-bottom:48px}
.cl-header-row{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;flex-wrap:wrap}
.cl-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);
}
.cl-pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;animation:cl-pulse 2s ease-in-out infinite}
@keyframes cl-pulse{0%,100%{opacity:1}50%{opacity:.3}}
.cl-h1{
  font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,1.3rem+2.5vw,3.4rem);
  line-height:1.05;letter-spacing:.005em;text-transform:uppercase;color:#fff;margin:10px 0 0;
}
.cl-sub{margin:6px 0 0;color:#a0a0a0;font-family:var(--font-display);font-weight:500;letter-spacing:.08em;text-transform:uppercase;font-size:14px}
.cl-sep{color:#555;margin:0 8px}
.cl-contact{
  padding:16px 20px;border:1px solid #2a2a2a;background:rgba(20,20,20,.5);border-radius:10px;
  text-align:right;min-width:200px;
}
.cl-contact-eyebrow{margin:0;font-family:var(--font-display);font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#a0a0a0}
.cl-contact-phone{
  display:block;margin:4px 0 2px;font-family:var(--font-display);font-weight:700;font-size:24px;
  color:var(--accent);text-decoration:none;letter-spacing:.01em;
}
.cl-contact-phone:hover{color:var(--accent-2)}
.cl-contact-sub{margin:0;color:#777;font-size:11px}
.cl-actions{margin-top:24px;display:flex;gap:14px;flex-wrap:wrap}

.cl-intro{padding:24px 28px;background:#141414;border-radius:10px;border-left:4px solid var(--accent);margin-bottom:48px}
.cl-intro h2{
  margin:0;font-family:var(--font-display);font-weight:700;font-size:1.4rem;
  letter-spacing:.005em;text-transform:uppercase;color:#fff;
}
.cl-intro p{margin:10px 0 0;color:#d4d4d4;line-height:1.55}
.cl-warn{
  margin-top:18px;padding:10px 14px;border:1px solid rgba(232,69,31,.3);background:rgba(232,69,31,.06);
  border-radius:6px;font-size:13px;color:#e8e8e8;line-height:1.55;
}
.cl-warn strong{color:var(--accent)}

.cl-phases{display:flex;flex-direction:column;gap:32px}
.cl-phase{padding:28px;border:1px solid #2a2a2a;background:rgba(20,20,20,.35);border-radius:10px}
.cl-phase-head{display:flex;align-items:center;gap:14px;padding-bottom:14px;border-bottom:1px solid #2a2a2a;margin-bottom:24px}
.cl-num{
  flex-shrink:0;width:32px;height:32px;border-radius:8px;
  background:rgba(232,69,31,.12);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--accent);
}
.cl-phase-head h3{
  margin:0;font-family:var(--font-display);font-weight:700;font-size:1.25rem;
  letter-spacing:.01em;text-transform:uppercase;color:#fff;
}
.cl-items{display:flex;flex-direction:column;gap:24px}
.chk-item{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start}
.chk-box{
  margin-top:4px;width:20px;height:20px;
  appearance:none;-webkit-appearance:none;
  border:2px solid #4a4a4a;border-radius:4px;background:#0a0a0a;
  cursor:pointer;position:relative;flex-shrink:0;
  transition:background var(--t-fast), border-color var(--t-fast);
}
.chk-box:checked{background:var(--accent);border-color:var(--accent)}
.chk-box:checked::after{
  content:"";position:absolute;left:5px;top:1px;width:5px;height:11px;
  border:solid #0a0a0a;border-width:0 2.5px 2.5px 0;transform:rotate(45deg);
}
.chk-box:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.chk-item label{cursor:pointer;color:#d4d4d4;line-height:1.55}
.chk-title{display:block;font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:#fff;letter-spacing:.005em;text-transform:uppercase;margin-bottom:4px}
.chk-desc{display:block;font-size:15px;color:#c8c8c8;line-height:1.6;margin-bottom:10px}
.chk-photo{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);
  background:rgba(232,69,31,.06);border:1px solid rgba(232,69,31,.18);border-radius:4px;
}
.chk-photo-ico{font-size:13px}

.cl-footer{margin-top:48px;padding:24px;border-top:1px solid #2a2a2a;color:#a8a8a8;font-size:14px;line-height:1.55}
.cl-footer p{margin:0 0 8px}
.cl-footer a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px}
.cl-meta{font-size:12px;color:#666;font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;margin-top:14px!important}

@media(max-width:720px){
  .cl-contact{min-width:0;text-align:left;width:100%}
  .cl-actions .btn{width:100%;justify-content:center}
  .cl-phase{padding:20px}
}

/* ============================================================
   PRINT — checklist becomes a clean black-on-white document
   ============================================================ */
@media print{
  @page{margin:0.5in 0.6in}
  *{background:transparent!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}
  body{background:#fff!important;color:#000!important}
  nav, footer, .menu-btn, .nav-cta, .cta-band, .crumbs, .marquee, .modal-back, .review-trigger{display:none!important}
  .checklist-page{padding:0!important;background:#fff!important;color:#000!important}
  .checklist-page::before{display:none!important}
  .container{max-width:none!important;padding:0!important}
  .cl-header{border-bottom:2px solid #000!important;margin-bottom:24px!important;padding-bottom:18px!important}
  .cl-eyebrow{color:#c4471c!important}
  .cl-pulse{display:none!important}
  .cl-h1{color:#000!important}
  .cl-sub{color:#333!important}
  .cl-contact{border:1px solid #000!important;background:transparent!important}
  .cl-contact-phone{color:#c4471c!important}
  .cl-actions{display:none!important}
  .cl-intro{background:transparent!important;border:1px solid #000!important;border-left:4px solid #c4471c!important}
  .cl-intro h2{color:#000!important}
  .cl-warn{border:1px solid #c4471c!important;background:transparent!important;color:#000!important}
  .cl-warn strong{color:#c4471c!important}
  .cl-phase{break-inside:avoid;border:1px solid #000!important;background:transparent!important;margin-bottom:18px;padding:16px!important}
  .cl-phase-head{border-bottom:1px solid #000!important;padding-bottom:8px;margin-bottom:14px}
  .cl-num{background:#c4471c!important;color:#fff!important;border-radius:4px}
  .cl-phase-head h3, .chk-title{color:#000!important}
  .chk-box{border:2px solid #000!important;background:#fff!important}
  .chk-desc{color:#222!important}
  .chk-photo{background:transparent!important;border:1px solid #c4471c!important;color:#c4471c!important}
  .cl-footer{border-top:2px solid #000!important;color:#222!important;padding:12px 0 0!important}
  .cl-footer a{color:#c4471c!important;text-decoration:none!important}
  a[href]::after{content:""!important}
}

/* ============================================================
   STORM CHECKLIST LEAD-GATE
   ============================================================ */
.gate-grid{
  display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:start;
  margin-top:48px;
}
@media(max-width:880px){.gate-grid{grid-template-columns:1fr;gap:32px}}

.gate-left h2{
  font-family:var(--font-display);font-weight:700;font-size:clamp(1.6rem,1.2rem+1.8vw,2.4rem);
  line-height:1.08;text-transform:uppercase;color:#fff;letter-spacing:.005em;
}
.gate-lede{color:#d4d4d4;font-size:17px;line-height:1.6;margin:18px 0 28px;max-width:48ch}

.gate-list{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:18px}
.gate-list li{
  padding:18px 20px;background:rgba(20,20,20,.55);
  border:1px solid #2a2a2a;border-left:3px solid var(--accent);border-radius:6px;
  color:#c8c8c8;font-size:15px;line-height:1.55;
}
.gate-list li strong{
  display:block;font-family:var(--font-display);font-weight:700;font-size:13px;
  letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:6px;
}

.gate-trust{
  display:flex;flex-wrap:wrap;gap:10px;
}
.gate-trust span{
  padding:8px 14px;border:1px solid #2a2a2a;background:rgba(20,20,20,.4);border-radius:999px;
  font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:#c8c8c8;
}

.gate-form-wrap{position:sticky;top:120px}
@media(max-width:880px){.gate-form-wrap{position:static}}

.gate-form{
  padding:32px;background:#141414;border:1px solid #2a2a2a;border-radius:10px;
  box-shadow:0 30px 60px -28px rgba(0,0,0,.7);
}
.gate-form-title{
  margin:0;font-family:var(--font-display);font-weight:700;font-size:1.4rem;
  letter-spacing:.005em;text-transform:uppercase;color:#fff;
}
.gate-form-sub{margin:8px 0 24px;color:#a8a8a8;font-size:14px;line-height:1.5}

.gate-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.gate-field label{
  font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);
}
.gate-field input{
  background:#0a0a0a;border:1px solid #2a2a2a;border-radius:4px;
  padding:11px 12px;color:#fff;font:inherit;font-size:15px;
  transition:border-color var(--t-fast);
}
.gate-field input:focus{outline:none;border-color:var(--accent)}

.gate-submit{
  width:100%;justify-content:center;margin-top:10px;font-size:14px!important;
}
.gate-privacy{
  margin:14px 0 0;color:#8a8a8a;font-size:11px;line-height:1.5;text-align:center;
}
.gate-privacy a{color:var(--accent-2);text-decoration:underline}

.gate-warn{
  margin-top:48px;padding:18px 24px;
  background:rgba(232,69,31,.06);border:1px solid rgba(232,69,31,.25);border-radius:8px;
  color:#e8e8e8;line-height:1.6;font-size:15px;
}
.gate-warn strong{color:var(--accent)}
.gate-warn a{color:var(--accent-2);text-decoration:underline;font-weight:600}

/* ============================================================
   DOWNLOAD CTA — distinct from btn-primary so the two don't compete
   ============================================================ */
.btn-download{
  display:inline-flex;align-items:center;gap:10px;
  background:transparent;
  border:2px solid var(--accent);
  color:var(--accent);
  padding:12px 20px;
  font-family:var(--font-display);font-size:13px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;line-height:1.2;
  border-radius:var(--r);
  transition:background var(--t-fast), color var(--t-fast), box-shadow var(--t-fast), transform var(--t-fast);
  position:relative;
}
.btn-download.btn-lg{padding:16px 24px;font-size:14px}
.btn-download:hover{
  background:var(--accent);
  color:#0a0a0a;
  box-shadow:0 12px 36px -10px var(--accent);
  transform:translateY(-2px);
}
.btn-download .dl-icon{flex-shrink:0}
.btn-download:hover .dl-icon{transform:translateY(2px)}
.btn-download .dl-icon{transition:transform var(--t-norm)}

.dl-badge{
  display:inline-block;margin-left:6px;padding:3px 8px;
  background:var(--accent);color:#0a0a0a;
  font-family:var(--font-display);font-size:10px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  border-radius:3px;
  transition:background var(--t-fast), color var(--t-fast);
}
.btn-download:hover .dl-badge{
  background:#0a0a0a;color:var(--accent);
}

/* Aside-card variant for the storm download CTA */
.aside-card.download-card{
  border:1px solid rgba(232,69,31,.4);
  background:linear-gradient(180deg, rgba(232,69,31,.06), rgba(20,20,20,.55));
}
.aside-card.download-card h4{color:var(--accent)}
.dl-badge-pill{
  display:inline-block;margin-bottom:10px;padding:4px 10px;
  background:rgba(232,69,31,.15);border:1px solid rgba(232,69,31,.35);
  color:var(--accent-2);
  font-family:var(--font-display);font-size:10px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;border-radius:999px;
}
.aside-card.download-card .btn-download{
  width:100%;justify-content:center;font-size:12px;padding:11px 16px;
}
.aside-card.download-card .btn-download .dl-badge{display:none}

/* CTA band — allow 3 buttons to wrap nicely */
.cta-band-actions{gap:12px}
@media(max-width:560px){
  .cta-band-actions .btn{width:100%;justify-content:center}
  .btn-download .dl-badge{display:none}
}

/* ============================================================
   MOBILE POLISH PASS — comprehensive responsive fixes
   ============================================================ */

/* Guard against any element exceeding the viewport width.
   img is already capped, but svg, iframe, video, table need it too. */
img, svg, iframe, video, table { max-width: 100%; }

/* Long URLs / emails / phone numbers can break out of cards — wrap them */
.aside-card a, .meta-row .v, .foot-col a, .voice .who, .voice .when,
.cl-contact-phone, .partner-card a {
  word-break: break-word;
  overflow-wrap: anywhere;
}

/* Tap targets — every clickable thing needs ≥40px (WCAG AA minimum is 24px,
   AAA + Apple HIG recommend 44px). Already true for .btn, but safety-check
   small inline links inside forms / nav with explicit padding. */
.menu-btn { min-width: 44px; min-height: 44px; }

/* ============================================================
   TABLET RANGE (881–1024) — service grids, hero text constraint
   ============================================================ */
@media (max-width: 1024px) {
  /* The new page-hero text-left layout: at tablet, give text the full container
     and hide the image slot (already done in main rule, ensuring here too). */
  .page-hero-content { max-width: 100% !important; }
  .page-hero-media { display: none !important; }

  /* Insurance step labels (A/B/C) scale down */
  .step-label { font-size: 52px; width: 64px; }

  /* Container side-padding still has breathing room at tablet */
  .container { padding: 0 28px; }
}

/* ============================================================
   STANDARD MOBILE (≤880) — nav, hero, sections, forms
   ============================================================ */
@media (max-width: 880px) {
  /* Section padding everywhere — single source of truth for mobile rhythm */
  section,
  #services, #insurance, #work, #voices, #faq, #areas, #blog, #contact,
  #contact-page, .article, .prose, .cta-band, .checklist-page {
    padding-top: 72px;
    padding-bottom: 72px;
  }

  /* Hero specifically gets less top-padding since it sits directly under nav */
  .hero { padding: 130px 0 64px; }

  /* Hero h1 sizing — match home heading scale to subpages */
  .hero h1 { font-size: clamp(2.1rem, 1.2rem + 5vw, 3.4rem); }

  /* Section heads stack and gap shrinks */
  .sec-head { gap: 20px; }
  .sec-head .lede { font-size: 16px; }

  /* CTA bands with 3 buttons stack at full width below 880 */
  .cta-band-actions { flex-direction: column; align-items: stretch; gap: 12px; }
  .cta-band-actions .btn { width: 100%; justify-content: center; }
  .cta-band-actions .btn-download .dl-badge { display: none; }

  /* Hero action buttons (Request Inspection / Emergency Repair) — full width */
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions .btn { width: 100%; justify-content: center; flex: none; }

  /* Insurance step labels small */
  .step-label { font-size: 42px; width: 52px; }
  .step { padding: 18px 0; gap: 14px; }
  .step h4 { font-size: 17px; }

  /* Footer 4-col → 2x2, brand spans both columns */
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .foot-brand { grid-column: span 2; }

  /* Map wraps get a sensible height on mobile (was 480px min, too tall) */
  .map-wrap { min-height: 320px; }

  /* Prose grid stacks, aside-cards become full-width and lose stickiness */
  .prose { padding: 60px 0; }
  .prose-aside { position: static; }
  .aside-card { padding: 22px; }

  /* Article body — tighter line length / smaller font */
  .article-body p { font-size: 16px; line-height: 1.7; }

  /* Storm checklist gate page */
  .checklist-page { padding-top: 120px; padding-bottom: 64px; }
  .cl-header-row { gap: 18px; }
  .cl-contact { width: 100%; text-align: left; min-width: 0; }
  .gate-form { padding: 24px; }
  .gate-trust { gap: 8px; }
  .gate-trust span { font-size: 10px; padding: 6px 11px; }

  /* Reviews — column-count 2 already handled, just verify */
  .voices { column-count: 1; }

  /* Areas list — keep 2-col on mobile for compact tile feel */
  .areas-list ul, .areas-list ul.full { grid-template-columns: 1fr 1fr; gap: 8px 16px; }
  .areas-list li { font-size: 14px; padding: 5px 0; }

  /* Local partners — stack to 1 column at 720, ensure here too */
  .partner-grid { grid-template-columns: 1fr; }

  /* Service cards — sensible min-height (was 360, often too tall) */
  .svc { min-height: 320px; }
  .svc-body { padding: 22px; }
  .svc h3 { font-size: 1.3rem; }
  .svc p { font-size: 14.5px; }

  /* Insurance card with the $0 / big number */
  .ins-card { padding: 20px; flex-direction: column; align-items: stretch; gap: 14px; }
  .ins-card .big { font-size: 44px; }

  /* Contact / form */
  form.estimate { padding: 22px; gap: 14px; }
  .meta-row { grid-template-columns: 1fr; gap: 4px; padding: 14px 0; }

  /* Modal sizing on small screens */
  .modal { padding: 26px 22px; }
  .modal h3 { font-size: 1.5rem; }

  /* FAQ tighter padding */
  .faq summary { padding: 22px 0; gap: 14px; }
  .faq .ic { width: 32px; height: 32px; }
  .faq .a { padding: 0 0 24px; font-size: 15.5px; }

  /* Marquee — smaller, less crowded */
  .marquee-track { padding: 16px 0; gap: 36px; }
  .marquee span { font-size: 17px; gap: 36px; letter-spacing: .12em; }

  /* Posts (blog hub) — full width cards */
  .post { padding: 24px; min-height: 0; }
  .post h3 { font-size: 1.2rem; }
}

/* ============================================================
   SMALL MOBILE (≤560) — single col everything, tight padding
   ============================================================ */
@media (max-width: 560px) {
  /* Container side-padding tighter for max content width */
  .container { padding: 0 18px; }

  /* Section padding even smaller on phones */
  section,
  #services, #insurance, #work, #voices, #faq, #areas, #blog, #contact,
  #contact-page, .article, .prose, .cta-band, .checklist-page {
    padding-top: 56px;
    padding-bottom: 56px;
  }

  .hero { padding: 110px 0 52px; }
  .hero h1 { font-size: clamp(1.9rem, 1rem + 6vw, 2.6rem); letter-spacing: -.005em; }
  .hero h1 br { display: none; }   /* let it flow naturally */
  .hero-lead { font-size: 15.5px; }

  /* Hero meta — 2x2 layout, last item spans both */
  .hero-meta { grid-template-columns: 1fr 1fr; gap: 16px; padding-top: 20px; }
  .hero-meta > div:last-child { grid-column: span 2; text-align: center; }
  .hero-meta .k { font-size: 1.7rem; }

  /* Page hero, section heads — tighter */
  .page-hero h1, .page-hero-content h1 { font-size: clamp(1.7rem, 1.2rem + 2.5vw, 2.2rem); }
  .page-hero-lede { font-size: 15.5px; }
  h2 { font-size: clamp(1.6rem, 1.1rem + 3vw, 2.2rem); }

  /* Footer single column on phones */
  .foot-grid { grid-template-columns: 1fr; gap: 24px; }
  .foot-brand { grid-column: span 1; }
  .foot-bottom { flex-direction: column; gap: 6px; }

  /* Form labels + inputs */
  .field input, .field select, .field textarea { font-size: 16px; }  /* prevent iOS auto-zoom */
  .gate-field input { font-size: 16px; padding: 12px 14px; }

  /* Badges (Licensed etc) */
  .badges { gap: 6px; }
  .badge { font-size: 10.5px; padding: 6px 10px; }

  /* Hero meta stat keys — keep big but not over-big */
  .hero-meta .k { font-size: 1.6rem; }

  /* Step labels (the big A/B/C/1/2/3) tighter */
  .step-label { font-size: 34px; width: 42px; }

  /* CTA band heading scale */
  .cta-band h2 { font-size: clamp(1.5rem, 1.1rem + 2vw, 2rem); }

  /* Modal full-screen feel on small phones */
  .modal-back { padding: 12px; }
  .modal { padding: 22px 18px; border-radius: 10px; }
  .review-opt { padding: 14px 16px; gap: 12px; }
  .review-opt .icon { width: 38px; height: 38px; }

  /* Storm checklist header simplification on phones */
  .cl-h1 { font-size: clamp(1.5rem, 1.1rem + 2.5vw, 2.2rem); }
  .cl-contact { padding: 14px 16px; }
  .cl-contact-phone { font-size: 21px; }

  /* Tile captions in gallery */
  .tile-cap { left: 12px; right: 12px; bottom: 12px; font-size: 11px; letter-spacing: .12em; gap: 8px; }

  /* Service cards stack tighter */
  .svc-body { padding: 18px; }

  /* Areas list — single col on tiny screens */
  .areas-list ul, .areas-list ul.full { grid-template-columns: 1fr; }

  /* Crumbs smaller */
  .crumbs { font-size: 10px; letter-spacing: .14em; }

  /* Marquee tighter */
  .marquee span { font-size: 15px; gap: 28px; }
}

/* ============================================================
   TINY MOBILE (≤380) — last-ditch space saving for 320–380 phones
   ============================================================ */
@media (max-width: 380px) {
  .container { padding: 0 14px; }
  .hero h1 { font-size: 1.85rem; }
  .nav-inner { gap: 8px; }
  .brand img { height: 48px; }
  .phone { display: none; }
}

/* ============================================================
   LANDSCAPE PHONES (height-constrained, hero needs to be shorter)
   ============================================================ */
@media (max-width: 900px) and (orientation: landscape) and (max-height: 500px) {
  .hero { padding: 90px 0 40px; }
  .hero-meta { margin-top: 28px; }
  .checklist-page { padding-top: 96px; }
}

/* ============================================================
   iOS Safari address-bar fix: avoid 100vh issues in hero (we use padding not vh)
   ============================================================ */
.hero { min-height: 0; }   /* explicit, in case anything added height:100vh upstream */

/* ============================================================
   ACCESSIBILITY: focus rings on keyboard nav for all interactive
   ============================================================ */
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible, summary:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.btn:focus-visible { outline-offset: 3px; }

/* Disable hover transforms on touch devices (no actual hover, prevents stuck states) */
@media (hover: none) {
  .btn:hover, .voice:hover, .tile:hover, .voices-foot a:hover,
  .review-opt:hover, .post:hover, .partner-card:hover,
  .svc:hover, .aside-card.urgent:hover { transform: none !important; }
}

/* ============================================================
   MOBILE FIXES (round 2) — addressing observed phone rendering
   ============================================================ */

/* ----- NAV BAR: tighter, balanced on phones ----- */
@media (max-width: 880px) {
  .nav-inner { height: 70px; padding: 0; gap: 10px; }
  .brand img { height: 46px; }
  /* Compact Free Estimate button on mobile so it doesn't dominate */
  .nav .nav-cta .btn-primary {
    padding: 10px 14px;
    font-size: 12px;
    letter-spacing: .08em;
  }
  .menu-btn { width: 42px; height: 42px; }
  .nav-cta { gap: 8px; }
}

/* On very narrow phones, drop the button text to just "Estimate" */
@media (max-width: 420px) {
  .brand img { height: 40px; }
  .nav .nav-cta .btn-primary { padding: 9px 12px; font-size: 11px; }
}

/* ----- HERO META: 3-COLUMN on mobile so 48h sits naturally ----- */
@media (max-width: 880px) {
  .hero-meta {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 10px !important;
    padding-top: 18px;
    margin-top: 36px;
  }
  .hero-meta > div:last-child {
    grid-column: auto !important;
    text-align: left !important;
  }
  .hero-meta .k { font-size: 1.55rem; }
  .hero-meta .v { font-size: 9.5px; letter-spacing: .14em; margin-top: 6px; }
}
@media (max-width: 420px) {
  .hero-meta .k { font-size: 1.35rem; }
  .hero-meta .v { font-size: 9px; letter-spacing: .12em; }
}

/* ----- SUB-PAGE HERO PHOTOS: show as full-bleed background on mobile ----- */
@media (max-width: 1024px) {
  /* Override the universal hide so the photo CAN show on mobile when set */
  .page-hero.has-bg .page-hero-media {
    display: block !important;
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    background-position: center !important;
    background-size: cover !important;
    z-index: 0;
  }
  /* But still hide the dashed-border placeholder for pages without a photo */
  .page-hero-media.is-placeholder { display: none !important; }

  /* Dark gradient overlay so text stays readable over the photo */
  .page-hero.has-bg {
    position: relative;
    isolation: isolate;
    overflow: hidden;
  }
  .page-hero.has-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(180deg,
      rgba(0,0,0,.85) 0%,
      rgba(0,0,0,.6) 40%,
      rgba(0,0,0,.7) 75%,
      rgba(0,0,0,.92) 100%);
  }
  .page-hero.has-bg .container {
    position: relative;
    z-index: 2;
  }
  .page-hero.has-bg h1,
  .page-hero.has-bg .page-hero-lede,
  .page-hero.has-bg .eyebrow {
    text-shadow: 0 2px 14px rgba(0,0,0,.7);
  }
}

/* ----- HOME HERO H1 SPACING (safety net even after source fix) ----- */
@media (max-width: 880px) {
  /* Ensure the br between "weather" and "the" still creates a space when hidden */
  .hero h1 br { display: inline; visibility: hidden; }
  .hero h1 br::after { content: " "; }
}
