/* =========================================================
   Aluminum Glass Pro Systems - Mobile-First Stylesheet
   Brand: soft light blue primary, soft yellow accent only,
   black text, white / off-white background, light gray separators.
   ========================================================= */

/* BRAND TOKENS
   --blue        soft light blue (logo)        #7DB2E0
   --blue-deep   readable blue for text/links  #2E6DA4
   --blue-ink    deep navy for headings        #1B3A57
   --yellow      soft accent (CTA)             #F2D466
   --yellow-deep CTA hover / shadow            #E3BE45
   --ink         body text                     #222831
   --muted       secondary text                #5B6770
   --line        light gray separators         #E7ECF1
   --bg          white                         #FFFFFF
   --bg-soft     off-white section             #F7FAFC
   --green       quiet trust (call accent)     #2E8B6F  (used sparingly)
*/
:root{
  --blue:#7DB2E0;
  --blue-soft:#EAF3FB;
  --blue-deep:#2E6DA4;
  --blue-ink:#1B3A57;
  --yellow:#F2D466;
  --yellow-deep:#E3BE45;
  --yellow-soft:#FDF6DC;
  --ink:#222831;
  --muted:#5B6770;
  --line:#E7ECF1;
  --bg:#FFFFFF;
  --bg-soft:#F7FAFC;
  --shadow:0 2px 10px rgba(27,58,87,.06);
  --shadow-card:0 1px 3px rgba(27,58,87,.08);
  --radius:14px;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  padding-bottom:78px; /* room for sticky CTA */
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--blue-deep);text-decoration:none;}
a:hover{text-decoration:underline;}

/* CONTAINER */
.container{width:100%;max-width:760px;margin:0 auto;padding:0 20px;}

/* HEADINGS */
h1{font-size:1.72rem;line-height:1.22;margin:0 0 12px;font-weight:800;color:var(--blue-ink);letter-spacing:-.2px;}
h2{font-size:1.42rem;line-height:1.3;margin:0 0 10px;font-weight:800;color:var(--blue-ink);letter-spacing:-.2px;}
h3{font-size:1.12rem;margin:10px 0 6px;font-weight:700;color:var(--blue-ink);}
.section-sub{color:var(--muted);margin-top:-2px;margin-bottom:20px;}

