/* Angels Garage Doors — main.css (mobile-first, brand tokens) */
@font-face{
  font-family:"Inter";
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url("/assets/fonts/inter-var.woff2?v=1") format("woff2");
}
:root{
  --brand-primary:#0E6BA8;
  --brand-primary-dark:#0B567F;
  --brand-primary-light:#1F9DD8;
  --brand-accent:#E0A82E;
  --brand-accent-dark:#8A6400; /* AA on white */
  --ink-900:#11212B;
  --ink-700:#33424d;
  --ink-500:#5b6b76;
  --paper:#ffffff;
  --paper-2:#f4f8fb;
  --paper-3:#e9f1f7;
  --rule:#d7e2ea;
  --ok:#15803d;
  --shadow:0 1px 2px rgba(13,40,60,.06),0 6px 20px rgba(13,40,60,.08);
  --shadow-lg:0 12px 40px rgba(13,40,60,.16);
  --radius:14px;
  --radius-sm:10px;
  --wrap:1140px;
  --gap:clamp(16px,3vw,28px);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink-900);background:var(--paper);line-height:1.6;font-size:16px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{line-height:1.15;margin:0 0 .5em;font-weight:800;letter-spacing:-.01em}
h1{font-size:clamp(2rem,5vw,3.25rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.25rem)}
h3{font-size:clamp(1.2rem,2vw,1.4rem)}
p{margin:0 0 1rem}
a{color:var(--brand-primary);text-underline-offset:2px}
main a:not(.btn):not(.tile):not(.card-link):hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(16px,4vw,28px)}
.section{padding:clamp(40px,7vw,76px) 0}
.section--tint{background:var(--paper-2)}
.section--tint2{background:var(--paper-3)}
.eyebrow{font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;color:var(--brand-accent-dark);margin:0 0 .5rem}
.lead{font-size:1.125rem;color:var(--ink-700)}
.center{text-align:center}
.muted{color:var(--ink-500)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--brand-primary);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--brand-primary-light);outline-offset:2px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:800;text-decoration:none;border-radius:999px;padding:.85rem 1.5rem;border:2px solid transparent;cursor:pointer;font-size:1rem;transition:transform .08s ease,box-shadow .2s ease;line-height:1}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--brand-accent);color:var(--ink-900);box-shadow:var(--shadow)}
.btn--primary:hover{box-shadow:var(--shadow-lg)}
.btn--call{background:var(--brand-primary);color:#fff}
.btn--ghost{background:#fff;color:var(--brand-primary-dark);border-color:var(--rule)}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--lg{padding:1rem 1.9rem;font-size:1.08rem}
.btn--block{display:flex;width:100%;justify-content:center}

/* Header (built by main.js) */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:saturate(1.2) blur(6px);border-bottom:1px solid var(--rule)}
.site-header__bar{display:flex;align-items:center;gap:1rem;justify-content:space-between;padding:.6rem clamp(16px,4vw,28px);max-width:var(--wrap);margin:0 auto}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--ink-900)}
.brand img{width:44px;height:44px}
.brand b{font-size:1.18rem;font-weight:800;color:var(--brand-primary);line-height:1}
.brand small{display:block;font-size:.62rem;letter-spacing:.22em;font-weight:700;color:var(--ink-700)}
.nav{display:none;align-items:center;gap:.2rem}
.nav a{padding:.5rem .7rem;text-decoration:none;color:var(--ink-700);font-weight:600;border-radius:8px;font-size:.95rem}
.nav a:hover,.nav a[aria-current="page"]{background:var(--paper-3);color:var(--brand-primary-dark)}
.header-cta{display:none;gap:.5rem;align-items:center}
.menu-btn{display:inline-flex;background:var(--paper-3);border:1px solid var(--rule);border-radius:10px;padding:.55rem .7rem;font-weight:700;gap:.4rem;align-items:center;cursor:pointer;color:var(--ink-900)}
.mobile-nav{display:none;border-top:1px solid var(--rule);background:#fff;padding:.5rem clamp(16px,4vw,28px) 1rem}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:.7rem .4rem;border-bottom:1px solid var(--paper-3);text-decoration:none;color:var(--ink-900);font-weight:600}
.mobile-nav .btn{margin-top:.7rem}
@media(min-width:980px){.nav{display:flex}.header-cta{display:flex}.menu-btn{display:none}}

/* Urgency bar */
.urgency{background:var(--brand-primary-dark);color:#fff;text-align:center;font-size:.86rem;font-weight:600;padding:.4rem 1rem}
.urgency a{color:#fff;font-weight:800}

/* Hero */
.hero{position:relative;overflow:hidden;background:var(--brand-primary-dark)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(11,86,127,.92) 0%,rgba(14,107,168,.78) 48%,rgba(11,40,60,.55) 100%)}
.hero__inner{position:relative;z-index:1;display:grid;gap:clamp(20px,4vw,40px);grid-template-columns:1fr;padding:clamp(36px,6vw,72px) 0;color:#fff}
.hero h1{color:#fff;margin-bottom:.4em}
.hero .lead{color:rgba(255,255,255,.92)}
.hero .badge{display:inline-flex;gap:.4rem;align-items:center;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);padding:.35rem .8rem;border-radius:999px;font-weight:700;font-size:.82rem;margin-bottom:1rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.3rem}
.availcard{background:#fff;color:var(--ink-900);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow-lg)}
.availcard h3{margin-top:0}
.availcard .dot{width:10px;height:10px;border-radius:50%;background:var(--ok);display:inline-block;margin-right:.4rem;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
.availcard ul{list-style:none;margin:.6rem 0 0;padding:0}
.availcard li{display:flex;gap:.5rem;padding:.3rem 0;border-bottom:1px solid var(--paper-3);font-size:.95rem}
.availcard li:last-child{border-bottom:0}
@media(min-width:920px){.hero__inner{grid-template-columns:1.3fr .9fr;align-items:center}}

/* Trust strip */
.trust{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem;padding:1.1rem 0}
.trust .item{display:flex;gap:.55rem;align-items:center;font-weight:700;font-size:.9rem;color:var(--ink-700)}
.trust svg{flex:none;color:var(--brand-primary)}
@media(min-width:760px){.trust{grid-template-columns:repeat(6,1fr)}}

/* Grids and cards */
.grid{display:grid;gap:var(--gap)}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr 1fr}
@media(min-width:680px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr}}
@media(min-width:920px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}
.card{background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow)}
.card h3{margin-top:0}
.tile{display:block;text-decoration:none;color:inherit;background:#fff;border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .12s ease,box-shadow .2s ease}
.tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.tile img{aspect-ratio:3/2;object-fit:cover;width:100%}
.tile .tile__body{padding:1rem 1.1rem 1.2rem}
.tile h3{margin:0 0 .3rem;font-size:1.12rem;color:var(--brand-primary-dark)}
.tile p{margin:0;color:var(--ink-700);font-size:.94rem}
.tile .arrow{color:var(--brand-accent-dark);font-weight:800;margin-top:.6rem;display:inline-block}

/* Differentiator cards */
.why{display:grid;gap:var(--gap);grid-template-columns:1fr}
@media(min-width:680px){.why{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.why{grid-template-columns:repeat(4,1fr)}}
.why .card .num{font-weight:800;color:var(--brand-accent-dark);font-size:.85rem}

/* Pricing table */
.ptable{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--rule);border-radius:var(--radius);overflow:hidden}
.ptable th,.ptable td{padding:.8rem 1rem;text-align:left;border-bottom:1px solid var(--paper-3);font-size:.96rem}
.ptable th{background:var(--paper-2);font-weight:800}
.ptable td:last-child,.ptable th:last-child{text-align:center}
.ptable tr:last-child td{border-bottom:0}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--rule);border-radius:var(--radius-sm);margin:0 0 .7rem;overflow:hidden}
.faq summary{cursor:pointer;padding:1rem 1.1rem;font-weight:700;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--brand-accent-dark);font-weight:800;font-size:1.3rem}
.faq details[open] summary::after{content:"\2212"}
.faq details[open] summary{border-bottom:1px solid var(--paper-3)}
.faq .faq__a{padding:1rem 1.1rem;color:var(--ink-700)}

