/* Weber Garage Door — Design System | Mobile-first */

:root{
  --c-primary:#1a3a4a;--c-gold:#e8a530;--c-body:#2d4a5a;--c-secondary:#4a5860;
  --c-light-bg:#f8f7f4;--c-white:#ffffff;--c-footer:#0f2530;--c-top-bar:#1a3a4a;
  --c-border:#d8e0e4;--radius-sm:4px;--radius-md:8px;--radius-pill:20px;
  --shadow-sm:0 1px 4px rgba(0,0,0,.08);--shadow-md:0 4px 16px rgba(0,0,0,.12);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --max-w:1200px;--section-py:48px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);font-size:14px;line-height:1.6;color:var(--c-body);background:var(--c-white)}
img{display:block;max-width:100%;height:auto}
a{color:var(--c-primary);text-decoration:none}
a:hover{color:var(--c-gold)}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-weight:800;color:var(--c-primary);line-height:1.2}
h1{font-size:2rem}h2{font-size:1.6rem}h3{font-size:1.2rem}h4{font-size:1rem}
p{margin-bottom:1rem}p:last-child{margin-bottom:0}

/* Layout */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 16px}
.section{padding:var(--section-py) 0}
.section--light{background:var(--c-light-bg)}

/* Top Bar */
.top-bar{background:var(--c-top-bar);color:rgba(255,255,255,.8);font-size:12px;padding:6px 0}
.top-bar .container{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.top-bar a{color:rgba(255,255,255,.8)}
.top-bar a:hover{color:var(--c-gold)}
.top-bar__phone{font-weight:700;color:var(--c-gold)!important}

/* Nav */
.nav{background:var(--c-white);border-bottom:2px solid var(--c-gold);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}
.nav--sticky{box-shadow:var(--shadow-md)}
.nav .container{display:flex;align-items:center;justify-content:space-between;padding-top:10px;padding-bottom:10px}
.nav__logo img{width:180px;height:auto;object-fit:contain}
.nav__menu{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--c-white);border-top:1px solid var(--c-border);box-shadow:var(--shadow-md);padding:12px 0;z-index:99}
.nav__menu--open{display:flex}
.nav__menu a{display:block;padding:10px 20px;font-size:14px;font-weight:600;color:var(--c-primary);border-bottom:1px solid var(--c-border)}
.nav__menu a:last-child{border-bottom:none}
.nav__menu a:hover{color:var(--c-gold);background:var(--c-light-bg)}
.nav__cta{background:var(--c-gold);color:var(--c-primary)!important;border-radius:var(--radius-sm);padding:8px 16px!important;font-weight:700!important;border-bottom:none!important}
.nav__cta:hover{background:#d4941e!important}
.nav__hamburger{display:flex;flex-direction:column;justify-content:space-between;width:26px;height:18px;background:none;border:none;cursor:pointer;padding:0}
.nav__hamburger span{display:block;height:2px;background:var(--c-primary);border-radius:2px;transition:transform .2s,opacity .2s}
.nav__hamburger--open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav__hamburger--open span:nth-child(2){opacity:0}
.nav__hamburger--open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* Hero */
.hero{position:relative;background:var(--c-primary);overflow:hidden;min-height:480px;display:flex;align-items:center}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(to right,rgba(255,255,255,.93) 0%,rgba(255,255,255,.93) 50%,rgba(255,255,255,.40) 100%)}
.hero-content{position:relative;z-index:2;width:100%;display:flex;flex-direction:column;gap:32px;padding:48px 0}
.hero-text{flex:1}
.hero-text .label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--c-gold);margin-bottom:12px}
.hero-text h1{font-size:2.2rem;color:var(--c-primary);margin-bottom:16px}
.hero-text p{font-size:1rem;color:var(--c-body);max-width:520px}
.hero-form{flex:0 0 auto}
.hero--service{min-height:260px}
.hero--service .hero-content{padding:36px 0}

