/*
Theme Name: Quality Disposal
Theme URI: https://qualitydisposal.com
Description: Custom standalone theme for Quality Disposal — a Grand Rapids, MI waste & recycling company. Reproduces the approved homepage and service-page designs (Panera-inspired greens + gold), with responsive layouts and the service-area ZIP checker. No parent theme required; activating it auto-creates the 6 pages and sets the homepage.
Author: Ashwanth (with Claude)
Version: 1.0.0
Text Domain: quality-disposal
*/

/* =========================================================
   DESIGN TOKENS
   ========================================================= */
:root{
  --qd-forest:#1B4332;     /* dark sections, footer band, CTAs */
  --qd-deep:#10231a;       /* deepest green, footer base */
  --qd-green:#2D6A4F;      /* main brand green */
  --qd-mid:#40916C;        /* mid green */
  --qd-light:#D8F3DC;      /* light green panels, chips */
  --qd-light-border:#b7e0c2;
  --qd-gold:#D4A843;       /* primary CTA */
  --qd-gold-soft:#E8C46A;  /* gold heading accent on dark */
  --qd-gold-light:#F4E3B8; /* eyebrows on dark */
  --qd-cream:#FAFAF7;      /* page background */
  --qd-ink:#10231a;
  --qd-ink-2:#18221c;
  --qd-body:#4a554c;
  --qd-body-2:#5a655c;
  --qd-muted:#7c8a80;
  --qd-border:#e7e4dc;
  --qd-border-2:#ece7da;
  --qd-maxw:1240px;
}

/* =========================================================
   BASE — neutralize GeneratePress defaults for full-bleed design
   ========================================================= */
body.quality-disposal,
.quality-disposal .site-content,
.quality-disposal .content-area{
  background:var(--qd-cream);
  color:var(--qd-ink-2);
  font-family:'Source Sans 3', system-ui, -apple-system, sans-serif;
  -webkit-font-smoothing:antialiased;
  margin:0;
}
.quality-disposal .site-content{ padding:0; }
.quality-disposal .inside-article,
.quality-disposal .entry-content{ margin:0; }
/* Make the GP container full width on our templates */
.quality-disposal #page,
.quality-disposal .site-content,
.quality-disposal #content{ max-width:100%; padding:0; margin:0; }
.quality-disposal .entry-content > *{ margin:0; }

