/* ============================================================
   Albuquerque Garage Door Pros — Rank & Rent Landing
   Modern minimal · Orange action · White space · Mobile-first
   ============================================================ */

:root{
  --accent:        #FF6B35;
  --accent-dark:   #E55520;
  --accent-soft:   #FFF1EA;
  --ink:           #2C3E50;
  --ink-soft:      #5A6B7C;
  --ink-muted:     #8A99A8;
  --line:          #E5E9EE;
  --bg:            #F8F9FA;
  --white:         #FFFFFF;
  --success:       #1F8A5B;

  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 16px;

  --shadow-sm: 0 1px 2px rgba(20,30,45,.06), 0 1px 3px rgba(20,30,45,.04);
  --shadow:    0 4px 14px rgba(20,30,45,.08);
  --shadow-lg: 0 18px 40px rgba(20,30,45,.12);

  --container: 1200px;
  --gutter: 24px;

  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
}

/* Variants — set on <body data-variant="..."> */
body[data-variant="trust"]{
  --accent:      #2C3E50;
  --accent-dark: #1B2A38;
  --accent-soft: #EEF2F6;
}
body[data-variant="maintenance"]{
  --accent:      #1F8A5B;
  --accent-dark: #176B47;
  --accent-soft: #E8F5EE;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:16px}

/* ---------- Layout helpers ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
}

.section{padding:80px 0}
.section--tight{padding:56px 0}
.section-eyebrow{
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:12px;
  font-weight:600;
  color:var(--accent);
  margin:0 0 10px;
}
.section-title{
  font-size:36px;
  font-weight:700;
  letter-spacing:-.02em;
  margin:0 0 12px;
  color:var(--ink);
  text-wrap:balance;
}
.section-sub{
  color:var(--ink-soft);
  font-size:17px;
  margin:0 0 40px;
  max-width:560px;
  text-wrap:pretty;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  height:52px;
  padding:0 22px;
  border-radius:var(--radius);
  font-weight:600;
  font-size:15px;
  letter-spacing:-.005em;
  transition:transform .12s ease, box-shadow .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
  white-space:nowrap;
  user-select:none;
}
.btn:active{transform:translateY(1px)}
.btn--primary{
  background:var(--accent);
  color:#fff;
  box-shadow:0 6px 16px rgba(255,107,53,.28);
}
body[data-variant="trust"] .btn--primary{box-shadow:0 6px 16px rgba(44,62,80,.25)}
body[data-variant="maintenance"] .btn--primary{box-shadow:0 6px 16px rgba(31,138,91,.25)}
.btn--primary:hover{background:var(--accent-dark)}
.btn--ghost{
  background:#fff;
  color:var(--ink);
  border:1.5px solid var(--line);
}
.btn--ghost:hover{border-color:var(--ink);}
.btn--sm{height:40px;padding:0 16px;font-size:14px;border-radius:8px}
.btn--lg{height:58px;padding:0 28px;font-size:16px}
.btn--block{width:100%}

.icon{width:18px;height:18px;flex-shrink:0}

/* ---------- Top bar ---------- */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  -webkit-backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--ink);font-size:16px;letter-spacing:-.01em}
.logo__mark{
  width:34px;height:34px;
  display:grid;place-items:center;
  background:var(--accent-soft);
  color:var(--accent);
  border-radius:8px;
}
.logo__mark svg{width:20px;height:20px}
.topbar__right{display:flex;align-items:center;gap:14px}
.topbar__phone{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:600;color:var(--accent);font-size:15px;
}
.topbar__phone:hover{color:var(--accent-dark)}
@media (max-width:640px){
  .topbar__inner{height:60px}
  .topbar__phone span{display:none}
  .logo{font-size:14px}
  .logo .logo__city{display:none}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  overflow:hidden;
  background:var(--bg);
}
.hero__grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:56px;
  align-items:center;
  padding:72px 0 88px;
}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;
  border:1px solid var(--line);
  padding:6px 12px;
  border-radius:999px;
  font-size:13px;
  font-weight:500;
  color:var(--ink-soft);
  margin-bottom:20px;
}
.hero__eyebrow .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--success);
  box-shadow:0 0 0 0 rgba(31,138,91,.6);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(31,138,91,.5)}
  70%{box-shadow:0 0 0 10px rgba(31,138,91,0)}
  100%{box-shadow:0 0 0 0 rgba(31,138,91,0)}
}
.hero__title{
  font-size:clamp(34px, 4.6vw, 56px);
  line-height:1.05;
  letter-spacing:-.025em;
  font-weight:700;
  margin:0 0 18px;
  color:var(--ink);
  text-wrap:balance;
}
.hero__title em{color:var(--accent);font-style:normal}
.hero__sub{
  font-size:18px;
  color:var(--ink-soft);
  margin:0 0 32px;
  max-width:520px;
  text-wrap:pretty;
}
.hero__sub b{color:var(--ink);font-weight:600}
.hero__ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:28px}
.hero__meta{
  display:flex;flex-wrap:wrap;gap:18px 24px;
  color:var(--ink-soft);font-size:14px;
}
.hero__meta-item{display:inline-flex;align-items:center;gap:6px}
.hero__meta-item svg{width:16px;height:16px;color:var(--success)}

