/*
Theme Name: Plumbline
Theme URI: https://example.com/plumbline
Author: Built with Claude
Author URI: https://example.com
Description: A bold, trust-building WordPress theme for plumbing and heating businesses. Click-to-call header, emergency banner, services grid, reviews, service-area map and a built-in quote request form — all editable from the WordPress admin. Navy & red aesthetic.
Version: 2.7 (video as middle review)
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: plumbline
Tags: business, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, two-columns, theme-options
*/

/* ============================================================
   PLUMBLINE — Design tokens
   ============================================================ */
:root{
  --ink:#0d1b2a;
  --ink-2:#152a40;
  --ink-3:#1d3a57;
  /* Brand accents: navy base + red */
  --copper:#b23b3b;          /* primary RED accent */
  --copper-bright:#cf4a4a;   /* brighter red for hover */
  --copper-soft:#e3a3a3;     /* light red tint */
  --green:#2fa83a;           /* mascot green (used sparingly) */
  --green-bright:#42c150;
  --copper-rgb:178,59,59;    /* red as rgb for translucent fills */
  --paper:#f7f3ec;
  --paper-2:#efe7da;
  --paper-3:#e4d9c6;
  --text:#15212e;
  --text-soft:#475463;
  --text-invert:#f3ede2;
  --text-invert-soft:#a8b6c6;
  --line:#dcd2c2;
  --line-dark:rgba(255,255,255,.12);
  --good:#2fa83a;
  --shadow-sm:0 1px 2px rgba(13,27,42,.06),0 2px 8px rgba(13,27,42,.05);
  --shadow-md:0 8px 24px rgba(13,27,42,.10);
  --shadow-lg:0 24px 60px rgba(13,27,42,.18);
  --radius:14px;
  --radius-lg:22px;
  --maxw:1180px;
  --ff-display:"Archivo",-apple-system,BlinkMacSystemFont,sans-serif;
  --ff-body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ============================================================
   Reset & base
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--ff-body);
  font-size:clamp(16px,1.05vw,17.5px);
  line-height:1.65;
  color:var(--text);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--copper);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--ink)}
h1,h2,h3,h4{font-family:var(--ff-display);line-height:1.04;margin:0 0 .5em;letter-spacing:-.02em;font-weight:800}
p{margin:0 0 1.1em}
ul{margin:0 0 1.1em}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}

/* skip link / a11y */
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
.skip-link{position:absolute;left:-999px;top:0;background:var(--copper);color:#fff;padding:10px 16px;z-index:9999}
.skip-link:focus{left:8px;top:8px;border-radius:8px}
:focus-visible{outline:3px solid var(--copper-bright);outline-offset:2px}

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--ff-display);font-weight:700;font-size:.98rem;letter-spacing:.01em;
  padding:.85em 1.5em;border-radius:999px;cursor:pointer;border:2px solid transparent;
  transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .2s var(--ease),color .2s var(--ease);
  white-space:nowrap;line-height:1;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--copper);color:#fff;box-shadow:0 6px 18px rgba(178,59,59,.35)}