/* Reviews */
.review{background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow)}
.review .stars{color:var(--brand-accent);font-size:1.05rem;letter-spacing:2px}
.review p{font-style:italic;color:var(--ink-900)}
.review .who{font-weight:700;font-size:.92rem;color:var(--ink-700)}
.review .src{font-size:.82rem;color:var(--ink-500)}

/* Lead form */
.leadform{background:#fff;border:1px solid var(--rule);border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow)}
.field{margin-bottom:.85rem}
.field label{display:block;font-weight:700;font-size:.9rem;margin-bottom:.3rem}
.field input,.field select,.field textarea{width:100%;padding:.75rem .85rem;border:1px solid var(--rule);border-radius:10px;font:inherit;color:var(--ink-900);background:#fff}
.field textarea{min-height:96px;resize:vertical}
.formnote{font-size:.82rem;color:var(--ink-500);margin-top:.5rem}

/* Guarantee seal */
.seal{display:flex;gap:1rem;align-items:center;background:linear-gradient(120deg,var(--paper-2),#fff);border:1px solid var(--rule);border-radius:var(--radius);padding:1.3rem}
.seal .ico{flex:none;width:64px;height:64px;border-radius:50%;background:var(--brand-primary);display:grid;place-items:center;color:#fff}

/* Dark CTA */
.cta-dark{background:linear-gradient(120deg,var(--brand-primary-dark),var(--brand-primary));color:#fff;text-align:center}
.cta-dark h2{color:#fff}
.cta-dark .btn--ghost-light:hover{background:rgba(255,255,255,.12)}
.cta-dark__btns{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.2rem}

/* Breadcrumbs */
.crumbs{font-size:.84rem;color:var(--ink-500);padding:.9rem 0}
.crumbs a{color:var(--ink-700);text-decoration:none}
.crumbs a:hover{text-decoration:underline}

/* Sticky mobile CTA */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:90;display:grid;grid-template-columns:1fr 1fr;gap:.5rem;padding:.5rem;background:rgba(255,255,255,.97);border-top:1px solid var(--rule);box-shadow:0 -4px 16px rgba(13,40,60,.1)}
.sticky-cta .btn{padding:.8rem;font-size:.98rem}
@media(min-width:980px){.sticky-cta{display:none}}
body{padding-bottom:72px}
@media(min-width:980px){body{padding-bottom:0}}

/* Footer */
.site-footer{background:var(--ink-900);color:#cdd9e1;margin-top:0}
.site-footer a{color:#cdd9e1;text-decoration:none}
.site-footer a:hover{text-decoration:underline;color:#fff}
.footer-grid{display:grid;gap:2rem;grid-template-columns:1fr;padding:clamp(36px,6vw,60px) 0 1.5rem}
@media(min-width:760px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.site-footer h4{color:#fff;font-size:.95rem;letter-spacing:.04em;margin:0 0 .8rem}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.45rem;font-size:.92rem}
.footer-brand b{color:#fff;font-size:1.2rem}
.footer-bottom{border-top:1px solid #24343f;padding:1rem 0 2rem;font-size:.82rem;color:#9fb1bd;display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between}

/* Gallery */
.gallery{columns:2;column-gap:12px}
@media(min-width:760px){.gallery{columns:3}}
@media(min-width:1080px){.gallery{columns:4}}
.gallery img{width:100%;margin:0 0 12px;border-radius:10px;break-inside:avoid;box-shadow:var(--shadow)}

/* Toaster + exit modal */
.toaster{position:fixed;left:50%;bottom:88px;transform:translateX(-50%) translateY(20px);background:var(--ink-900);color:#fff;padding:.7rem 1.1rem;border-radius:999px;font-size:.9rem;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:.3s;z-index:120}
.toaster.show{opacity:1;transform:translateX(-50%) translateY(0)}
.modal{position:fixed;inset:0;background:rgba(11,30,45,.6);display:none;place-items:center;z-index:140;padding:1rem}
.modal.open{display:grid}
.modal__box{background:#fff;border-radius:var(--radius);max-width:440px;padding:1.6rem;box-shadow:var(--shadow-lg);position:relative}
.modal__box h3{margin-top:0}
.modal__close{position:absolute;top:.7rem;right:.8rem;background:none;border:0;font-size:1.4rem;cursor:pointer;color:var(--ink-500)}

/* Utility */
.stack>*+*{margin-top:1rem}
.pill{display:inline-block;background:var(--paper-3);color:var(--brand-primary-dark);font-weight:700;font-size:.78rem;padding:.25rem .7rem;border-radius:999px;margin:.15rem .15rem 0}
.hr{height:1px;background:var(--rule);border:0;margin:2rem 0}
.zips{font-size:.9rem;color:var(--ink-700);line-height:1.9}
hr{border:0;border-top:1px solid var(--rule)}
@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto!important;transition:none!important}}