/* Form */
.form{background:var(--c-primary);color:var(--c-white);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:24px;width:100%}
.form__title{font-size:1.1rem;font-weight:800;color:var(--c-white);margin-bottom:16px;text-align:center}
.form__group{margin-bottom:12px}
.form__label{display:block;font-size:12px;font-weight:600;color:rgba(255,255,255,.8);margin-bottom:4px;text-transform:uppercase;letter-spacing:1px}
.form__input,.form__select,.form__textarea{width:100%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-sm);color:var(--c-white);font-family:var(--font);font-size:14px;padding:10px 12px;outline:none;transition:border-color .15s}
.form__input::placeholder,.form__textarea::placeholder{color:rgba(255,255,255,.5)}
.form__input:focus,.form__select:focus,.form__textarea:focus{border-color:var(--c-gold);background:rgba(255,255,255,.15)}
.form__select option{background:var(--c-primary);color:var(--c-white)}
.form__textarea{min-height:80px;resize:vertical}
.form__submit{display:block;width:100%;background:var(--c-gold);color:var(--c-primary);font-family:var(--font);font-size:15px;font-weight:800;border:none;border-radius:var(--radius-sm);padding:14px 20px;cursor:pointer;transition:background .15s,transform .1s;margin-top:4px}
.form__submit:hover{background:#d4941e}
.form__submit:active{transform:scale(.98)}
.form__success{display:none;text-align:center;padding:24px 0;color:var(--c-white)}
.form__success--visible{display:block}
.form__success-icon{font-size:2.5rem;margin-bottom:8px}

.form__checkbox{display:flex;align-items:flex-start;gap:8px;margin-bottom:14px;font-size:12px;color:rgba(255,255,255,.7);line-height:1.4}
.form__checkbox input[type="checkbox"]{margin-top:2px;accent-color:var(--c-gold);width:16px;height:16px;flex-shrink:0}
.form__checkbox a{color:var(--c-gold);text-decoration:underline}

/* Buttons */
.btn{display:inline-block;font-family:var(--font);font-size:15px;font-weight:700;border-radius:var(--radius-sm);padding:12px 24px;cursor:pointer;border:2px solid transparent;transition:background .15s,color .15s,border-color .15s;text-align:center;white-space:nowrap}
.btn--primary{background:var(--c-gold);color:var(--c-primary);border-color:var(--c-gold)}
.btn--primary:hover{background:#d4941e;border-color:#d4941e;color:var(--c-primary)}
.btn--secondary{background:var(--c-primary);color:var(--c-white);border-color:var(--c-primary)}
.btn--secondary:hover{background:#0f2530;border-color:#0f2530;color:var(--c-white)}
.btn--outline{background:transparent;color:var(--c-primary);border-color:var(--c-primary)}
.btn--outline:hover{background:var(--c-primary);color:var(--c-white)}
.btn--lg{font-size:17px;padding:15px 32px}
.btn--sm{font-size:13px;padding:8px 16px}

/* Cards */
.card{background:var(--c-white);border-radius:var(--radius-md);border-bottom:3px solid var(--c-gold);box-shadow:var(--shadow-sm);padding:24px;transition:box-shadow .2s,transform .2s}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card__icon{font-size:2rem;margin-bottom:12px}
.card__title{font-size:1.05rem;font-weight:800;color:var(--c-primary);margin-bottom:8px}
.card--problem{background:var(--c-light-bg);border-bottom:none;border-left:3px solid var(--c-gold);border-radius:var(--radius-sm);box-shadow:none}
.card--problem:hover{box-shadow:var(--shadow-sm);transform:none}

/* Service Grid */
.service-grid{display:grid;grid-template-columns:1fr;gap:16px}
.service-link{display:block;background:var(--c-white);border-radius:var(--radius-md);border-bottom:3px solid var(--c-gold);box-shadow:var(--shadow-sm);padding:20px;transition:box-shadow .2s,transform .2s;color:var(--c-primary)}
.service-link:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);color:var(--c-gold)}
.service-link__icon{font-size:1.8rem;margin-bottom:8px}
.service-link__title{font-size:.95rem;font-weight:700}
.service-link__desc{font-size:.85rem;color:var(--c-secondary);margin-top:4px;margin-bottom:0}

/* Pill */
.pill{display:inline-block;background:var(--c-light-bg);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);font-size:13px;font-weight:600;color:var(--c-primary);padding:6px 14px}
.pill--white{background:var(--c-white)}

/* Trust Checks */
.trust-check{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}
.trust-check__icon{flex-shrink:0;width:22px;height:22px;background:var(--c-gold);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:1px}
.trust-check__icon::after{content:"";display:block;width:6px;height:10px;border:2px solid var(--c-primary);border-top:none;border-left:none;transform:rotate(45deg) translate(-1px,-1px)}
.trust-check__text{font-size:14px;color:var(--c-body)}

/* Process Steps */
.process-step{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}
.process-step__num{flex-shrink:0;width:28px;height:28px;background:var(--c-gold);color:var(--c-primary);border-radius:50%;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-top:2px}
.process-step__body h3{font-size:1rem;margin-bottom:4px}
.process-step__body p{font-size:14px;margin-bottom:0}

/* FAQ */
.faq{border-top:1px solid var(--c-border)}
.faq__item{border-bottom:1px solid var(--c-border)}
.faq__question{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 0;cursor:pointer;font-size:15px;font-weight:600;color:var(--c-primary);background:none;border:none;width:100%;text-align:left;font-family:var(--font);transition:color .15s}
.faq__question:hover{color:var(--c-gold)}
.faq__icon{flex-shrink:0;font-size:20px;font-weight:300;line-height:1;color:var(--c-gold);transition:transform .2s}
.faq__item--open .faq__icon{transform:rotate(45deg)}
.faq__answer{overflow:hidden;max-height:0;transition:max-height .3s ease-out,padding .3s;padding:0;font-size:14px;color:var(--c-body)}
.faq__item--open .faq__answer{max-height:800px;padding-bottom:16px}

/* CTA Banner */
.cta-banner{background:var(--c-gold);padding:40px 0;text-align:center}
.cta-banner h2{color:var(--c-primary);margin-bottom:8px}
.cta-banner p{color:var(--c-primary);opacity:.85;margin-bottom:24px}
.cta-banner__buttons{display:flex;flex-direction:column;gap:12px;align-items:center}