/* Accent underline used under section titles */
.accent-line{display:block;width:46px;height:4px;border-radius:3px;background:var(--yellow);margin:6px 0 16px;}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(180%) blur(6px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 16px;max-width:760px;margin:0 auto;
}
.logo{display:flex;align-items:center;}
.logo img{height:42px;width:auto;}
.btn-call-header{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--blue-deep);color:#fff;
  padding:10px 15px;border-radius:10px;
  font-weight:700;font-size:.95rem;min-height:44px;
}
.btn-call-header:hover{text-decoration:none;background:#255b8a;}

/* ============ HERO ============ */
.hero{
  background:
    radial-gradient(120% 90% at 85% -10%, var(--blue-soft) 0%, rgba(234,243,251,0) 55%),
    linear-gradient(180deg,#FFFFFF 0%, var(--bg-soft) 100%);
  padding:26px 0 30px;
  border-bottom:1px solid var(--line);
}
.hero .eyebrow{
  display:inline-block;
  font-size:.78rem;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  color:var(--blue-deep);
  background:#fff;border:1px solid var(--blue);
  padding:6px 12px;border-radius:999px;margin-bottom:14px;
  box-shadow:var(--shadow-card);
}
.hero h1{margin-bottom:10px;}
.hero h1 .hl{
  background:linear-gradient(180deg,transparent 62%, var(--yellow) 62%);
  padding:0 2px;
}
.hero .sub{font-size:1.06rem;margin:0 0 20px;color:#3a4753;}

.hero-photo{margin:0 0 20px;}

.cta-row{display:flex;flex-direction:column;gap:11px;margin-bottom:18px;}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  text-align:center;padding:16px 18px;border-radius:12px;
  font-weight:800;font-size:1.06rem;min-height:54px;line-height:1.2;
  border:2px solid transparent;touch-action:manipulation;transition:background .15s ease;
}
.btn-primary{background:var(--yellow);color:#3a2f00;box-shadow:0 2px 0 var(--yellow-deep),var(--shadow-card);}
.btn-primary:hover{background:#f6dc7f;text-decoration:none;}
.btn-secondary{background:#fff;color:var(--blue-deep);border-color:var(--blue);}
.btn-secondary:hover{background:var(--blue-soft);text-decoration:none;}
.btn-block{width:100%;margin-top:6px;}
.btn-small{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  background:var(--blue-deep);color:#fff;padding:11px 16px;border-radius:9px;
  font-weight:700;font-size:.95rem;margin-top:10px;min-height:44px;width:100%;
}
.btn-small:hover{background:#255b8a;text-decoration:none;}
.btn-text{display:inline-block;color:var(--blue-deep);font-weight:700;margin-top:8px;}
.btn-text:hover{text-decoration:none;color:#255b8a;}

/* Secondary text-link CTA under the service grid (e.g. "See Our Work") */
.services-cta{text-align:center;margin-top:18px;}
.btn-text-cta{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:44px;padding:10px 14px;
}

/* TRUST POINTS (hero) */
.trust-points{
  list-style:none;padding:14px;margin:0;
  display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;
  font-size:.92rem;color:var(--ink);font-weight:600;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);
}
.trust-points li{padding:2px 0;display:flex;align-items:center;gap:7px;}
.trust-points li::before{content:"";flex:0 0 auto;width:16px;height:16px;border-radius:50%;
  background:var(--blue-soft);border:1.5px solid var(--blue);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%232E6DA4' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;}

/* ============ TRUST BAR ============ */
.trust-bar{background:#fff;padding:16px 0;border-bottom:1px solid var(--line);}
.trust-bar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;text-align:center;}
.trust-item{display:flex;flex-direction:column;gap:2px;padding:4px 2px;}
.trust-item strong{color:var(--blue-deep);font-size:.98rem;}
.trust-item .stars{color:var(--yellow-deep);font-size:.95rem;letter-spacing:1px;}
.trust-item span{font-size:.76rem;color:var(--muted);}
.trust-item + .trust-item{border-left:1px solid var(--line);}

/* ============ SECTIONS ============ */
section{padding:34px 0;}
section.hero{padding-top:26px;padding-bottom:30px;}
.bg-soft{background:var(--bg-soft);}

/* ============ PREMIUM IMAGE PLACEHOLDERS ============ */
.img-placeholder{
  position:relative;overflow:hidden;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:
    linear-gradient(135deg,var(--blue-soft) 0%, #ffffff 60%),
    var(--bg-soft);
  min-height:180px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:8px;padding:16px;
  box-shadow:var(--shadow-card);
}
/* subtle slanted brand stripes echoing the logo tiles */
.img-placeholder::before{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(110deg,
      rgba(125,178,224,.16) 0 22px,
      rgba(255,255,255,0) 22px 70px),
    repeating-linear-gradient(110deg,
      rgba(242,212,102,.16) 35px 57px,
      rgba(255,255,255,0) 57px 105px);
  opacity:.9;
}
.img-placeholder .ph-ico{
  position:relative;z-index:1;
  width:46px;height:46px;border-radius:12px;
  background:#fff;border:1px solid var(--blue);
  display:flex;align-items:center;justify-content:center;
  color:var(--blue-deep);box-shadow:var(--shadow-card);
}
.img-placeholder .ph-label{
  position:relative;z-index:1;
  font-size:.82rem;font-weight:700;color:var(--blue-ink);
  background:rgba(255,255,255,.85);padding:4px 10px;border-radius:999px;
}
.img-placeholder .ph-tag{
  position:absolute;top:10px;left:10px;z-index:1;
  font-size:.66rem;font-weight:800;letter-spacing:.5px;text-transform:uppercase;
  color:var(--blue-deep);background:#fff;border:1px solid var(--blue);
  padding:3px 9px;border-radius:999px;
}
.img-placeholder.tag-after .ph-tag{color:#3a2f00;background:var(--yellow);border-color:var(--yellow-deep);}

/* hero photo placeholder a touch taller */
.hero-photo .img-placeholder{min-height:200px;}

/* real hero photo - inherits the premium framed look */
.hero-photo img{
  width:100%;height:auto;display:block;
  border-radius:var(--radius);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  aspect-ratio:1024/559;object-fit:cover;
}

/* real service-card photo: same corners/border/shadow as placeholders */
.card-img{
  width:100%;height:auto;
  aspect-ratio:4/3;object-fit:cover;
  border-radius:var(--radius);
  border:1px solid var(--line);
  box-shadow:var(--shadow-card);
  margin-bottom:12px;
}

/* ============ SERVICES ============ */
.service-grid{display:grid;grid-template-columns:1fr;gap:16px;}
.service-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow-card);transition:box-shadow .15s ease,transform .15s ease;
}
.service-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.service-card .img-placeholder{min-height:140px;margin-bottom:12px;}
.service-card p{margin:4px 0 6px;color:#3a4753;}

/* ============ PROBLEMS ============ */
.problem-group-title{
  font-size:.82rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.6px;
  color:var(--blue-deep);
  margin:0 0 12px;
  display:flex;
  align-items:center;
  gap:10px;
}
.problem-group-title::before{
  content:"";
  width:20px;height:3px;
  background:var(--yellow);
  border-radius:2px;
  flex:0 0 auto;
}
.problem-group-title + .problem-list{margin-bottom:22px;}
.problem-list + .problem-group-title{margin-top:6px;}

.problem-list{
  list-style:none;padding:0;margin:0 0 18px;
  display:grid;grid-template-columns:1fr;gap:10px;
}
.problem-list li{
  background:#fff;padding:13px 15px;border-radius:11px;
  border:1px solid var(--line);border-left:4px solid var(--blue);
  font-weight:600;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-card);
}
.problem-list li svg{flex:0 0 auto;color:var(--blue-deep);}

/* ============ RECENT WORK GALLERY ============ */
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.gallery-grid .img-placeholder{aspect-ratio:3/4;min-height:0;}
.job-photo{
  margin:0;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-card);background:#fff;
}
.job-photo img{
  width:100%;height:100%;display:block;
  aspect-ratio:3/4;object-fit:cover;object-position:center top;
}
/* roller detail: white product shot, shown full (not cropped) with a caption */
.job-photo.roller-detail{
  display:flex;flex-direction:column;background:#fff;
}
.job-photo.roller-detail img{
  aspect-ratio:auto;object-fit:contain;background:#fff;padding:10px 10px 4px;
}
.job-photo.roller-detail figcaption{
  font-size:.78rem;font-weight:700;color:var(--blue-ink);
  text-align:center;padding:4px 8px 10px;
}

/* ============ WHY US ============ */
.why-list{list-style:none;padding:0;margin:0;display:grid;gap:12px;}
.why-list li{
  padding:14px 16px;background:#fff;border-radius:11px;
  border:1px solid var(--line);border-left:4px solid var(--yellow-deep);
  box-shadow:var(--shadow-card);
}
.why-list strong{color:var(--blue-ink);display:block;margin-bottom:2px;}

/* =========================================================
   REVIEWS — Premium editorial style
   Warm ivory section, muted-gold stars, serif quotes,
   divider + circular initial badge + Google source label.
   Used on the homepage (with an optional dark featured card)
   and as a lighter reusable block on service pages.
   ========================================================= */

/* Gold accents kept local to the reviews section so the rest
   of the site keeps its blue/yellow identity. */
:root{
  --gold:#C8A33A;          /* muted gold for stars / accents */
  --gold-soft:#E6D9B0;     /* gold hairline borders          */
  --ivory:#FBF8F1;         /* warm off-white section bg       */
  --ivory-deep:#F6F1E6;    /* slightly deeper ivory           */
  --card-line:#ECE3CF;     /* warm card border / divider      */
}

/* ---- Section shell ---- */
.reviews-editorial{
  background:
    radial-gradient(130% 80% at 50% -25%, #FFFDF7 0%, rgba(255,253,247,0) 60%),
    linear-gradient(180deg, var(--ivory) 0%, var(--ivory-deep) 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:48px 0;
}
.reviews-editorial h2{color:var(--blue-ink);}
.reviews-editorial .accent-line{background:var(--gold);}

/* Upper label / eyebrow */
.reviews-editorial .eyebrow{
  display:inline-block;
  font-size:.74rem;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;
  color:#9a7b1f;background:#fff;border:1px solid var(--gold-soft);
  padding:6px 13px;border-radius:999px;margin-bottom:14px;box-shadow:var(--shadow-card);
}

/* ---- Rating summary line ---- */
.rating-summary{
  display:flex;align-items:center;flex-wrap:wrap;gap:4px 12px;margin:0 0 26px;
}
.rating-summary .stars{font-size:1.18rem;letter-spacing:3px;margin:0;color:var(--gold);}
.rating-summary .rating-score{font-weight:800;color:var(--blue-ink);font-size:1.12rem;}
.rating-summary .rating-label{color:var(--muted);font-size:.92rem;}

/* ---- Grid ---- */
.review-grid{display:grid;gap:16px;}

/* ---- Light card (default) ---- */
.review-card{
  background:#fff;padding:26px 24px;border-radius:20px;
  border:1px solid var(--card-line);box-shadow:0 6px 24px rgba(27,58,87,.06);
  display:flex;flex-direction:column;position:relative;
}
.review-card .stars{
  color:var(--gold);font-size:1.02rem;letter-spacing:3px;margin:0 0 16px;
}
.review-card .review-text{
  margin:0 0 22px;color:#33414e;
  font-family:Georgia,"Times New Roman",serif;
  font-size:1.13rem;line-height:1.62;font-style:normal;quotes:none;
}
.review-card .review-text::before,
.review-card .review-text::after{content:none;}

/* identity row — thin divider above */
.review-meta{
  display:flex;align-items:center;gap:13px;
  margin-top:auto;padding-top:18px;border-top:1px solid var(--card-line);
}
.review-badge{
  flex:0 0 auto;width:46px;height:46px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--blue-soft);color:var(--blue-deep);
  font-weight:800;font-size:1.08rem;border:1px solid var(--blue);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
.review-id{display:flex;flex-direction:column;line-height:1.3;}
.review-author{margin:0;font-weight:800;color:var(--blue-ink);font-size:.98rem;}
.review-source{
  margin:0;font-size:.78rem;font-weight:600;color:var(--muted);
  display:inline-flex;align-items:center;gap:6px;
}
.review-source::before{
  content:"";width:14px;height:14px;flex:0 0 auto;
  background-repeat:no-repeat;background-position:center;background-size:contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath fill='%234285F4' d='M45.12 24.5c0-1.56-.14-3.06-.4-4.5H24v8.51h11.84c-.51 2.75-2.06 5.08-4.39 6.64v5.52h7.11c4.16-3.83 6.56-9.47 6.56-16.17z'/%3E%3Cpath fill='%2334A853' d='M24 46c5.94 0 10.92-1.97 14.56-5.33l-7.11-5.52c-1.97 1.32-4.49 2.1-7.45 2.1-5.73 0-10.58-3.87-12.31-9.07H4.34v5.7C7.96 41.07 15.4 46 24 46z'/%3E%3Cpath fill='%23FBBC05' d='M11.69 28.18C11.25 26.86 11 25.45 11 24s.25-2.86.69-4.18v-5.7H4.34C2.85 17.09 2 20.45 2 24s.85 6.91 2.34 9.88l7.35-5.7z'/%3E%3Cpath fill='%23EA4335' d='M24 10.75c3.23 0 6.13 1.11 8.41 3.29l6.31-6.31C34.91 4.18 29.93 2 24 2 15.4 2 7.96 6.93 4.34 14.12l7.35 5.7c1.73-5.2 6.58-9.07 12.31-9.07z'/%3E%3C/svg%3E");
}

/* ---- Optional dark featured card (homepage) ---- */
.review-card.featured{
  background:linear-gradient(155deg,#1B3A57 0%, #15314A 100%);
  border-color:#15314A;box-shadow:0 14px 36px rgba(27,58,87,.24);
}
.review-card.featured .review-text{color:#F3F7FB;font-size:1.22rem;}
.review-card.featured .stars{color:var(--yellow);}
.review-card.featured .review-meta{border-top-color:rgba(255,255,255,.16);}
.review-card.featured .review-author{color:#fff;}
.review-card.featured .review-source{color:#AFC4D8;}
.review-card.featured .review-badge{
  background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3);color:#fff;
}
/* subtle serif quote glyph on the featured card */
.review-card.featured::before{
  content:"\201C";position:absolute;top:6px;right:22px;
  font-family:Georgia,serif;font-size:4.2rem;line-height:1;
  color:rgba(255,255,255,.12);pointer-events:none;
}

/* ---- CTA row under reviews ---- */
.reviews-cta{margin-top:28px;}

/* keep a harmless generic .stars fallback for any other use */
.stars{letter-spacing:2px;}

/* ---- Reviews responsive ---- */
@media (min-width:600px){
  .review-card.featured{grid-column:1 / -1;}
}

/* ============ AREAS ============ */
.area-list{list-style:none;padding:0;margin:14px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.area-list li{
  background:#fff;padding:11px 12px;border-radius:9px;font-weight:600;text-align:center;
  border:1px solid var(--line);color:var(--blue-ink);
}

/* ============ FAQ ============ */
.faq details{
  background:#fff;border:1px solid var(--line);border-radius:11px;
  margin-bottom:11px;overflow:hidden;box-shadow:var(--shadow-card);
}
.faq summary{
  cursor:pointer;padding:15px 46px 15px 16px;font-weight:700;color:var(--blue-ink);
  list-style:none;position:relative;
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{
  content:"+";position:absolute;right:14px;top:50%;transform:translateY(-50%);
  width:26px;height:26px;border-radius:50%;background:var(--blue-soft);
  color:var(--blue-deep);font-size:1.2rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.faq details[open] summary::after{content:"\2212";background:var(--yellow);color:#3a2f00;}
.faq details p{padding:0 16px 15px;margin:0;color:#3a4753;}

/* ============ FINAL CTA ============ */
.final-cta{
  background:linear-gradient(180deg,var(--blue-soft) 0%, #fff 100%);
  border-top:1px solid var(--line);text-align:center;
}
.final-cta h2{color:var(--blue-ink);}
.final-cta p{color:#3a4753;margin-bottom:18px;}

/* ============ FOOTER ============ */
.site-footer{background:#fff;border-top:1px solid var(--line);color:var(--ink);padding:28px 0;font-size:.95rem;}
.site-footer .container{text-align:center;}
.site-footer .footer-logo{height:40px;width:auto;margin:0 auto 12px;}
.site-footer p{margin:4px 0;color:var(--muted);}
.site-footer a{color:var(--blue-deep);font-weight:700;}
.site-footer .biz-name{font-size:1.08rem;color:var(--blue-ink);margin-bottom:6px;font-weight:800;}
.site-footer .hours-title{margin-top:16px;color:var(--blue-ink);}
.footer-nav{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px 16px;
  margin:18px 0 14px;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.footer-nav a{color:var(--blue-deep);font-size:.9rem;font-weight:600;}
.copyright{font-size:.82rem;color:#9aa6b1;margin-top:12px;}

/* ============ STICKY MOBILE CTA ============ */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:100;display:flex;
  background:#fff;box-shadow:0 -4px 16px rgba(27,58,87,.12);border-top:1px solid var(--line);
  padding:8px;gap:8px;
}
.sticky-btn{
  flex:1;text-align:center;border-radius:11px;
  font-weight:800;font-size:1rem;min-height:54px;
  display:flex;align-items:center;justify-content:center;gap:7px;
}
.sticky-call{background:var(--blue-deep);color:#fff;}
.sticky-call:hover{text-decoration:none;background:#255b8a;}
.sticky-estimate{background:var(--yellow);color:#3a2f00;border:1px solid var(--yellow-deep);}
.sticky-estimate:hover{text-decoration:none;background:#f6dc7f;}

/* ============ CONTACT FORM ============ */
.contact-form{background:#fff;padding:20px;border-radius:var(--radius);border:1px solid var(--line);margin-top:14px;box-shadow:var(--shadow-card);}
.contact-form label{display:block;font-weight:700;margin:12px 0 6px;color:var(--blue-ink);}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:14px;font-size:1rem;border:1px solid #CDD8E2;border-radius:10px;background:#fff;min-height:48px;font-family:inherit;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(125,178,224,.3);
}
.contact-form button{width:100%;margin-top:18px;background:var(--yellow);color:#3a2f00;border:1px solid var(--yellow-deep);padding:16px;font-size:1.1rem;font-weight:800;border-radius:12px;cursor:pointer;min-height:56px;}
.contact-form button:hover{background:#f6dc7f;}
.privacy-note{font-size:.85rem;color:var(--muted);margin-top:12px;text-align:center;}

/* ============ RESPONSIVE ============ */
@media (min-width:600px){
  h1{font-size:2.05rem;}
  h2{font-size:1.7rem;}
  .cta-row{flex-direction:row;}
  .cta-row .btn{flex:1;}
  .service-grid{grid-template-columns:1fr 1fr;}
  .problem-list{grid-template-columns:1fr 1fr;}
  .review-grid{grid-template-columns:1fr 1fr;}
  .area-list{grid-template-columns:repeat(3,1fr);}
  .btn-small{width:auto;}
}
@media (min-width:900px){
  body{padding-bottom:0;}
  .sticky-cta{display:none;}
  h1{font-size:2.3rem;}
  .service-grid{grid-template-columns:repeat(3,1fr);}
  .review-grid{grid-template-columns:repeat(3,1fr);}
}

/* ACCESSIBILITY */
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}
:focus-visible{outline:3px solid var(--blue-deep);outline-offset:2px;}

/* ============ VIDEO GALLERY ============ */
.video-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.video-card{
  margin:0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-card);
}
.video-card video{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio:16/9;
  object-fit:cover;
  background:#000;
}
.video-caption{
  margin:0;
  padding:10px 14px 12px;
  font-size:.9rem;
  font-weight:700;
  color:var(--blue-ink);
  text-align:center;
}

@media (min-width:600px){
  .video-grid{grid-template-columns:1fr 1fr;}
}