.qd h1,.qd h2,.qd h3,.qd h4,
.qd-page h1,.qd-page h2,.qd-page h3,.qd-page h4{
  font-family:'Playfair Display', Georgia, serif; margin:0;
}
.qd-page{ letter-spacing:0; }
.qd p{ margin:0; }
.qd a{ text-decoration:none; }
.qd ul{ margin:0; padding:0; list-style:none; }
.qd img{ display:block; max-width:100%; }
.qd *{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body.quality-disposal a[href^="tel:"]{ font-variant-numeric:lining-nums; font-feature-settings:'lnum' 1; }

@keyframes qdHeroIn{ from{opacity:0; transform:translateY(22px);} to{opacity:1; transform:translateY(0);} }

/* shared wrappers */
.qd-wrap{ max-width:var(--qd-maxw); margin:0 auto; padding-left:28px; padding-right:28px; }

/* =========================================================
   UTILITY BAR
   ========================================================= */
.qd-utility{ background:var(--qd-forest); color:rgba(255,255,255,0.82); font-size:13px; }
.qd-utility-inner{ padding:4px 28px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.qd-utility a{ display:flex; align-items:center; gap:7px; color:inherit; text-decoration:none; }
.qd-utility .qd-util-left{ display:flex; gap:22px; align-items:center; flex-wrap:wrap; }
.qd-utility .qd-util-right{ display:flex; align-items:center; gap:14px; }
.qd-utility svg{ width:14px; height:14px; fill:var(--qd-gold); }
.qd-social{ display:flex; gap:8px; }
.qd-social a{ width:25px; height:25px; border-radius:50%; background:rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; }
.qd-util-cta{ background:var(--qd-gold); color:var(--qd-forest)!important; font-weight:700; font-size:12px; letter-spacing:0.06em; text-transform:uppercase; padding:7px 16px; border-radius:5px; }

/* =========================================================
   HEADER / NAV
   ========================================================= */
.qd-header{ position:sticky; top:0; z-index:60; background:rgba(255,255,255,0.92); backdrop-filter:blur(10px); border-bottom:1px solid var(--qd-border-2); box-shadow:0 2px 14px rgba(27,67,50,0.05); }
.qd-header-inner{ max-width:var(--qd-maxw); margin:0 auto; padding:8px 28px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.qd-brand{ display:flex; align-items:center; gap:11px; }
.qd-logo{ width:52px; height:52px; border-radius:10px; background:var(--qd-green); display:flex; align-items:center; justify-content:center; color:#fff; font-family:'Playfair Display'; font-weight:900; font-size:27px; }
.qd-brand-name{ display:flex; flex-direction:column; line-height:1.1; }
.qd-brand-name b{ font-family:'Playfair Display'; font-weight:700; font-size:24px; color:var(--qd-forest); }
.qd-brand-name span{ font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--qd-gold); font-weight:700; }
.qd-nav{ display:flex; align-items:center; gap:6px; font-size:13.5px; font-weight:600; letter-spacing:0.03em; text-transform:uppercase; color:var(--qd-body); }
.qd-nav a{ padding:8px 13px; border-radius:5px; color:var(--qd-body); }
.qd-nav a:hover{ color:var(--qd-green); }
.qd-nav a.qd-current{ color:var(--qd-green); }
.qd-nav a.qd-contact{ background:var(--qd-green); color:#fff; padding:10px 20px; border-radius:6px; margin-left:6px; }
.qd-nav-toggle{ display:none; background:none; border:none; cursor:pointer; padding:8px; }
.qd-nav-toggle span{ display:block; width:24px; height:2px; background:var(--qd-forest); margin:5px 0; transition:.25s; }

/* =========================================================
   HOME — HERO
   ========================================================= */
.qd-hero{ position:relative; min-height:600px; display:flex; align-items:center; overflow:hidden; background:var(--qd-forest); }
.qd-hero-bg{ position:absolute; inset:0; background-position:center; background-size:cover; background-repeat:no-repeat; }
.qd-hero-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(102deg, rgba(16,35,26,0.93) 0%, rgba(27,67,50,0.82) 44%, rgba(27,67,50,0.32) 100%); }
.qd-hero-inner{ position:relative; z-index:2; padding:74px 28px 120px; max-width:var(--qd-maxw); margin:0 auto; width:100%; }
.qd-hero-copy{ max-width:660px; animation:qdHeroIn .7s ease both; }
.qd-eyebrow{ display:flex; align-items:center; gap:11px; margin-bottom:20px; }
.qd-eyebrow i{ width:40px; height:2px; background:var(--qd-gold); display:block; }
.qd-eyebrow span{ font-size:12.5px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--qd-gold-light); }
.qd-hero h1{ font-size:54px; line-height:1.08; font-weight:900; color:#fff; }
.qd-hero h1 em{ color:var(--qd-gold-soft); font-style:normal; }
.qd-hero p{ margin-top:20px; font-size:18px; line-height:1.6; color:rgba(255,255,255,0.8); max-width:540px; }
.qd-hero-cta{ margin-top:32px; display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.qd-btn-gold{ background:var(--qd-gold); color:var(--qd-forest); font-weight:700; font-size:15px; letter-spacing:0.05em; text-transform:uppercase; padding:15px 30px; border-radius:6px; box-shadow:0 8px 22px rgba(212,168,67,0.35); }
.qd-link-underline{ color:#fff; font-weight:600; font-size:15px; display:flex; align-items:center; gap:8px; padding:13px 4px; border-bottom:1.5px solid rgba(255,255,255,0.35); }
.qd-trust{ position:absolute; bottom:0; left:0; right:0; z-index:3; background:rgba(16,35,26,0.78); backdrop-filter:blur(8px); border-top:1px solid rgba(212,168,67,0.28); padding:16px 28px; display:flex; gap:30px; align-items:center; justify-content:center; flex-wrap:wrap; color:rgba(255,255,255,0.82); font-size:13.5px; font-weight:600; }
.qd-trust span.qd-pt{ display:flex; align-items:center; gap:9px; }
.qd-trust span.qd-pt b{ color:var(--qd-gold); font-weight:700; }
.qd-trust .qd-divider{ width:1px; height:22px; background:rgba(255,255,255,0.16); }

/* =========================================================
   HOME — SERVICE CARDS
   ========================================================= */
.qd-services{ display:grid; grid-template-columns:repeat(4,1fr); }
.qd-card{ position:relative; overflow:hidden; min-height:450px; display:flex; flex-direction:column; justify-content:flex-end; transition:box-shadow .25s; }
.qd-card:hover{ box-shadow:inset 0 -5px 0 var(--qd-gold); }
.qd-card-bg{ position:absolute; inset:0; background-position:center; background-size:cover; }
.qd-card-overlay{ position:absolute; inset:0; background:linear-gradient(to top, rgba(16,35,26,0.97) 6%, rgba(16,35,26,0.58) 44%, rgba(16,35,26,0.1) 100%), linear-gradient(to right, rgba(16,35,26,0.92) 0%, rgba(16,35,26,0) 24%, rgba(16,35,26,0) 76%, rgba(16,35,26,0.92) 100%); }
.qd-card-num{ position:absolute; top:12px; right:20px; font-family:'Playfair Display'; font-size:66px; font-weight:900; color:rgba(255,255,255,0.1); line-height:1; }
.qd-card-body{ position:relative; padding:26px 26px 30px; }
.qd-card-body h3{ font-family:'Playfair Display'; font-size:25px; font-weight:700; color:#fff; margin-bottom:9px; }
.qd-card-body p{ font-size:14px; line-height:1.55; color:rgba(255,255,255,0.78); margin-bottom:14px; }
.qd-card-more{ display:inline-flex; align-items:center; gap:7px; font-size:12px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--qd-gold-light); }

/* =========================================================
   HOME — SPLIT "WHY CHOOSE US"
   ========================================================= */
.qd-split{ display:grid; grid-template-columns:1fr 1fr; min-height:500px; }
.qd-split-panel{ background:var(--qd-forest); padding:66px 56px; display:flex; flex-direction:column; justify-content:center; position:relative; overflow:hidden; }
.qd-split-panel::before{ content:""; position:absolute; bottom:-80px; right:-80px; width:280px; height:280px; border-radius:50%; background:rgba(212,168,67,0.08); }
.qd-split-inner{ position:relative; }
.qd-split-inner .qd-eyebrow i{ width:36px; }
.qd-split-inner .qd-eyebrow span{ letter-spacing:0.16em; }
.qd-split h2{ font-size:40px; font-weight:700; color:#fff; line-height:1.15; }
.qd-split h2 em{ color:var(--qd-gold-soft); font-style:normal; }
.qd-split p{ margin-top:18px; font-size:16.5px; line-height:1.7; color:rgba(255,255,255,0.72); max-width:480px; }
.qd-perks{ margin-top:26px; display:flex; flex-direction:column; gap:12px; }
.qd-perks li{ display:flex; align-items:center; gap:11px; font-size:15.5px; color:rgba(255,255,255,0.85); font-weight:500; }
.qd-perks svg{ width:17px; height:17px; fill:var(--qd-gold); flex-shrink:0; }
.qd-split-cta{ margin-top:32px; display:flex; gap:14px; flex-wrap:wrap; }
.qd-btn-gold-sm{ background:var(--qd-gold); color:var(--qd-forest); font-weight:700; font-size:14px; letter-spacing:0.05em; text-transform:uppercase; padding:14px 28px; border-radius:6px; }
.qd-btn-ghost{ border:1.5px solid rgba(255,255,255,0.3); color:rgba(255,255,255,0.9); font-weight:600; font-size:14px; letter-spacing:0.05em; text-transform:uppercase; padding:12px 26px; border-radius:6px; }
.qd-split-photos{ display:grid; grid-template-rows:1fr 1fr; }
.qd-split-photo{ position:relative; background-position:center; background-size:cover; min-height:250px; }
.qd-split-photo + .qd-split-photo{ border-top:3px solid var(--qd-gold); }
.qd-split-photo::after{ content:""; position:absolute; inset:0; background:rgba(0,0,0,0.16); }
.qd-split-photo span{ position:absolute; bottom:16px; left:16px; z-index:2; background:rgba(16,35,26,0.82); color:#fff; font-size:12px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; padding:8px 14px; border-radius:4px; border-left:3px solid var(--qd-gold); }

/* =========================================================
   HOME — ABOUT
   ========================================================= */
.qd-about{ background:var(--qd-cream); padding:90px 28px; }
.qd-about-grid{ max-width:1180px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center; }
.qd-about .qd-eyebrow span{ color:var(--qd-gold); }
.qd-about h2{ font-size:38px; font-weight:700; color:var(--qd-forest); line-height:1.18; }
.qd-about h2 em{ color:var(--qd-gold); font-style:normal; }
.qd-about p{ margin-top:18px; font-size:16.5px; line-height:1.75; color:var(--qd-body); }
.qd-about p strong{ color:var(--qd-forest); }
.qd-badge{ display:inline-flex; align-items:center; gap:10px; background:var(--qd-forest); color:#fff; padding:12px 22px; border-radius:40px; font-size:14.5px; font-weight:700; margin-top:24px; }
.qd-badge svg{ width:18px; height:18px; fill:var(--qd-gold); }
.qd-about-figure{ position:relative; }
.qd-about-figure .qd-photo{ border-radius:14px; overflow:hidden; aspect-ratio:4/3; box-shadow:0 20px 50px -20px rgba(27,67,50,0.4); }
.qd-about-figure .qd-photo img{ width:100%; height:100%; object-fit:cover; }
.qd-stat{ position:absolute; bottom:-22px; left:-24px; background:var(--qd-gold); color:var(--qd-forest); padding:18px 26px; border-radius:12px; box-shadow:0 12px 32px rgba(0,0,0,0.2); text-align:center; }
.qd-stat b{ font-family:'Playfair Display'; font-size:42px; font-weight:900; line-height:1; display:block; }
.qd-stat span{ font-size:12px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; line-height:1.2; margin-top:4px; display:block; }

/* =========================================================
   HOME — SERVICE-AREA CHECKER
   ========================================================= */
.qd-geo{ background:linear-gradient(135deg,var(--qd-forest) 0%,var(--qd-deep) 100%); padding:80px 28px; }
.qd-geo-grid{ max-width:1180px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.qd-geo .qd-eyebrow i{ width:36px; }
.qd-geo .qd-eyebrow span{ color:var(--qd-gold-light); }
.qd-geo h2{ font-size:36px; font-weight:700; color:#fff; line-height:1.18; }
.qd-geo p{ margin-top:14px; font-size:16px; line-height:1.65; color:rgba(255,255,255,0.72); max-width:440px; }
.qd-geo-field{ margin-top:26px; display:flex; max-width:480px; border-radius:8px; overflow:hidden; box-shadow:0 10px 30px rgba(0,0,0,0.3); }
.qd-geo-field input{ flex:1; padding:16px 18px; font-size:15px; border:none; background:#fff; color:var(--qd-ink-2); outline:none; font-family:inherit; }
.qd-geo-field button{ background:var(--qd-gold); color:var(--qd-forest); border:none; padding:16px 24px; font-family:inherit; font-weight:700; font-size:14px; letter-spacing:0.05em; text-transform:uppercase; cursor:pointer; }
.qd-geo-result{ margin-top:16px; font-size:15.5px; font-weight:700; }
.qd-geo-result.ok{ color:#8FE3A0; }
.qd-geo-result.no{ color:#F4B89A; }
.qd-geo-continue{ margin-top:16px; display:inline-flex; align-items:center; gap:9px; background:var(--qd-gold); color:var(--qd-forest); font-weight:700; font-size:14px; letter-spacing:0.05em; text-transform:uppercase; padding:14px 28px; border-radius:6px; box-shadow:0 8px 22px rgba(212,168,67,0.3); }
.qd-geo-note{ margin-top:18px; font-size:13.5px; color:rgba(255,255,255,0.45); }
.qd-geo-note a{ color:var(--qd-gold-light); }
.qd-geo-map{ border-radius:14px; overflow:hidden; box-shadow:0 20px 50px -18px rgba(0,0,0,0.6); border:1px solid rgba(212,168,67,0.3); }
.qd-geo-map img{ width:100%; }

/* =========================================================
   FOOTER
   ========================================================= */
.qd-footer{ background:var(--qd-deep); color:rgba(255,255,255,0.62); }
.qd-footer a{ color:inherit; text-decoration:none; transition:color .15s; }
.qd-footer a:hover{ color:#fff; }
.qd-footer-grid{ max-width:var(--qd-maxw); margin:0 auto; padding:56px 28px 30px; display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:40px; }
.qd-footer-brand .qd-fb{ display:flex; align-items:center; gap:11px; margin-bottom:14px; }
.qd-footer-brand .qd-flogo{ width:40px; height:40px; border-radius:10px; background:var(--qd-gold); display:flex; align-items:center; justify-content:center; color:var(--qd-forest); font-family:'Playfair Display'; font-weight:900; font-size:21px; }
.qd-footer-brand b{ font-family:'Playfair Display'; font-weight:700; font-size:18px; color:#fff; display:block; }
.qd-footer-brand .qd-ftag{ font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:rgba(244,227,184,0.8); font-weight:700; }
.qd-footer-brand p{ font-size:14px; line-height:1.65; max-width:280px; }
.qd-fsocial{ display:flex; gap:9px; margin-top:18px; }
.qd-fsocial a{ width:33px; height:33px; border-radius:50%; background:rgba(255,255,255,0.08); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; color:rgba(255,255,255,0.7); }
.qd-footer h4{ font-size:12px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--qd-gold-light); margin-bottom:15px; }
.qd-footer ul{ display:flex; flex-direction:column; gap:10px; font-size:14px; }
.qd-footer-contact{ display:flex; flex-direction:column; gap:11px; font-size:14px; }
.qd-footer-contact a,.qd-footer-contact span{ display:flex; gap:9px; align-items:center; }
.qd-footer-contact svg{ width:15px; height:15px; fill:var(--qd-gold); flex-shrink:0; }
.qd-footer-bottom{ border-top:1px solid rgba(255,255,255,0.1); }
.qd-footer-bottom .qd-fb-inner{ max-width:var(--qd-maxw); margin:0 auto; padding:20px 28px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:13px; color:rgba(255,255,255,0.45); }

/* =========================================================
   INNER SERVICE PAGES
   ========================================================= */
.qd-page{ background:#fff; }
.qd-page-hero{ background:linear-gradient(180deg,var(--qd-cream) 0%,#ffffff 100%); }
.qd-page-hero-grid{ max-width:1200px; margin:0 auto; padding:54px 28px 56px; display:grid; grid-template-columns:1.05fr 0.95fr; gap:54px; align-items:center; }
.qd-breadcrumb{ font-size:13px; color:var(--qd-muted); font-weight:600; margin-bottom:18px; }
.qd-breadcrumb a{ color:var(--qd-green); }
.qd-page-hero h1{ font-size:52px; line-height:1.03; font-weight:900; color:var(--qd-deep); letter-spacing:-0.02em; }
.qd-page-hero p{ margin-top:20px; font-size:18px; line-height:1.55; color:var(--qd-body); max-width:520px; }
.qd-page-hero-cta{ margin-top:30px; display:flex; gap:14px; flex-wrap:wrap; }
.qd-pill-gold{ background:var(--qd-gold); color:var(--qd-forest); font-weight:700; font-size:16px; padding:15px 28px; border-radius:999px; box-shadow:0 10px 24px -10px rgba(212,168,67,0.55); }
.qd-pill-outline{ background:#fff; color:#15201a; font-weight:700; font-size:16px; padding:15px 28px; border-radius:999px; border:1.5px solid #d9d6cd; }
.qd-page-hero-figure{ aspect-ratio:4/3; border-radius:24px; overflow:hidden; box-shadow:0 20px 50px -20px rgba(27,67,50,0.35); }
.qd-page-hero-figure img{ width:100%; height:100%; object-fit:cover; }

.qd-section{ max-width:1200px; margin:0 auto; padding:74px 28px 20px; }
.qd-kicker{ font-size:12.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--qd-green); font-weight:700; margin-bottom:12px; }
.qd-section > h2{ font-size:38px; font-weight:900; color:var(--qd-deep); line-height:1.05; max-width:620px; letter-spacing:-0.02em; }
.qd-features{ margin-top:38px; display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.qd-feature{ display:flex; gap:16px; border:1px solid var(--qd-border); border-radius:16px; padding:24px; }
.qd-feature.span2{ grid-column:span 2; }
.qd-feature .qd-check{ flex:none; width:34px; height:34px; border-radius:9px; background:var(--qd-light); color:var(--qd-green); display:flex; align-items:center; justify-content:center; font-weight:800; }
.qd-feature h3{ font-size:18px; font-weight:800; color:var(--qd-deep); }
.qd-feature p{ margin-top:6px; font-size:15px; color:var(--qd-body-2); line-height:1.5; }

.qd-panel-wrap{ max-width:1200px; margin:0 auto; padding:64px 28px; }
.qd-panel{ background:var(--qd-light); border:1px solid var(--qd-light-border); border-radius:24px; padding:44px; }
.qd-panel h2{ font-size:30px; font-weight:900; color:var(--qd-deep); }
.qd-panel > p{ margin-top:10px; font-size:16px; color:var(--qd-body-2); max-width:560px; }
.qd-panel-grid{ margin-top:30px; display:grid; gap:16px; }
.qd-panel-grid.cols-2{ grid-template-columns:1fr 1fr; }
.qd-panel-grid.cols-3{ grid-template-columns:repeat(3,1fr); gap:14px; }
.qd-panel-grid.cols-4{ grid-template-columns:repeat(4,1fr); }
.qd-panel-card{ background:#fff; border:1px solid var(--qd-border); border-radius:16px; padding:28px; }
.qd-panel-card .qd-big{ font-family:'Playfair Display'; font-weight:900; font-size:42px; color:var(--qd-green); }
.qd-panel-card .qd-big small{ font-size:18px; color:var(--qd-muted); }
.qd-panel-card .qd-size{ font-family:'Playfair Display'; font-weight:900; font-size:20px; color:var(--qd-green); }
.qd-panel-card h3{ margin-top:6px; font-size:19px; font-weight:800; color:var(--qd-deep); }
.qd-panel-card p{ margin-top:8px; font-size:14.5px; color:var(--qd-body-2); line-height:1.5; }
.qd-chip{ background:#fff; border:1px solid var(--qd-border); border-radius:14px; padding:20px; font-weight:700; color:var(--qd-deep); }

.qd-cross{ max-width:1200px; margin:0 auto; padding:10px 28px 60px; }
.qd-cross h2{ font-size:24px; font-weight:800; color:var(--qd-deep); margin-bottom:22px; }
.qd-cross-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.qd-cross-grid a{ border:1px solid var(--qd-border); border-radius:16px; padding:24px; display:flex; justify-content:space-between; align-items:center; transition:border-color .2s, box-shadow .2s; }
.qd-cross-grid a:hover{ border-color:var(--qd-mid); box-shadow:0 8px 20px -14px rgba(27,67,50,0.4); }
.qd-cross-grid a b{ font-family:'Playfair Display'; font-weight:800; font-size:18px; color:var(--qd-deep); }
.qd-cross-grid a span{ color:var(--qd-green); font-weight:800; }

.qd-cta-band-wrap{ padding:20px 28px 84px; }
.qd-cta-band{ max-width:1200px; margin:0 auto; background:var(--qd-forest); border-radius:28px; padding:56px; text-align:center; }
.qd-cta-band h2{ font-size:38px; font-weight:900; color:#fff; max-width:620px; margin:0 auto; line-height:1.08; }
.qd-cta-band p{ margin-top:16px; font-size:17px; color:#bfe0ca; max-width:480px; margin-left:auto; margin-right:auto; }
.qd-cta-band-cta{ margin-top:28px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.qd-cta-band-cta .qd-pill-gold{ color:var(--qd-deep); font-weight:800; }
.qd-cta-band-cta .qd-pill-clear{ background:transparent; color:#fff; font-weight:700; font-size:16px; padding:15px 30px; border-radius:999px; border:1.5px solid rgba(255,255,255,0.3); }

/* =========================================================
   GET STARTED — FORM
   ========================================================= */
.qd-gs-head{ background:linear-gradient(180deg,var(--qd-cream) 0%,#ffffff 100%); padding:48px 28px 10px; }
.qd-gs-head-inner{ max-width:1140px; margin:0 auto; }
.qd-gs-head .qd-eyebrow span{ color:var(--qd-gold); }
.qd-gs-head h1{ font-size:46px; font-weight:900; color:var(--qd-forest); line-height:1.1; max-width:680px; }
.qd-zip-confirm{ margin-top:16px; display:inline-flex; align-items:center; gap:9px; background:var(--qd-light); border:1px solid var(--qd-light-border); color:var(--qd-forest); font-size:14px; font-weight:700; padding:9px 16px; border-radius:999px; }
.qd-zip-confirm b{ color:var(--qd-green); }
.qd-gs-body{ padding:34px 28px 84px; }
.qd-gs-grid{ max-width:1140px; margin:0 auto; display:grid; grid-template-columns:1.4fr 1fr; gap:40px; align-items:start; }
.qd-form-card{ background:#fff; border:1px solid var(--qd-border-2); border-radius:18px; padding:40px; box-shadow:0 18px 44px -28px rgba(27,67,50,0.35); }
.qd-form-card h2{ font-size:24px; font-weight:700; color:var(--qd-forest); }
.qd-form-card > p{ margin-top:8px; font-size:15px; color:var(--qd-body-2); }
.qd-form-grid{ margin-top:26px; display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.qd-form-grid label{ display:flex; flex-direction:column; gap:7px; font-size:13px; font-weight:700; color:var(--qd-forest); letter-spacing:0.02em; }
.qd-form-grid label.span2{ grid-column:span 2; }
.qd-form-grid label .opt{ font-weight:500; color:#9a948a; }
.qd-form-grid input,.qd-form-grid select,.qd-form-grid textarea{ padding:13px 14px; font-size:15px; border:1.5px solid #d9d6cd; border-radius:9px; outline:none; color:var(--qd-ink-2); font-family:inherit; background:#fff; }
.qd-form-grid input:focus,.qd-form-grid select:focus,.qd-form-grid textarea:focus{ border-color:var(--qd-green); }
.qd-form-grid textarea{ resize:vertical; }
.qd-form-submit{ margin-top:24px; width:100%; background:var(--qd-gold); color:var(--qd-forest); border:none; font-weight:700; font-size:15px; letter-spacing:0.05em; text-transform:uppercase; padding:16px; border-radius:9px; cursor:pointer; box-shadow:0 8px 22px rgba(212,168,67,0.32); }
.qd-form-fine{ margin-top:12px; font-size:12.5px; color:#9a948a; text-align:center; }
.qd-form-thanks{ text-align:center; padding:30px 10px; }
.qd-form-thanks .qd-tick{ width:64px; height:64px; border-radius:50%; background:var(--qd-light); display:flex; align-items:center; justify-content:center; margin:0 auto; font-size:30px; color:var(--qd-green); }
.qd-form-thanks h2{ margin-top:20px; font-size:28px; font-weight:700; color:var(--qd-forest); }
.qd-form-thanks p{ margin-top:12px; font-size:16px; line-height:1.6; color:var(--qd-body-2); max-width:380px; margin-left:auto; margin-right:auto; }
.qd-form-thanks .qd-back{ margin-top:24px; display:inline-block; background:var(--qd-green); color:#fff; font-weight:700; font-size:14px; letter-spacing:0.04em; text-transform:uppercase; padding:13px 28px; border-radius:8px; }
.qd-gs-side{ display:flex; flex-direction:column; gap:20px; }
.qd-gs-call{ background:var(--qd-forest); border-radius:18px; padding:32px; color:#fff; text-align:center; }
.qd-gs-call .qd-eyebrow span{ color:var(--qd-gold-light); }
.qd-gs-call .qd-phone{ display:block; margin-top:10px; font-family:'Playfair Display'; font-weight:800; font-size:36px; color:#fff; text-align:center; }
.qd-gs-call p{ margin-top:10px; font-size:14.5px; color:rgba(255,255,255,0.7); line-height:1.55; }
.qd-gs-steps{ background:#fff; border:1px solid var(--qd-border-2); border-radius:18px; padding:32px; }
.qd-gs-steps h3{ font-size:18px; font-weight:700; color:var(--qd-forest); }
.qd-gs-steps .qd-steps{ margin-top:18px; display:flex; flex-direction:column; gap:16px; }
.qd-step{ display:flex; gap:13px; }
.qd-step .qd-n{ flex:none; width:28px; height:28px; border-radius:50%; background:var(--qd-light); color:var(--qd-green); font-weight:800; font-size:14px; display:flex; align-items:center; justify-content:center; }
.qd-step div{ font-size:14.5px; color:var(--qd-body); line-height:1.5; }
.qd-step div strong{ color:var(--qd-forest); }

.qd-hide{ display:none!important; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .qd-hero h1{ font-size:46px; }
  .qd-split-panel{ padding:54px 40px; }
  .qd-about-grid{ gap:48px; }
}
@media (max-width:900px){
  .qd-nav{ position:absolute; top:100%; left:0; right:0; background:#fff; flex-direction:column; align-items:stretch; gap:0; padding:8px 16px 16px; border-bottom:1px solid var(--qd-border-2); box-shadow:0 12px 24px rgba(27,67,50,0.08); display:none; }
  .qd-nav.qd-open{ display:flex; }
  .qd-nav a{ padding:12px 8px; border-radius:6px; }
  .qd-nav a.qd-contact{ margin-left:0; margin-top:6px; text-align:center; }
  .qd-nav-toggle{ display:block; }
  .qd-header-inner{ position:relative; }

  .qd-services{ grid-template-columns:1fr 1fr; }
  .qd-split{ grid-template-columns:1fr; }
  .qd-split-photos{ grid-template-rows:none; grid-template-columns:1fr 1fr; }
  .qd-split-photo + .qd-split-photo{ border-top:none; border-left:3px solid var(--qd-gold); }
  .qd-about-grid{ grid-template-columns:1fr; gap:60px; }
  .qd-geo-grid{ grid-template-columns:1fr; gap:36px; }
  .qd-page-hero-grid{ grid-template-columns:1fr; gap:36px; }
  .qd-page-hero h1{ font-size:42px; }
  .qd-gs-grid{ grid-template-columns:1fr; }
  .qd-footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:620px){
  .qd-wrap,.qd-hero-inner,.qd-header-inner,.qd-utility-inner{ padding-left:18px; padding-right:18px; }
  .qd-hero{ min-height:520px; }
  .qd-hero-inner{ padding:54px 18px 130px; }
  .qd-hero h1{ font-size:34px; }
  .qd-hero p{ font-size:16px; }
  .qd-services{ grid-template-columns:1fr; }
  .qd-split-panel{ padding:44px 22px; }
  .qd-split h2{ font-size:30px; }
  .qd-split-photos{ grid-template-columns:1fr; }
  .qd-split-photo + .qd-split-photo{ border-left:none; border-top:3px solid var(--qd-gold); }
  .qd-about{ padding:60px 18px; }
  .qd-about h2{ font-size:30px; }
  .qd-geo{ padding:56px 18px; }
  .qd-geo h2{ font-size:28px; }
  .qd-geo-field{ flex-direction:column; }
  .qd-page-hero h1{ font-size:34px; }
  .qd-section{ padding:48px 18px 10px; }
  .qd-section > h2{ font-size:30px; }
  .qd-features{ grid-template-columns:1fr; }
  .qd-feature.span2{ grid-column:auto; }
  .qd-panel-wrap{ padding:40px 18px; }
  .qd-panel{ padding:28px; }
  .qd-panel-grid.cols-2,.qd-panel-grid.cols-3,.qd-panel-grid.cols-4{ grid-template-columns:1fr; }
  .qd-cross-grid{ grid-template-columns:1fr; }
  .qd-cta-band{ padding:40px 24px; }
  .qd-cta-band h2{ font-size:28px; }
  .qd-form-card{ padding:26px; }
  .qd-form-grid{ grid-template-columns:1fr; }
  .qd-form-grid label.span2{ grid-column:auto; }
  .qd-gs-head h1{ font-size:34px; }
  .qd-footer-grid{ grid-template-columns:1fr; gap:28px; }
}
