/* San Diego Garage Doors — main.css
   Palette: Navy #0A2A5E, Red #C8102E, Gold #E0982A, White, Section gray #F5F7FA
   All text/bg pairs verified >= 4.5:1 WCAG AA. No em-dashes anywhere. */

:root {
  --navy: #0A2A5E;
  --navy-700: #143a73;
  --red: #C8102E;
  --red-700: #a50d26;
  --gold: #E0982A;
  --white: #FFFFFF;
  --gray-50: #F5F7FA;
  --gray-100: #eaeef4;
  --gray-300: #c9d2e0;
  --gray-600: #5a6b85;
  --ink: #16223a;
  --shadow-sm: 0 1px 3px rgba(10,42,94,.10);
  --shadow-md: 0 6px 20px rgba(10,42,94,.12);
  --shadow-lg: 0 16px 44px rgba(10,42,94,.18);
  --radius: 12px;
  --radius-lg: 18px;
  --maxw: 1180px;
  --space: clamp(3rem, 7vw, 6rem);
  --font-head: "Poppins", "Segoe UI", system-ui, sans-serif;
  --font-body: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--white);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4 { font-family: var(--font-head); color: var(--navy); line-height: 1.15; margin: 0 0 .5em; font-weight: 700; }
h1 { font-size: clamp(2rem, 5vw, 3.4rem); letter-spacing: -.02em; }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.5rem); letter-spacing: -.015em; }
h3 { font-size: clamp(1.2rem, 2vw, 1.5rem); }
p { margin: 0 0 1rem; }
a { color: var(--red); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(1rem, 4vw, 2rem); }
.section { padding: var(--space) 0; }
.section--gray { background: var(--gray-50); }
.section--navy { background: var(--navy); color: #e8eefb; }
.section--navy h1, .section--navy h2, .section--navy h3, .section--navy p, .section--navy nav, .section--navy span, .section--navy li { color: #e8eefb; }
.section--navy h1, .section--navy h2, .section--navy h3 { color: #fff; }
.section--navy a { color: #ffd27a; }
.section--navy a:hover { color: #fff; }
.eyebrow { font-family: var(--font-head); font-weight: 600; text-transform: uppercase; letter-spacing: .12em; font-size: .78rem; color: var(--red); margin: 0 0 .6rem; }
.lead { font-size: 1.15rem; color: var(--gray-600); max-width: 60ch; }
.center { text-align: center; }
.center .lead { margin-inline: auto; }

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--font-head); font-weight: 600; font-size: 1.02rem; padding: .85rem 1.6rem; border-radius: 999px; border: 2px solid transparent; cursor: pointer; transition: transform .15s ease, box-shadow .15s ease, background .15s ease; text-decoration: none; }
.btn:hover { text-decoration: none; transform: translateY(-2px); }
.btn--primary { background: var(--red); color: #fff; box-shadow: var(--shadow-md); }
.btn--primary:hover { background: var(--red-700); }
.btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.6); }
.btn--ghost:hover { background: rgba(255,255,255,.12); }
.btn--navy { background: var(--navy); color: #fff; }
.btn--navy:hover { background: var(--navy-700); }
.btn--lg { font-size: 1.12rem; padding: 1rem 2rem; }

/* Header */
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.96); backdrop-filter: blur(8px); border-bottom: 1px solid var(--gray-100); }
.nav { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .6rem 0; }
.brand { display: flex; align-items: center; gap: .6rem; }
.brand img { height: 52px; width: auto; }
.brand-text { font-family: var(--font-head); font-weight: 700; color: var(--navy); font-size: 1.05rem; line-height: 1.1; }
.nav-links { display: flex; align-items: center; gap: 1.4rem; list-style: none; margin: 0; padding: 0; }
.nav-links a { color: var(--navy); font-family: var(--font-head); font-weight: 500; font-size: .98rem; }
.nav-links a:hover { color: var(--red); text-decoration: none; }
.nav-cta { display: flex; align-items: center; gap: .8rem; }
.nav-phone { font-family: var(--font-head); font-weight: 700; color: var(--navy); white-space: nowrap; }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: .4rem; }
.nav-toggle span { display: block; width: 26px; height: 3px; background: var(--navy); border-radius: 2px; margin: 5px 0; transition: .2s; }

