/* Atlantic Garage Experts — supplemental (non-critical) styles */

/* Lead form fields */
.lead-form .fields{display:grid;gap:14px}
.lead-form label{display:block;font-family:'Oswald',sans-serif;font-weight:500;color:#0a1f44;font-size:.95rem}
.lead-form input,.lead-form select,.lead-form textarea{
  width:100%;margin-top:5px;padding:11px 12px;border:1px solid #cfd6e2;border-radius:7px;
  font-family:inherit;font-size:1rem;background:#fff;color:#1a2230
}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{
  outline:none;border-color:#c9a227;box-shadow:0 0 0 3px rgba(201,162,39,.18)
}
.lead-form textarea{resize:vertical}

/* Contact / form two-column responsiveness */
@media(max-width:820px){
  #quote .wrap{grid-template-columns:1fr !important}
  section .wrap[style*="grid-template-columns"]{grid-template-columns:1fr !important}
  aside .card[style*="sticky"]{position:static !important}
}

/* details/summary markers */
details summary{position:relative;padding-right:38px !important;list-style:none}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);color:#c9a227;font-size:1.4rem;font-weight:700}
details[open] summary::after{content:"\2212"}

/* neighborhood list two-col on small screens collapses */
@media(max-width:560px){
  ul[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important}
}