/* Breadcrumb */
.breadcrumb{font-size:12px;color:var(--c-secondary);padding:10px 0}
.breadcrumb a{color:var(--c-secondary);text-decoration:underline}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb__sep{margin:0 6px;opacity:.5}

/* Map */
.map-container{position:relative;width:100%;overflow:hidden;border-radius:var(--radius-md);height:200px}
.map-container iframe{position:absolute;inset:0;width:100%;height:100%;border:none}

/* Footer */
.footer{background:var(--c-footer);color:rgba(255,255,255,.75);padding:48px 0 0;font-size:14px}
.footer__grid{display:grid;grid-template-columns:1fr;gap:32px;padding-bottom:40px}
.footer__col h4{color:var(--c-white);font-size:.8rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:14px}
.footer__col a{display:block;color:rgba(255,255,255,.7);font-size:13px;padding:3px 0}
.footer__col a:hover{color:var(--c-gold)}
.footer__logo{width:160px;height:auto;margin-bottom:14px;object-fit:contain}
.footer__tagline{font-size:13px;color:rgba(255,255,255,.6)}
.footer__phone{font-size:1.2rem;font-weight:800;color:var(--c-gold)!important;margin-top:8px;display:inline-block}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:16px 0;display:flex;flex-direction:column;gap:8px;font-size:12px;color:rgba(255,255,255,.5)}
.footer__bottom a{color:rgba(255,255,255,.5);text-decoration:underline}
.footer__bottom a:hover{color:rgba(255,255,255,.8)}
.footer__legal{display:flex;gap:16px;flex-wrap:wrap}

/* Sticky CTA (mobile) */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--c-white);border-top:1px solid var(--c-border);box-shadow:0 -4px 16px rgba(0,0,0,.12);padding:10px 16px;gap:10px}
.sticky-cta--visible{display:flex}
.sticky-cta__call{flex:1;background:var(--c-gold);color:var(--c-primary);font-size:14px;font-weight:800;border:none;border-radius:var(--radius-sm);padding:12px 10px;text-align:center;cursor:pointer;font-family:var(--font)}
.sticky-cta__quote{flex:1;background:var(--c-white);color:var(--c-primary);font-size:14px;font-weight:700;border:2px solid var(--c-primary);border-radius:var(--radius-sm);padding:12px 10px;text-align:center;cursor:pointer;font-family:var(--font)}
.sticky-cta__call:hover{background:#d4941e}
.sticky-cta__quote:hover{background:var(--c-light-bg)}

/* Section Label */
.label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--c-gold);margin-bottom:8px}

/* Grid Helpers */
.grid-2,.grid-3,.grid-4{display:grid;grid-template-columns:1fr;gap:20px}

/* Utilities */
.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}
.skip-link{position:absolute;top:-100%;left:8px;background:var(--c-primary);color:var(--c-white);padding:8px 16px;border-radius:0 0 var(--radius-sm) var(--radius-sm);z-index:1000;font-size:14px;font-weight:600}
.skip-link:focus{top:0}
.text-center{text-align:center}
.text-gold{color:var(--c-gold)}
.text-white{color:var(--c-white)!important}
.text-muted{color:var(--c-secondary)}
.last-updated{font-size:12px;color:var(--c-secondary);font-style:italic}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}
.flex{display:flex}.flex-wrap{flex-wrap:wrap}.gap-8{gap:8px}.gap-16{gap:16px}.items-center{align-items:center}

/* 480px */
@media(min-width:480px){
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:repeat(2,1fr)}
  .cta-banner__buttons{flex-direction:row;justify-content:center}
  .problem-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
}

/* 768px */
@media(min-width:768px){
  body{font-size:16px}
  h1{font-size:2.8rem}h2{font-size:2rem}h3{font-size:1.35rem}
  :root{--section-py:72px}
  .container{padding:0 24px}
  .nav__hamburger{display:none}
  .nav__menu{display:flex!important;flex-direction:row;position:static;background:none;border:none;box-shadow:none;padding:0;gap:4px;align-items:center}
  .nav__menu a{padding:8px 12px;border-bottom:none;font-size:13px}
  .nav__menu a:hover{background:none}
  .hero-content{flex-direction:row;align-items:center;gap:48px}
  .hero-text{flex:1}.hero-form{flex:0 0 340px}
  .hero-text h1{font-size:2.8rem}
  .footer__grid{grid-template-columns:repeat(2,1fr)}
  .footer__bottom{flex-direction:row;justify-content:space-between}
  .map-container{height:300px}
  .sticky-cta,.sticky-cta--visible{display:none!important}
  .grid-3{grid-template-columns:repeat(2,1fr)}
}

/* 1024px */
@media(min-width:1024px){
  .container{padding:0 32px}
  .service-grid{grid-template-columns:repeat(4,1fr)}
  .service-grid--5{grid-template-columns:repeat(5,1fr)}
  .footer__grid{grid-template-columns:2fr 1fr 1fr 1fr}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .hero{min-height:540px}
  .hero-text h1{font-size:3.2rem}
}