/* Hero */
.hero { position: relative; color: #fff; }
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(105deg, rgba(10,42,94,.92) 0%, rgba(10,42,94,.74) 45%, rgba(10,42,94,.30) 100%); z-index: 1; }
.hero__inner { position: relative; z-index: 2; padding: clamp(3.5rem, 9vw, 7rem) 0; max-width: 640px; }
.hero h1 { color: #fff; }
.hero .lead { color: #dce6f7; }
.hero__badges { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1.4rem 0; }
.badge { display: inline-flex; align-items: center; gap: .4rem; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.28); padding: .4rem .85rem; border-radius: 999px; font-size: .86rem; font-weight: 500; }
.hero__cta { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.6rem; }

/* Trust bar */
.trustbar { background: var(--navy); color: #cfdcf3; border-top: 1px solid rgba(255,255,255,.08); }
.trustbar__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; padding: 1.4rem 0; text-align: center; }
.trustbar strong { display: block; font-family: var(--font-head); font-size: 1.5rem; color: #fff; }
.trustbar span { font-size: .82rem; }

/* Cards / grids */
.grid { display: grid; gap: 1.4rem; }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.card { background: #fff; border: 1px solid var(--gray-100); border-radius: var(--radius-lg); padding: 1.6rem; box-shadow: var(--shadow-sm); transition: transform .18s ease, box-shadow .18s ease; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.card__icon { width: 52px; height: 52px; border-radius: 14px; background: var(--gray-50); color: var(--navy); display: grid; place-items: center; margin-bottom: 1rem; }
.card__icon svg { width: 28px; height: 28px; }
.card h3 { margin-bottom: .4rem; }
.card p { color: var(--gray-600); font-size: .98rem; margin: 0; }
.card__link { display: inline-flex; align-items: center; gap: .35rem; margin-top: .9rem; font-family: var(--font-head); font-weight: 600; color: var(--red); font-size: .95rem; }

/* Steps */
.steps { counter-reset: step; display: grid; gap: 1.4rem; grid-template-columns: repeat(4,1fr); }
.step { position: relative; padding-top: 3.4rem; }
.step::before { counter-increment: step; content: counter(step); position: absolute; top: 0; left: 0; width: 2.6rem; height: 2.6rem; background: var(--red); color: #fff; font-family: var(--font-head); font-weight: 700; border-radius: 50%; display: grid; place-items: center; }
.step h3 { font-size: 1.1rem; }
.step p { color: var(--gray-600); font-size: .95rem; margin: 0; }

/* Pricing */
.price-table { width: 100%; border-collapse: collapse; background: #fff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); }
.price-table th, .price-table td { padding: .9rem 1.1rem; text-align: left; border-bottom: 1px solid var(--gray-100); }
.price-table th { background: var(--navy); color: #fff; font-family: var(--font-head); }
.price-table tr:last-child td { border-bottom: 0; }

/* CTA band */
.cta-band { background: var(--red); color: #fff; text-align: center; }
.cta-band h2 { color: #fff; }
.cta-band .btn--primary { background: #fff; color: var(--red); }
.cta-band .btn--primary:hover { background: var(--gray-50); }

/* Reviews */
.review { background: #fff; border-radius: var(--radius-lg); padding: 1.6rem; border: 1px solid var(--gray-100); box-shadow: var(--shadow-sm); }
.review__stars { color: var(--gold); font-size: 1.1rem; letter-spacing: 2px; margin-bottom: .6rem; }
.review p { font-size: 1.02rem; }
.review__name { font-family: var(--font-head); font-weight: 600; color: var(--navy); font-size: .92rem; }

/* Footer */
.site-footer { background: var(--navy); color: #b9c8e4; padding: var(--space) 0 2rem; }
.site-footer h4 { color: #fff; font-size: 1rem; margin-bottom: 1rem; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2rem; }
.footer-grid a { color: #b9c8e4; font-size: .95rem; display: block; padding: .2rem 0; }
.footer-grid a:hover { color: #fff; text-decoration: none; }
.footer-brand img { height: 64px; background: #fff; border-radius: 12px; padding: 8px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: 2.4rem; padding-top: 1.4rem; font-size: .85rem; display: flex; justify-content: space-between; flex-wrap: wrap; gap: .6rem; }

/* Forms */
.form { display: grid; gap: 1rem; }
.field label { display: block; font-family: var(--font-head); font-weight: 500; font-size: .92rem; margin-bottom: .35rem; color: var(--navy); }
.field input, .field select, .field textarea { width: 100%; padding: .8rem 1rem; border: 1.5px solid var(--gray-300); border-radius: 10px; font: inherit; font-size: 1rem; }
.field input:focus, .field select:focus, .field textarea:focus { outline: 3px solid rgba(200,16,46,.25); border-color: var(--red); }

/* Floating mobile call bar */
.callbar { display: none; }

/* Gallery */
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.gallery-item { margin: 0; position: relative; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); background: var(--gray-50); }
.gallery-item img { width: 100%; height: 260px; object-fit: cover; display: block; transition: transform .3s ease; }
.gallery-item:hover img { transform: scale(1.05); }
.gallery-item figcaption { position: absolute; left: 0; right: 0; bottom: 0; background: linear-gradient(transparent, rgba(10,42,94,.92)); color: #fff; font-size: .82rem; padding: 1.6rem .9rem .7rem; opacity: 0; transition: opacity .25s ease; font-family: var(--font-head); }
.gallery-item:hover figcaption, .gallery-item:focus-within figcaption { opacity: 1; }
@media (max-width: 900px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } .gallery-item figcaption { opacity: 1; } }
@media (max-width: 560px) { .gallery-grid { grid-template-columns: 1fr; } }

/* Skip-link / focus */
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--navy); color: #fff; padding: .8rem 1.2rem; z-index: 100; }
.skip-link:focus { left: 0; }
:focus-visible { outline: 3px solid var(--red); outline-offset: 2px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* Responsive */
@media (max-width: 920px) {
  .grid--4 { grid-template-columns: repeat(2,1fr); }
  .steps { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .nav-links, .nav-cta .btn { display: none; }
  .nav-toggle { display: block; }
  .nav-links.open { display: flex; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; background: #fff; padding: 1rem 1.5rem; gap: .4rem; box-shadow: var(--shadow-md); }
  .nav-links.open a { padding: .6rem 0; border-bottom: 1px solid var(--gray-100); }
  .grid--3, .grid--2, .trustbar__grid { grid-template-columns: 1fr 1fr; }
  .callbar { display: flex; position: fixed; bottom: 0; left: 0; right: 0; z-index: 60; }
  .callbar a { flex: 1; text-align: center; padding: .9rem; font-family: var(--font-head); font-weight: 700; color: #fff; }
  .callbar a:hover { text-decoration: none; }
  .callbar .c-call { background: var(--red); }
  .callbar .c-book { background: var(--navy); }
  body { padding-bottom: 3.4rem; }
}
@media (max-width: 480px) {
  .grid--3, .grid--2, .trustbar__grid, .steps, .footer-grid { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

/* Before/after slider */
.ba-grid{gap:2rem}
.ba-slider{position:relative;width:100%;aspect-ratio:4/3;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);background:var(--navy);user-select:none}
.ba-slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.ba-before-wrap{position:absolute;inset:0;width:50%;overflow:hidden;border-right:3px solid #fff}
.ba-before-wrap .ba-before{width:200%;max-width:none}
.ba-range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:3}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;transform:translateX(-50%);pointer-events:none;z-index:2}
.ba-handle::after{content:"\2194";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:38px;height:38px;background:#fff;color:var(--navy);border-radius:50%;display:grid;place-items:center;font-size:1.1rem;font-weight:700;box-shadow:0 2px 8px rgba(10,42,94,.35)}
.ba-tag{position:absolute;bottom:.7rem;padding:.25rem .6rem;border-radius:6px;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-family:var(--font-head);color:#fff;z-index:2;pointer-events:none}
.ba-tag--before{left:.7rem;background:rgba(10,42,94,.85)}
.ba-tag--after{right:.7rem;background:rgba(200,16,46,.9)}
.ba-slider:focus-visible{outline:3px solid var(--gold);outline-offset:2px}