/* image rendering */
img{font-style:italic;color:#5b6577}

/* skip-to-content for a11y on focus */
a.skip{position:absolute;left:-9999px}
a.skip:focus{left:10px;top:10px;background:#0a1f44;color:#fff;padding:10px 14px;border-radius:6px;z-index:100}

/* float-call hidden on very small print */
@media print{.float-call-desktop,.mobile-cta,.topbar,nav.main{display:none}}

/* ---------- Google-style review cards ---------- */
.gcard{position:relative;background:#fff;border:1px solid #e3ddcd;border-radius:12px;padding:22px 22px 18px;box-shadow:0 2px 10px rgba(10,31,68,.06)}
.gcard .glogo{position:absolute;top:16px;right:16px}
.gcard-top{display:flex;align-items:center;gap:12px;padding-right:30px}
.gavatar{flex:0 0 auto;width:44px;height:44px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-weight:600;font-size:1.1rem}
.gmeta{display:flex;flex-direction:column;line-height:1.25}
.gname{font-weight:700;color:#1a2230;font-size:1rem}
.gname svg{margin-left:3px}
.gdate{color:#5b6577;font-size:.85rem}
.gstars{color:#fbbc05;font-size:1.15rem;letter-spacing:1px;margin:12px 0 8px}
.gtext{color:#1a2230;margin:0 0 12px}
.gloc{color:#5b6577;font-size:.85rem;border-top:1px solid #eee6d6;padding-top:10px}

/* Service cards with image header */
.card-svc{padding:0;overflow:hidden;display:flex;flex-direction:column}
.card-thumb{display:block;aspect-ratio:3/2;overflow:hidden;background:#eef1f7}
.card-thumb picture{display:block;width:100%;height:100%}
.card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .25s}
.card-svc:hover .card-thumb img{transform:scale(1.05)}
.card-svc .card-body{padding:22px}

/* Trust strip + brand logos */
.trust-strip{display:flex;flex-wrap:wrap;gap:16px 26px;align-items:center;justify-content:center;margin-top:22px}
.brands-row{display:flex;flex-wrap:wrap;gap:20px 34px;align-items:center;justify-content:center}
.brands-row img{filter:grayscale(100%);opacity:.72;transition:.2s}
.brands-row img:hover{filter:none;opacity:1}
.foot-brands{display:flex;flex-wrap:wrap;align-items:center;gap:12px 18px;justify-content:center;padding-bottom:22px;margin-bottom:22px;border-bottom:1px solid #20396b}
.foot-brands-label{color:#cdd6e6;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:1px;font-size:.78rem}
.foot-brands img{background:#fff;border-radius:6px;padding:5px 8px}

/* Masonry gallery */
.masonry{column-count:4;column-gap:14px}
.masonry-item{display:block;margin:0 0 14px;break-inside:avoid;border-radius:10px;overflow:hidden;cursor:zoom-in;box-shadow:0 3px 12px rgba(10,31,68,.1)}
.masonry-item img{width:100%;height:auto;display:block;transition:transform .2s}
.masonry-item:hover img{transform:scale(1.04)}
@media(max-width:1000px){.masonry{column-count:3}}
@media(max-width:680px){.masonry{column-count:2}}
@media(max-width:380px){.masonry{column-count:1}}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:1100;display:none;align-items:center;justify-content:center;background:rgba(8,18,40,.93);padding:24px;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:95vw;max-height:90vh;border-radius:8px;box-shadow:0 10px 50px rgba(0,0,0,.6)}
.lightbox-x{position:fixed;top:12px;right:20px;background:none;border:0;color:#fff;font-size:2.6rem;line-height:1;cursor:pointer}

/* Video facade (click-to-play, Bunny Stream) */
.video-embed{position:relative;aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#0a1f44,#11305f);box-shadow:0 6px 20px rgba(10,31,68,.18)}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-embed .video-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.82)}
.video-play{position:absolute;inset:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:transparent;border:0;cursor:pointer;color:#fff}
.video-play .vp-icon{width:64px;height:64px;border-radius:50%;background:#c9a227;color:#0a1f44;display:flex;align-items:center;justify-content:center;font-size:1.4rem;padding-left:4px;box-shadow:0 4px 16px rgba(0,0,0,.3);transition:.15s}
.video-play:hover .vp-icon{transform:scale(1.08);background:#e3c14e}
.video-play .vp-label{font-family:'Oswald',sans-serif;font-weight:600;letter-spacing:.5px;text-transform:uppercase;font-size:.92rem;text-shadow:0 1px 4px rgba(0,0,0,.4)}

/* Google rating summary card */
.grating{background:#fff;border:1px solid #e3ddcd;border-radius:12px;padding:24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;box-shadow:0 2px 10px rgba(10,31,68,.06)}
.grating .score{font-family:'Oswald',sans-serif;font-size:3.2rem;color:#0a1f44;line-height:1}
.grating .gstars{font-size:1.5rem;margin:4px 0}
.grating .gsum-right{display:flex;align-items:center;gap:10px}

/* ---------- Item 1: service sidebar sticky-as-one-unit (overlap fix) ----------
   Both aside cards live in .svc-aside and move together, so the Related Services
   card can never slide up over the CTA card's technician image. On <=820px the
   contact grid collapses to one column and the rail is plain flow. */
.svc-aside{display:grid;gap:18px}
@media(min-width:821px){
  .svc-rail{align-self:stretch}
  .svc-aside{position:sticky;top:90px}
}

/* ---------- Item 3: small vertical (9:16) video reel ---------- */
.video-embed--portrait{aspect-ratio:9/16;max-width:300px;margin:0 auto;border-radius:16px}
.reel-wrap{align-items:center}
@media(max-width:820px){.reel-wrap{text-align:center}.video-embed--portrait{max-width:280px}}

/* ---------- Item 4: inline form validation errors ---------- */
.f-err{display:block;color:#d93025;font-size:.8rem;margin-top:4px;font-family:'Source Sans 3',sans-serif;font-weight:600}
.lead-form input.is-invalid,.lead-form select.is-invalid{border-color:#d93025;box-shadow:0 0 0 3px rgba(217,48,37,.14)}

/* ---------- Item 2: gallery preview spacing ---------- */
.masonry--preview{margin-top:26px}

/* ---------- Item 5: designed Thank-You popup ---------- */
.thanks-modal{position:fixed;inset:0;z-index:1200;display:none;align-items:center;justify-content:center;padding:24px 16px}
.thanks-modal.open{display:flex}
.tm-backdrop{position:fixed;inset:0;background:rgba(10,31,68,.66)}
.tm-card{position:relative;background:#fff;border-radius:16px;max-width:420px;width:100%;padding:34px 28px 26px;text-align:center;box-shadow:0 24px 70px rgba(0,0,0,.45);border-top:5px solid var(--gold);animation:lmIn .2s ease-out}
.tm-x{position:absolute;top:8px;right:12px;background:none;border:0;font-size:2rem;line-height:1;color:var(--muted);cursor:pointer;padding:4px 8px}
.tm-x:hover{color:var(--navy)}
.tm-logo{display:flex;justify-content:center;margin-bottom:10px}
.tm-card h3{font-size:1.8rem;margin-bottom:8px;color:var(--navy)}
.tm-card p{color:var(--muted);margin-bottom:18px}
.tm-call{display:block;width:100%;margin-bottom:10px}
.tm-close-btn{display:block;width:100%;background:#eef1f7;color:var(--navy)}
.tm-close-btn:hover{background:#e2e7f1}