.hero__media{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  aspect-ratio: 4/5;
}
.hero__media img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.hero__badge{
  position:absolute;
  left:20px;bottom:20px;
  background:#fff;
  border-radius:12px;
  padding:14px 16px;
  box-shadow:var(--shadow);
  display:flex;align-items:center;gap:12px;
  max-width:calc(100% - 40px);
}
.hero__badge-icon{
  width:40px;height:40px;border-radius:10px;
  background:var(--accent-soft);
  color:var(--accent);
  display:grid;place-items:center;flex-shrink:0;
}
.hero__badge-icon svg{width:22px;height:22px}
.hero__badge-text strong{display:block;font-size:14px;color:var(--ink);font-weight:600}
.hero__badge-text span{font-size:12px;color:var(--ink-muted)}

@media (max-width:900px){
  .hero__grid{grid-template-columns:1fr;gap:32px;padding:48px 0 64px}
  .hero__media{aspect-ratio:4/3;max-height:420px}
}

/* ---------- Services ---------- */
.services{background:#fff}
.services__grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:20px;
}
.service{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:28px;
  transition:border-color .15s, transform .15s, box-shadow .15s;
}
.service:hover{
  border-color:var(--accent);
  transform:translateY(-2px);
  box-shadow:var(--shadow);
}
.service__icon{
  width:48px;height:48px;
  border-radius:12px;
  background:var(--accent-soft);
  color:var(--accent);
  display:grid;place-items:center;
  margin-bottom:18px;
}
.service__icon svg{width:24px;height:24px}
.service__title{font-size:19px;font-weight:600;margin:0 0 8px;color:var(--ink)}
.service__desc{font-size:15px;color:var(--ink-soft);margin:0 0 16px;line-height:1.5}
.service__link{
  font-size:14px;font-weight:600;color:var(--accent);
  display:inline-flex;align-items:center;gap:4px;
}
.service__link:hover{gap:8px}
@media (max-width:640px){
  .services__grid{grid-template-columns:1fr}
}