.btn--primary:hover{background:var(--copper-bright);color:#fff;box-shadow:0 10px 26px rgba(178,59,59,.45)}
.btn--ghost{background:transparent;color:var(--text-invert);border-color:rgba(255,255,255,.35)}
.btn--ghost:hover{background:rgba(255,255,255,.1);color:#fff;border-color:#fff}
.btn--dark{background:var(--ink);color:#fff}
.btn--dark:hover{background:var(--ink-2);color:#fff}
.btn--lg{font-size:1.08rem;padding:1.05em 1.9em}

/* ============================================================
   Emergency banner
   ============================================================ */
.emergency-bar{
  background:var(--copper);color:#fff;text-align:center;
  font-family:var(--ff-display);font-weight:600;font-size:.92rem;
  padding:.55em 1em;display:flex;justify-content:center;align-items:center;gap:.6em;flex-wrap:wrap;
}
.emergency-bar a{color:#fff;text-decoration:underline;font-weight:800}
.emergency-bar .pulse{width:9px;height:9px;border-radius:50%;background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.7);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.6)}70%{box-shadow:0 0 0 9px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}

/* ============================================================
   Header
   ============================================================ */
.site-header{position:sticky;top:0;z-index:200;background:rgba(247,243,236,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 0;min-height:68px}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand-mark{width:40px;height:40px;border-radius:11px;background:var(--ink);display:grid;place-items:center;flex-shrink:0;box-shadow:var(--shadow-sm)}
.brand-mark svg{width:24px;height:24px}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-name{font-family:var(--ff-display);font-weight:800;font-size:1.25rem;color:var(--ink);letter-spacing:-.02em;white-space:nowrap}
.brand-tag{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--copper);font-weight:700;white-space:nowrap}

.main-nav ul{list-style:none;display:flex;gap:.4rem;margin:0;padding:0}
.main-nav a{font-family:var(--ff-display);font-weight:600;font-size:.96rem;color:var(--ink);padding:.5em .85em;border-radius:9px;white-space:nowrap}
.main-nav a:hover{background:var(--paper-2);color:var(--ink)}
.main-nav .current-menu-item>a{color:var(--copper)}

.header-cta{display:flex;align-items:center;gap:.9rem;flex-shrink:0}
.header-phone{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}
.header-phone .label{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-soft);font-weight:700}
.header-phone .num{font-family:var(--ff-display);font-weight:800;font-size:1.15rem;color:var(--ink)}
.header-phone .num:hover{color:var(--copper)}

.nav-toggle{display:none;background:var(--ink);border:0;width:46px;height:46px;border-radius:11px;cursor:pointer;padding:0;place-items:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:20px;height:2px;background:#fff;border-radius:2px;transition:.25s var(--ease)}
.nav-toggle span{position:relative}
.nav-toggle span::before{position:absolute;top:-6px}
.nav-toggle span::after{position:absolute;top:6px}
.nav-toggle[aria-expanded="true"] span{background:transparent}
.nav-toggle[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

/* ============================================================
   Hero
   ============================================================ */
.hero{position:relative;background:var(--ink);color:var(--text-invert);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 500px at 85% -10%,rgba(178,59,59,.28),transparent 60%),
  radial-gradient(700px 600px at 0% 110%,rgba(29,58,87,.7),transparent 55%);}
.hero::after{content:"";position:absolute;inset:0;opacity:.04;background-image:linear-gradient(var(--text-invert) 1px,transparent 1px),linear-gradient(90deg,var(--text-invert) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(circle at 70% 30%,#000,transparent 75%)}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center;padding:clamp(3.5rem,7vw,6rem) 0}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5em;font-family:var(--ff-display);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--copper-soft);background:rgba(178,59,59,.12);border:1px solid rgba(178,59,59,.3);padding:.5em 1em;border-radius:999px;margin-bottom:1.4rem}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:900;letter-spacing:-.03em;margin-bottom:.4em}
.hero h1 .accent{color:var(--copper-bright)}
.hero-lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--text-invert-soft);max-width:34ch;margin-bottom:2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:2rem}
.hero-points{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.6rem 1.6rem}
.hero-points li{display:flex;align-items:center;gap:.5em;font-weight:600;font-size:.95rem;color:var(--text-invert)}
.hero-points svg{width:18px;height:18px;color:var(--copper-bright);flex-shrink:0}

/* hero card */
.hero-card{background:var(--paper);color:var(--text);border-radius:var(--radius-lg);padding:1.8rem;box-shadow:var(--shadow-lg);position:relative}
.hero-card h3{font-size:1.4rem;color:var(--ink)}
.hero-card .sub{color:var(--text-soft);font-size:.95rem;margin-bottom:1.3rem}
.hero-card .stars{color:var(--copper);letter-spacing:2px;font-size:1.1rem}
.mini-form{display:grid;gap:.7rem}
.mini-form input,.mini-form select,.mini-form textarea{width:100%;font:inherit;padding:.8em .9em;border:1.5px solid var(--line);border-radius:11px;background:#fff;color:var(--text)}
.mini-form input:focus,.mini-form select:focus,.mini-form textarea:focus{outline:none;border-color:var(--copper)}
.mini-form .btn{width:100%;justify-content:center}
.hero-card .reassure{font-size:.8rem;color:var(--text-soft);text-align:center;margin:.4rem 0 0}

/* ============================================================
   Section scaffolding
   ============================================================ */
.section{padding:clamp(3.5rem,7vw,6rem) 0}
.section--paper2{background:var(--paper-2)}
.section--ink{background:var(--ink);color:var(--text-invert)}
.section-head{max-width:640px;margin:0 auto 3rem;text-align:center}
.section-head.left{text-align:left;margin-left:0}
.eyebrow{display:inline-block;font-family:var(--ff-display);font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--copper);margin-bottom:.8rem}
.section-head h2{font-size:clamp(2rem,4vw,3rem);color:var(--ink)}
.section--ink .section-head h2{color:#fff}
.section-head p{color:var(--text-soft);font-size:1.1rem;margin:0}
.section--ink .section-head p{color:var(--text-invert-soft)}

/* ============================================================
   Trust bar
   ============================================================ */
.trustbar{background:var(--ink-2);color:var(--text-invert)}
.trustbar .container{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.4rem 2rem;padding-top:1.5rem;padding-bottom:1.5rem}
.trust-item{display:flex;align-items:center;gap:.7rem;font-family:var(--ff-display);font-weight:600;font-size:.96rem}
.trust-item svg{width:26px;height:26px;color:var(--copper-bright);flex-shrink:0}

/* ============================================================
   Services grid
   ============================================================ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.service-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);position:relative;overflow:hidden}
.service-card::after{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--copper);transition:width .35s var(--ease)}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:transparent}
.service-card:hover::after{width:100%}
.service-icon{width:54px;height:54px;border-radius:13px;background:var(--paper-2);display:grid;place-items:center;margin-bottom:1.1rem;color:var(--copper)}
.service-icon svg{width:28px;height:28px}
.service-card h3{font-size:1.28rem;color:var(--ink);margin-bottom:.4rem}
.service-card p{color:var(--text-soft);font-size:.96rem;margin:0}

/* ============================================================
   Why choose us / split
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.feature-list{list-style:none;padding:0;margin:1.6rem 0 0;display:grid;gap:1.3rem}
.feature-list li{display:flex;gap:1rem;align-items:flex-start}
.feature-list .ico{width:46px;height:46px;border-radius:12px;background:var(--copper);color:#fff;display:grid;place-items:center;flex-shrink:0}
.feature-list .ico svg{width:24px;height:24px}
.feature-list h4{font-size:1.12rem;margin:0 0 .25rem;color:var(--ink)}
.feature-list p{margin:0;color:var(--text-soft);font-size:.95rem}
.media-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--ink-2);aspect-ratio:4/3}
.media-frame img{width:100%;height:100%;object-fit:cover}
.media-frame .placeholder{position:absolute;inset:0;display:grid;place-items:center;color:var(--text-invert-soft);font-family:var(--ff-display);text-align:center;padding:2rem}
.media-frame .placeholder svg{width:64px;height:64px;color:var(--copper-bright);margin:0 auto .8rem}
.stat-badge{position:absolute;bottom:1.2rem;left:1.2rem;background:var(--paper);color:var(--ink);border-radius:14px;padding:.9rem 1.2rem;box-shadow:var(--shadow-md)}
.stat-badge b{font-family:var(--ff-display);font-size:1.8rem;display:block;line-height:1;color:var(--copper)}
.stat-badge span{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-soft);font-weight:700}

/* ============================================================
   Testimonials
   ============================================================ */
.reviews-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:1.4rem}
.review-card{flex:1 1 320px;max-width:400px;background:var(--ink-2);border:1px solid var(--line-dark);border-radius:var(--radius);padding:1.7rem;display:flex;flex-direction:column}
.review-card--video{padding:0;overflow:hidden;background:#000}
.review-card--video iframe,.review-card--video blockquote,.review-card--video video,.review-card--video .tiktok-embed,.review-card--video .fb-video{width:100%!important;max-width:100%!important;margin:0!important;border:0;display:block}
.review-card .stars{color:var(--copper-bright);letter-spacing:2px;margin-bottom:.8rem}
.review-card blockquote{margin:0 0 1.2rem;font-size:1.02rem;line-height:1.6;color:var(--text-invert)}
.review-card .who{margin-top:auto;display:flex;align-items:center;gap:.8rem}
.review-card .avatar{width:42px;height:42px;border-radius:50%;background:var(--copper);color:#fff;display:grid;place-items:center;font-family:var(--ff-display);font-weight:800;flex-shrink:0}
.review-card .who b{display:block;font-family:var(--ff-display);font-size:.98rem;color:#fff}
.review-card .who span{font-size:.82rem;color:var(--text-invert-soft)}

/* ============================================================
   Areas served
   ============================================================ */
.areas{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.area-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem}
.area-chips span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.5em 1.1em;font-weight:600;font-size:.92rem;color:var(--ink);transition:.2s var(--ease)}
.area-chips span:hover{background:var(--copper);color:#fff;border-color:var(--copper)}
.area-visual{aspect-ratio:1/1;border-radius:var(--radius-lg);background:radial-gradient(circle at 50% 40%,var(--ink-3),var(--ink));position:relative;overflow:hidden;box-shadow:var(--shadow-lg);display:grid;place-items:center}
.area-visual .ring{position:absolute;border:1.5px solid rgba(178,59,59,.4);border-radius:50%}
.area-visual .ring.r1{width:30%;height:30%}
.area-visual .ring.r2{width:55%;height:55%;border-color:rgba(178,59,59,.28)}
.area-visual .ring.r3{width:82%;height:82%;border-color:rgba(178,59,59,.16)}
.area-visual .pin{position:relative;z-index:2;color:var(--copper-bright);text-align:center}
.area-visual .pin svg{width:54px;height:54px;margin:0 auto}
.area-visual .pin b{font-family:var(--ff-display);color:#fff;display:block;margin-top:.4rem}

/* ============================================================
   Quote / contact section
   ============================================================ */
.quote-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.quote-info h2{color:#fff;font-size:clamp(2rem,4vw,2.8rem)}
.quote-info p{color:var(--text-invert-soft)}
.contact-lines{list-style:none;padding:0;margin:1.8rem 0 0;display:grid;gap:1.1rem}
.contact-lines li{display:flex;gap:.9rem;align-items:center}
.contact-lines .ico{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid var(--line-dark);display:grid;place-items:center;color:var(--copper-bright);flex-shrink:0}
.contact-lines .ico svg{width:22px;height:22px}
.contact-lines b{display:block;color:#fff;font-family:var(--ff-display);font-size:1.05rem}
.contact-lines span{color:var(--text-invert-soft);font-size:.9rem}
.contact-lines a{color:#fff}
.contact-lines a:hover{color:var(--copper-bright)}

.quote-form{background:var(--paper);border-radius:var(--radius-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-lg)}
.quote-form h3{color:var(--ink);font-size:1.5rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1rem}
.field label{display:block;font-family:var(--ff-display);font-weight:600;font-size:.86rem;color:var(--ink);margin-bottom:.4rem}
.field input,.field select,.field textarea{width:100%;font:inherit;padding:.8em .95em;border:1.5px solid var(--line);border-radius:11px;background:#fff;color:var(--text);transition:border-color .2s var(--ease)}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--copper);box-shadow:0 0 0 3px rgba(178,59,59,.15)}
.quote-form .btn{width:100%;justify-content:center;margin-top:.4rem}
.form-note{font-size:.82rem;color:var(--text-soft);text-align:center;margin:.9rem 0 0}
.form-status{padding:.9em 1.1em;border-radius:11px;margin-bottom:1.2rem;font-weight:600;font-size:.95rem}
.form-status.ok{background:rgba(63,138,92,.12);color:var(--good);border:1px solid rgba(63,138,92,.3)}
.form-status.err{background:rgba(178,59,59,.12);color:var(--copper);border:1px solid rgba(178,59,59,.3)}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:var(--ink);color:var(--text-invert-soft);padding:clamp(3rem,5vw,4.5rem) 0 2rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.site-footer .brand-name{color:#fff}
.footer-about p{margin-top:1rem;max-width:34ch;font-size:.94rem}
.footer-col h4{font-family:var(--ff-display);color:#fff;font-size:1rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1.1rem}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.footer-col a{color:var(--text-invert-soft);font-size:.94rem}
.footer-col a:hover{color:var(--copper-bright)}
.social-links{margin-top:1.1rem;display:flex;gap:.6rem}
.social-links a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08);color:var(--text-invert);transition:background .2s var(--ease),transform .2s var(--ease)}
.social-links a:hover{background:var(--copper);color:#fff;transform:translateY(-2px)}
.social-links svg{width:19px;height:19px}
.social-links--hero{margin-top:1.6rem;gap:1rem}
.social-links--hero a{width:54px;height:54px}
.social-links--hero svg{width:26px;height:26px}
.footer-bottom{border-top:1px solid var(--line-dark);padding-top:1.5rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:.85rem}
.footer-bottom a{color:var(--text-invert-soft)}

/* ============================================================
   Generic page / posts
   ============================================================ */
.page-hero{background:var(--ink);color:var(--text-invert);padding:clamp(3rem,6vw,4.5rem) 0;text-align:center}
.page-hero h1{color:#fff;font-size:clamp(2.2rem,5vw,3.4rem)}
.page-hero p{color:var(--text-invert-soft);max-width:50ch;margin:0 auto}
.content-area{max-width:760px;margin:0 auto}
.content-area h2{color:var(--ink);margin-top:1.8em}
.content-area img{border-radius:var(--radius);margin:1.5em 0}
.entry-meta{color:var(--text-soft);font-size:.9rem;margin-bottom:1.5rem}
.wp-block-button__link,.wp-element-button{background:var(--copper);border-radius:999px}
blockquote{border-left:4px solid var(--copper);padding-left:1.2rem;margin-left:0;color:var(--text-soft);font-style:italic}
.post-thumb{border-radius:var(--radius-lg);overflow:hidden;margin-bottom:2rem;box-shadow:var(--shadow-md)}
.pagination{display:flex;gap:.5rem;justify-content:center;margin-top:3rem}
.pagination .page-numbers{padding:.6em 1em;border-radius:10px;background:#fff;border:1px solid var(--line);font-weight:700;font-family:var(--ff-display)}
.pagination .page-numbers.current{background:var(--copper);color:#fff;border-color:var(--copper)}

/* comments */
.comment-list{list-style:none;padding:0}
.comment-body{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;margin-bottom:1rem}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:2.5rem}
  .services-grid,.reviews-grid{grid-template-columns:1fr 1fr}
  .split,.areas,.quote-wrap{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  /* Solid dropdown that opens directly under the header */
  .main-nav{position:absolute!important;top:100%;left:0;right:0;width:auto!important;height:auto!important;display:none;transform:none!important;background:var(--ink)!important;border-top:3px solid var(--copper);box-shadow:var(--shadow-lg);padding:.4rem 0!important;z-index:9999!important;max-height:78vh;overflow-y:auto}
  .main-nav.open{display:block!important}
  .main-nav ul{flex-direction:column!important;gap:0;align-items:stretch;margin:0;padding:0}
  .main-nav li{border-bottom:1px solid rgba(255,255,255,.08)}
  .main-nav li:last-child{border-bottom:0}
  .main-nav a{display:block;padding:1em 1.4rem;font-size:1.05rem;text-align:left;color:#fff!important;border-radius:0;white-space:normal}
  .main-nav a:hover,.main-nav a:focus{background:rgba(255,255,255,.07);color:#fff!important}
  .nav-toggle{display:grid}
  .header-phone{display:none}
  .services-grid,.reviews-grid,.footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .nav-scrim{display:none!important}
  .header-inner{gap:.6rem;min-height:60px}
  .site-header{z-index:1100;overflow:visible}
  .brand-tag{display:none}
  .brand-name{font-size:1.05rem;white-space:normal;line-height:1.1}
  .hero-inner{padding:2.5rem 0}
  .hero h1{font-size:clamp(2.1rem,8vw,2.8rem)}
  .hero-mascot img{max-height:300px}
  .emergency-bar{font-size:.82rem;padding:.5em .8em}
}
@media(max-width:480px){
  .brand-text{display:none}            /* logo mark only — keeps the Get a Quote button visible */
  .header-cta .btn--primary{padding:.7em 1.1em;font-size:.9rem}
}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

/* ============================================================
   Mascot integration
   ============================================================ */
.hero-inner{align-items:stretch}
.hero-copy{align-self:center}
.brand-mark--img{background:transparent;box-shadow:none;overflow:hidden;border-radius:50%}
.brand-mark--img img{width:44px;height:44px;border-radius:50%;display:block;object-fit:cover}

.hero-mascot{position:relative;display:flex;align-items:flex-end;justify-content:center;min-height:100%}
.hero-mascot::before{content:"";position:absolute;left:50%;bottom:6%;width:78%;padding-bottom:78%;transform:translateX(-50%);background:radial-gradient(circle,rgba(232,57,42,.30),transparent 62%);filter:blur(8px);z-index:0}
.hero-mascot img{position:relative;z-index:1;max-height:520px;width:auto;max-width:100%;filter:drop-shadow(0 26px 34px rgba(0,0,0,.45));animation:mascotIn .8s var(--ease) both}
@keyframes mascotIn{from{opacity:0;transform:translateY(22px) scale(.97)}to{opacity:1;transform:none}}

/* Quick-quote band under the hero */
.quickband{background:var(--paper-2);border-bottom:1px solid var(--line)}
.quickband-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem 2.5rem;padding-top:1.4rem;padding-bottom:1.4rem;flex-wrap:wrap}
.quickband-copy{display:flex;flex-direction:column;line-height:1.1}
.quickband-copy .stars{color:var(--copper);letter-spacing:2px;font-size:1rem}
.quickband-copy h3{font-size:1.5rem;color:var(--ink);margin:.2rem 0 .15rem}
.quickband-copy p{margin:0;color:var(--text-soft);font-size:.9rem}
.quickband-form{display:flex;gap:.6rem;flex-wrap:wrap;flex:1;min-width:280px;justify-content:flex-end}
.quickband-form input,.quickband-form select{font:inherit;padding:.7em .9em;border:1.5px solid var(--line);border-radius:11px;background:#fff;color:var(--text);min-width:140px;flex:1}
.quickband-form input:focus,.quickband-form select:focus{outline:none;border-color:var(--copper)}
.quickband-form .btn{flex:0 0 auto}

/* Mascot badge in contact section */
.quote-avatar{display:inline-block;margin-bottom:1rem}
.quote-avatar img{width:64px;height:64px;border-radius:50%;border:2px solid var(--copper);box-shadow:var(--shadow-md)}

/* Footer brand lockup */
.footer-brand{display:flex;align-items:center;gap:.75rem}
.footer-mascot{width:48px;height:48px;border-radius:50%;flex-shrink:0;border:2px solid rgba(255,255,255,.15)}

@media(max-width:980px){
  .hero-mascot{order:-1;min-height:0}
  .hero-mascot img{max-height:340px}
  .quickband-form{justify-content:flex-start}
}
@media(max-width:760px){
  .quickband-inner{flex-direction:column;align-items:stretch}
  .quickband-form{justify-content:stretch}
  .quickband-form input,.quickband-form select,.quickband-form .btn{width:100%;flex:1 1 100%}
}

/* ============================================================
   About, FAQ, reviews CTA, TrueQuote
   ============================================================ */
.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2rem,5vw,3.5rem);align-items:start}
.about-story p{color:var(--text-soft);font-size:1.05rem}
.about-quals{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm)}
.about-quals h3{color:var(--ink);font-size:1.2rem;margin-bottom:1rem}
ul.ticks{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}
ul.ticks li{position:relative;padding-left:1.9rem;color:var(--text);font-size:.97rem}
ul.ticks li::before{content:"";position:absolute;left:0;top:.15em;width:18px;height:18px;border-radius:50%;background:var(--copper);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-size:13px;background-position:center;background-repeat:no-repeat}

.reviews-cta{text-align:center;margin-top:2.4rem}

.faq-list{max-width:820px;margin:0 auto;display:grid;gap:.8rem}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:1.15rem 1.4rem;font-family:var(--ff-display);font-weight:600;font-size:1.05rem;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-mark{position:relative;width:18px;height:18px;flex-shrink:0}
.faq-mark::before,.faq-mark::after{content:"";position:absolute;background:var(--copper);border-radius:2px;transition:transform .25s var(--ease)}
.faq-mark::before{top:8px;left:0;width:18px;height:2px}
.faq-mark::after{left:8px;top:0;width:2px;height:18px}
.faq-item[open] .faq-mark::after{transform:scaleY(0)}
.faq-item[open] summary{color:var(--copper)}
.faq-answer{padding:0 1.4rem 1.25rem}
.faq-answer p{margin:0;color:var(--text-soft)}

.truequote-box{margin-bottom:1.4rem}
.truequote-box h3{color:var(--ink);font-size:1.4rem;margin-bottom:.3rem}
.truequote-sub{color:var(--text-soft);font-size:.92rem;margin-bottom:1rem}
#truequote-widget{min-height:40px}
.quote-divider{display:flex;align-items:center;text-align:center;color:var(--text-soft);font-size:.85rem;margin:1.4rem 0;gap:1rem}
.quote-divider::before,.quote-divider::after{content:"";flex:1;height:1px;background:var(--line)}

@media(max-width:980px){ .about-grid{grid-template-columns:1fr;gap:2.6rem} .about-quals{margin-top:.25rem} }

/* Service-area map embed */
.area-visual{padding:0}
.area-map{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:var(--radius-lg);display:block;filter:saturate(1.05)}