/* ---------- Trust row ---------- */
.trust{background:var(--bg);padding:32px 0}
.trust__row{
  display:flex;flex-wrap:wrap;justify-content:center;gap:12px 14px;
}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 18px;
  font-size:14px;
  font-weight:500;
  color:var(--ink);
}
.pill svg{width:16px;height:16px;color:var(--accent)}
.pill .star{color:#F5A623}

/* ---------- Before / After ---------- */
.ba{background:#fff}
.ba__pair{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  background:var(--bg);
  border-radius:var(--radius-lg);
  padding:18px;
  border:1px solid var(--line);
}
.ba__pairs{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:900px){.ba__pairs{grid-template-columns:1fr}}
.ba__img{
  position:relative;
  aspect-ratio:3/2;
  border-radius:var(--radius);
  overflow:hidden;
  background:#dde3ea;
}
.ba__img img{width:100%;height:100%;object-fit:cover;display:block}
.ba__img--full{aspect-ratio:3/2}
.ba__tag{
  position:absolute;top:10px;left:10px;
  background:rgba(20,30,45,.78);
  color:#fff;
  font-size:11px;font-weight:600;
  padding:4px 10px;
  border-radius:999px;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.ba__tag--after{background:var(--success)}
.ba__caption{
  grid-column:1/-1;
  display:flex;align-items:center;gap:10px;
  font-size:14px;font-weight:500;color:var(--ink);
  padding:6px 4px 2px;
}
.ba__caption svg{width:18px;height:18px;color:var(--success);flex-shrink:0}

/* ---------- Lead form section (form + image) ---------- */
.book{background:var(--bg)}
.book__grid{
  display:grid;
  grid-template-columns:1fr 460px;
  gap:48px;
  align-items:start;
}
.book__copy h2{font-size:36px;font-weight:700;letter-spacing:-.02em;margin:0 0 14px;text-wrap:balance}
.book__copy p{font-size:17px;color:var(--ink-soft);margin:0 0 28px;max-width:520px}
.book__checks{display:grid;gap:14px;margin-bottom:28px}
.book__check{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--ink)}
.book__check svg{width:22px;height:22px;color:var(--success);flex-shrink:0;margin-top:1px}
.book__check b{font-weight:600;display:block}
.book__check span{color:var(--ink-soft);font-size:14px}

.form-card{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:28px;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  position:sticky;top:96px;
}
.form-card__title{font-size:20px;font-weight:700;margin:0 0 4px}
.form-card__sub{font-size:14px;color:var(--ink-soft);margin:0 0 22px}
.form-card__urgent{
  background:var(--accent-soft);
  color:var(--accent-dark);
  border-radius:8px;
  padding:10px 12px;
  font-size:13px;font-weight:500;
  margin-bottom:18px;
  display:flex;align-items:center;gap:8px;
}
.form-card__urgent svg{width:16px;height:16px;flex-shrink:0}

.form-grid{display:grid;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;font-weight:500;color:var(--ink)}
.field label .req{color:var(--accent)}
.field input,.field select{
  height:46px;
  padding:0 14px;
  border:1.5px solid var(--line);
  border-radius:8px;
  background:#fff;
  color:var(--ink);
  transition:border-color .15s, box-shadow .15s;
}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path fill='none' stroke='%235A6B7C' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M3 4.5l3 3 3-3'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.field input:focus,.field select:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.field input::placeholder{color:var(--ink-muted)}
/* honeypot */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

.form-card__submit{margin-top:6px}
.form-card__legal{font-size:12px;color:var(--ink-muted);margin:14px 0 0;text-align:center;line-height:1.5}

.form-thanks{
  text-align:center;padding:40px 16px;
}
.form-thanks__icon{
  width:64px;height:64px;border-radius:50%;
  background:var(--success);color:#fff;
  display:grid;place-items:center;margin:0 auto 18px;
}
.form-thanks__icon svg{width:32px;height:32px}
.form-thanks h3{font-size:22px;font-weight:700;margin:0 0 8px}
.form-thanks p{color:var(--ink-soft);font-size:15px;margin:0}

@media (max-width:980px){
  .book__grid{grid-template-columns:1fr;gap:32px}
  .form-card{position:static;max-width:560px}
}

/* ---------- FAQ ---------- */
.faq{background:#fff}
.faq__list{max-width:780px;margin:0 auto}
.faq__item{
  border-bottom:1px solid var(--line);
}
.faq__item:first-child{border-top:1px solid var(--line)}
.faq__q{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:22px 0;
  font-size:17px;font-weight:600;
  text-align:left;
  color:var(--ink);
}
.faq__q .plus{
  width:28px;height:28px;border-radius:50%;
  background:var(--bg);
  display:grid;place-items:center;flex-shrink:0;
  transition:background .15s, transform .25s;
}
.faq__q .plus svg{width:14px;height:14px;color:var(--ink);transition:transform .25s}
.faq__item.open .faq__q .plus{background:var(--accent);}
.faq__item.open .faq__q .plus svg{color:#fff;transform:rotate(45deg)}
.faq__a{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows .28s ease;
}
.faq__a > div{overflow:hidden}
.faq__item.open .faq__a{grid-template-rows:1fr}
.faq__a p{
  margin:0 0 22px;
  color:var(--ink-soft);
  font-size:15.5px;
  line-height:1.6;
  max-width:680px;
}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#cdd5dd;padding:64px 0 32px}
.footer__cta{
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  border-radius:var(--radius-lg);
  padding:36px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  margin-bottom:48px;
  color:#fff;
}
body[data-variant="trust"] .footer__cta{background:linear-gradient(135deg,#3D556F,#1B2A38)}
body[data-variant="maintenance"] .footer__cta{background:linear-gradient(135deg,#2BA471,#176B47)}
.footer__cta h3{font-size:24px;font-weight:700;margin:0 0 4px;letter-spacing:-.01em}
.footer__cta p{margin:0;opacity:.9;font-size:15px}
.footer__cta-actions{display:flex;gap:10px;flex-shrink:0}
.footer__cta .btn--primary{background:#fff;color:var(--accent);box-shadow:none}
.footer__cta .btn--primary:hover{background:#f3f3f3}
body[data-variant="trust"] .footer__cta .btn--primary{color:#1B2A38}
body[data-variant="maintenance"] .footer__cta .btn--primary{color:#176B47}
.footer__cta .btn--ghost{background:transparent;border-color:rgba(255,255,255,.5);color:#fff}
.footer__cta .btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
@media (max-width:760px){
  .footer__cta{flex-direction:column;align-items:flex-start;padding:28px}
  .footer__cta-actions{width:100%;flex-direction:column}
  .footer__cta-actions .btn{width:100%}
}

.footer__grid{
  display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:40px;
  margin-bottom:40px;
}
.footer__col h4{
  font-size:13px;text-transform:uppercase;letter-spacing:.12em;
  font-weight:600;color:#fff;margin:0 0 14px;
}
.footer__col p,.footer__col a{font-size:14px;line-height:1.7;color:#cdd5dd}
.footer__col a:hover{color:#fff}
.footer__col ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.footer__map{
  border-radius:12px;overflow:hidden;border:1px solid #3a4a5c;background:#1f2c3a;
  aspect-ratio:16/9;
}
.footer__map iframe{width:100%;height:100%;border:0;display:block}
.footer__bottom{
  border-top:1px solid #3a4a5c;
  padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;color:#9aa6b3;flex-wrap:wrap;gap:12px;
}
.footer__bottom a{color:#cdd5dd;margin-left:16px}
.footer__bottom a:first-of-type{margin-left:0}
@media (max-width:760px){
  .footer__grid{grid-template-columns:1fr;gap:28px}
}

/* ---------- Mobile sticky CTA ---------- */
.mobile-cta{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:60;
  background:#fff;
  border-top:1px solid var(--line);
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  gap:8px;
  box-shadow:0 -4px 16px rgba(20,30,45,.06);
}
.mobile-cta .btn{flex:1;height:50px;font-size:14px}
@media (max-width:760px){
  .mobile-cta{display:flex}
  body{padding-bottom:80px}
}

/* ---------- Fade in on load ---------- */
.fade-in{opacity:0;transform:translateY(12px);transition:opacity .6s ease, transform .6s ease}
.fade-in.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .fade-in{opacity:1;transform:none;transition:none}
  .hero__eyebrow .dot{animation:none}
}

