/* =========================================================================
   DAL Autoservice — section components
   ========================================================================= */

/* ===== HERO ===== */
.hero{
  position:relative;
  min-height:clamp(620px,78vh,820px);
  padding:clamp(92px,12vw,150px) 0 clamp(70px,9vw,120px);
  overflow:hidden;
  isolation:isolate;
  display:grid;
  align-items:center;
  background:#111827;
}
.hero-bg-img{
  position:absolute;
  inset:0;
  z-index:-3;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
.hero-bg-overlay{
  position:absolute;
  inset:0;
  z-index:-2;
  background:
    linear-gradient(90deg,rgba(8,12,20,.92) 0%,rgba(8,12,20,.7) 44%,rgba(8,12,20,.24) 100%),
    linear-gradient(0deg,rgba(8,12,20,.78) 0%,rgba(8,12,20,.08) 46%);
}
.hero-grid-bg{
  position:absolute; inset:0; z-index:-2;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 70% 30%,#000 0%,transparent 75%);
  mask-image:radial-gradient(ellipse 80% 70% at 70% 30%,#000 0%,transparent 75%);
}
.hero .glow-a{ width:620px; height:620px; background:radial-gradient(circle,var(--glow),transparent 65%); top:-180px; right:-120px; opacity:.7 }
.hero .glow-b{ width:480px; height:480px; background:radial-gradient(circle,rgba(227,31,43,.16),transparent 65%); bottom:-160px; left:-100px }

.hero-in{ display:block }
.hero-copy{ position:relative; z-index:2; min-width:0; max-width:760px }
.hero h1{ margin:24px 0 26px }
.hero h1,
.hero .lead{ color:#fff; text-shadow:0 18px 50px rgba(0,0,0,.45) }
.hero .lead{ color:rgba(255,255,255,.86); max-width:58ch }
.hero .eyebrow{ color:#fff }
.hero .eyebrow::before{ background:linear-gradient(90deg,transparent,#fff) }
.hero h1 em{ font-style:normal; position:relative; color:var(--blue-br) }
.hero h1 .stroke{ -webkit-text-stroke:1.4px rgba(255,255,255,.72); color:transparent }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:36px }
.hero .btn-ghost{ color:#fff; border-color:rgba(255,255,255,.36); background:rgba(255,255,255,.08) }
.hero .btn-ghost:hover{ border-color:rgba(255,255,255,.66); background:rgba(255,255,255,.16) }
.hero-meta{ display:flex; gap:30px; margin-top:48px; padding-top:30px; border-top:1px solid rgba(255,255,255,.22) }
.hero-meta .num{ font-family:var(--display); font-weight:700; font-size:1.9rem; letter-spacing:0 }
.hero-meta .lbl{ font-size:13px; color:rgba(255,255,255,.68); margin-top:2px }

/* hero visual */
.hero-visual{ position:relative; z-index:1; min-width:0 }
.hero-frame{
  position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line);
  box-shadow:0 40px 90px -45px rgba(15,23,42,.22), 0 0 0 1px var(--line-2);
  aspect-ratio:4/5;
}
.hero-frame image-slot,
.hero-frame img{ width:100%; height:100%; object-fit:cover }
.hero-tag{
  position:absolute; left:18px; bottom:18px; z-index:3;
  display:flex; align-items:center; gap:12px; padding:13px 18px;
  background:rgba(8,9,12,.62); backdrop-filter:blur(14px); border:1px solid var(--line);
  border-radius:14px;
}
.hero-tag .ring{ width:34px; height:34px; border-radius:50%; display:grid; place-items:center; background:var(--blue); flex:none }
.hero-tag .ring svg{ width:18px; height:18px }
.hero-tag b{ font-family:var(--display); display:block; font-size:.95rem }
.hero-tag span{ font-size:12px; color:var(--ink-dim) }
.hero-badge{
  position:absolute; right:-14px; top:34px; z-index:3;
  background:var(--bg-2); border:1px solid var(--line); border-radius:16px; padding:16px 20px;
  box-shadow:0 24px 50px -22px rgba(15,23,42,.2); text-align:center;
  animation:float 5s var(--ease) infinite;
}
.hero-badge .big{ font-family:var(--display); font-weight:800; font-size:2.1rem; letter-spacing:0; color:var(--blue-br); line-height:1 }
.hero-badge .sm{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); margin-top:6px }
@keyframes float{ 50%{ transform:translateY(-12px) } }

.image-hero-section{
  position:relative;
  min-height:clamp(560px,82vh,820px);
  display:grid;
  align-items:center;
  overflow:hidden;
  isolation:isolate;
  background:#111827;
}
.image-hero-section.main-hero{ min-height:clamp(640px,88vh,900px) }
.image-hero-section > img{
  position:absolute;
  inset:0;
  z-index:-2;
  width:100%;
  height:100%;
  object-fit:cover;
}
.image-hero-overlay{
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    linear-gradient(90deg,rgba(8,12,20,.88) 0%,rgba(8,12,20,.64) 42%,rgba(8,12,20,.16) 100%),
    linear-gradient(0deg,rgba(8,12,20,.76) 0%,rgba(8,12,20,.04) 45%);
}
.image-hero-content{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,360px);
  align-items:center;
  gap:clamp(28px,5vw,72px);
  padding-top:clamp(90px,12vw,160px);
  padding-bottom:clamp(70px,10vw,130px);
}
.image-hero-content .eyebrow{ color:#fff }
.image-hero-content .eyebrow::before{ background:linear-gradient(90deg,transparent,#fff) }
.hero-copy-block{ min-width:0; max-width:760px }
.hero-kicker{ display:flex; align-items:center; gap:16px; flex-wrap:wrap }
.hero-status{
  display:inline-flex; align-items:center; min-height:30px; padding:6px 12px; border-radius:100px;
  border:1px solid rgba(255,255,255,.24); color:rgba(255,255,255,.82); background:rgba(255,255,255,.08);
  font-size:.82rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; backdrop-filter:blur(10px);
}
.image-hero-content h1,
.image-hero-content h2{
  max-width:14ch;
  margin:22px 0 20px;
  color:#fff;
  text-shadow:0 18px 50px rgba(0,0,0,.45);
}
.image-hero-content .hero-title{ font-size:clamp(2.45rem,4.7vw,4.7rem); line-height:.98 }
.hero-title-mark{ color:var(--blue) }
.image-hero-content .crumb{ color:rgba(255,255,255,.72); margin-bottom:24px }
.image-hero-content .crumb a:hover{ color:#fff }
.image-hero-content .lead{
  color:rgba(255,255,255,.82);
  max-width:54ch;
  font-size:clamp(1rem,1.5vw,1.2rem);
}
.hero-service-pills{ display:flex; flex-wrap:wrap; gap:10px; margin-top:24px }
.hero-service-pills a{
  display:inline-flex; align-items:center; gap:9px;
  padding:9px 13px; border-radius:100px; color:#fff; background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22); font-size:.9rem; font-weight:800; backdrop-filter:blur(10px);
}
.hero-service-pills svg{ width:17px; height:17px; flex:none; color:var(--blue) }
.hero-service-pills svg path{ fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round }
.hero-service-pills a:hover{ background:rgba(227,31,43,.75); border-color:rgba(227,31,43,.9) }
.hero-service-pills a:hover svg{ color:#fff }
.image-hero-content .btn-ghost{
  color:#fff;
  border-color:rgba(255,255,255,.38);
  background:rgba(255,255,255,.08);
}
.image-hero-content .btn-ghost:hover{
  border-color:rgba(255,255,255,.66);
  background:rgba(255,255,255,.16);
}
.hero-review-proof{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
  margin-top:30px;
  color:#fff;
}
.hero-review-avatars{
  display:flex;
  align-items:center;
  min-width:max-content;
}
.hero-review-avatars span{
  width:38px;
  height:38px;
  margin-left:-9px;
  display:grid;
  place-items:center;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.72);
  background:linear-gradient(135deg,rgba(227,31,43,.95),rgba(255,90,97,.92));
  color:#fff;
  font-size:.72rem;
  font-weight:900;
  letter-spacing:0;
  box-shadow:0 14px 30px -18px rgba(0,0,0,.85);
}
.hero-review-avatars span:first-child{ margin-left:0 }
.hero-review-avatars span:nth-child(2){ background:linear-gradient(135deg,#475bc8,#7785e8) }
.hero-review-avatars span:nth-child(3){ background:linear-gradient(135deg,#172033,#3d495c) }
.hero-review-avatars span:last-child{ background:rgba(255,255,255,.12); color:#fff }
.hero-review-avatars span.has-image{
  overflow:hidden;
  background:#fff;
}
.hero-review-avatars span.has-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero-review-rating{ display:grid; gap:3px; font-weight:650; color:rgba(255,255,255,.86); line-height:1.25 }
.hero-review-stars{ color:var(--blue); font-size:1.28rem; letter-spacing:.08em; line-height:1 }
.hero-review-rating b{ color:#fff }
.hero-info-panel{
  position:relative; z-index:2; padding:24px; border-radius:20px;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22);
  color:#fff; backdrop-filter:blur(18px) saturate(140%);
  box-shadow:0 28px 70px -38px rgba(0,0,0,.65);
}
.hero-info-panel .panel-label{
  display:inline-flex; align-items:center; gap:8px; color:var(--blue); background:transparent; border-radius:0;
  padding:0; font-size:.75rem; font-weight:900; letter-spacing:.1em; text-transform:uppercase;
}
.hero-info-panel .panel-label svg{ width:15px; height:15px; flex:none }
.hero-info-panel .panel-label svg path{ fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round }
.hero-info-panel h2{ max-width:none; margin:16px 0 16px; font-size:1.45rem; line-height:1.12 }
.hero-info-panel ul{ display:grid; gap:10px; margin:0 0 20px; padding:0; list-style:none }
.hero-info-panel li{ display:flex; align-items:center; gap:10px; color:rgba(255,255,255,.84); font-weight:650 }
.hero-info-panel li::before{ content:none }
.hero-info-panel li svg{
  width:20px;
  height:20px;
  padding:4px;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  flex:none;
}
.hero-info-panel li svg path{ fill:none; stroke:currentColor; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round }
.hero-proof-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:20px }
.hero-proof-grid div{ padding:14px; border-radius:14px; background:rgba(8,12,20,.36); border:1px solid rgba(255,255,255,.12) }
.hero-proof-grid b{ display:block; font-family:var(--display); font-size:1.55rem; line-height:1; color:#fff }
.hero-proof-grid span{ display:block; margin-top:5px; color:rgba(255,255,255,.64); font-size:.78rem; line-height:1.25 }
.hero-info-panel .btn{ width:100%; justify-content:center }
.hero-panel-note{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin:16px 0 0;
  color:rgba(255,255,255,.68);
  font-weight:650;
  font-size:.85rem;
}
.hero-panel-note svg{ width:17px; height:17px; flex:none }
.hero-panel-note svg path{ fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round }

/* ===== SERVICES ===== */
.svc-grid{
  counter-reset:svc;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  align-items:stretch;
}
.svc-card{
  counter-increment:svc;
  position:relative; min-height:clamp(320px,31vw,380px); padding:0; border:0; border-radius:20px;
  background:#0b111d; color:#fff; overflow:hidden; isolation:isolate;
  box-shadow:0 22px 60px -44px rgba(15,23,42,.55);
  transition:transform .5s var(--ease), box-shadow .5s;
  display:flex; flex-direction:column;
}
.svc-card::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(180deg,rgba(8,12,20,.12) 0%,rgba(8,12,20,.38) 45%,rgba(8,12,20,.88) 100%),
    linear-gradient(90deg,rgba(8,12,20,.36) 0%,rgba(8,12,20,.06) 58%);
  transition:opacity .5s;
}
.svc-card:hover{ transform:translateY(-6px); box-shadow:0 34px 80px -44px rgba(15,23,42,.7) }
.svc-card:hover::before{ opacity:.92 }
.svc-media{
  position:absolute; inset:0; z-index:0; width:100%; height:100%;
  overflow:hidden; border:0; background:#111827; margin:0;
}
.svc-media img{ width:100%; height:100%; object-fit:cover; transition:transform .65s var(--ease), filter .65s var(--ease) }
.svc-card:hover .svc-media img{ transform:scale(1.06); filter:saturate(1.04) contrast(1.04) }
.svc-copy{
  position:absolute;
  left:28px;
  right:28px;
  bottom:28px;
  z-index:2;
}
.svc-card h3{
  margin:0 0 9px;
  max-width:100%;
  color:#fff;
  font-family:var(--display);
  font-size:var(--fs-h3);
  font-weight:800;
  line-height:1.22;
  overflow-wrap:normal;
  word-break:normal;
  hyphens:auto;
  text-shadow:0 16px 34px rgba(0,0,0,.52);
}
.svc-card p{
  margin:0;
  max-width:100%;
  color:rgba(255,255,255,.78);
  font-size:clamp(.9rem,1vw,.98rem);
  line-height:1.58;
  text-shadow:0 12px 26px rgba(0,0,0,.55);
}
.svc-card > h3{
  position:relative;
  z-index:2;
  margin:auto 28px 9px;
  max-width:calc(100% - 56px);
}
.svc-card > p{
  position:relative;
  z-index:2;
  margin:0 28px 28px;
  max-width:calc(100% - 56px);
}
.svc-arrow{ margin-top:20px; display:inline-flex; align-items:center; gap:8px; color:var(--blue-br); font-weight:700; font-size:.9rem; position:relative; z-index:1; opacity:.6; transition:opacity .4s, gap .4s }
.svc-card:hover .svc-arrow{ opacity:1; gap:13px }
.svc-arrow svg{ width:16px; height:16px }
.svc-card.wide{ grid-column:span 1 }
.svc-card.feature{
  grid-column:span 1; background:#0b111d;
  border:0;
}
.svc-card:nth-child(n){ grid-column:auto; grid-row:auto }

/* ===== WHY / split ===== */
.why-in{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center }
.why-list{ display:flex; flex-direction:column; gap:14px; margin-top:36px }
.why-item{
  display:flex; gap:18px; padding:22px; border:1px solid var(--line); border-radius:var(--r);
  background:var(--panel); transition:all .4s var(--ease);
}
.why-item:hover{ border-color:rgba(227,31,43,.45); transform:translateX(6px); background:var(--glow-soft) }
.why-item .ic{ width:46px; height:46px; flex:none; border-radius:12px; background:var(--bg-3); display:grid; place-items:center; color:var(--blue-br); border:1px solid var(--line) }
.why-item .ic svg{ width:24px; height:24px }
.why-item h3{ font-size:var(--fs-h3); margin-bottom:5px }
.why-item p{ color:var(--ink-dim); font-size:.93rem }
.why-visual{
  position:relative;
  align-self:center;
  max-height:480px;
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--line);
  aspect-ratio:16/10;
  box-shadow:0 40px 90px -48px rgba(15,23,42,.2)
}
.why-visual image-slot,
.why-visual img{ width:100%; height:100%; object-fit:cover }

/* ===== STATS ===== */
.stats{ background:var(--bg-1); border-block:1px solid var(--line-2); position:relative; overflow:hidden; padding:clamp(58px,7vw,96px) 0 }
.stats .sec-head{ margin-bottom:clamp(34px,4vw,54px) }
.stats-grid{ display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:0; position:relative; z-index:1; width:100% }
.stat{ text-align:center; padding:18px clamp(12px,2vw,24px); min-width:0 }
.stat .val{ font-family:var(--display); font-weight:800; font-size:clamp(2.65rem,5vw,4rem); letter-spacing:0; line-height:1; color:var(--blue-2); background:none; -webkit-text-fill-color:currentColor }
.stat .lbl{ margin-top:14px; font-size:14px; color:var(--ink-dim); letter-spacing:.02em }
.stat + .stat{ border-left:1px solid var(--line-2) }

/* ===== BEFORE / AFTER ===== */
.ba-wrap{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center }
.ba{
  position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line);
  aspect-ratio:3/2; user-select:none; box-shadow:0 40px 90px -48px rgba(15,23,42,.2); cursor:ew-resize;
}
.ba-layer{ position:absolute; inset:0 }
.ba-layer image-slot,
.ba-layer img{ width:100%; height:100%; object-fit:cover }
.ba-after{ clip-path:inset(0 0 0 var(--split,50%)) }
.ba-before{ clip-path:inset(0 calc(100% - var(--split,50%)) 0 0) }
.ba-tag{ position:absolute; top:16px; padding:7px 14px; border-radius:100px; font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; background:rgba(8,9,12,.7); backdrop-filter:blur(8px); border:1px solid var(--line); z-index:4 }
.ba-tag.l{ left:16px }
.ba-tag.r{ right:16px; color:var(--blue-br) }
.ba-handle{ position:absolute; top:0; bottom:0; left:var(--split,50%); width:2px; background:#fff; z-index:5; transform:translateX(-1px) }
.ba-handle::before{
  content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:48px; height:48px; border-radius:50%; background:var(--blue); border:3px solid #fff;
  box-shadow:0 8px 24px -4px var(--glow); display:grid; place-items:center;
}
.ba-handle::after{
  content:"⟷"; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); color:#fff; font-size:18px; z-index:1;
}

/* ===== PROCESS TIMELINE ===== */
.proc{ position:relative }
.proc-line{ position:absolute; left:50%; top:0; bottom:0; width:1px; background:var(--line); transform:translateX(-.5px) }
.proc-line .fill{ position:absolute; top:0; left:0; right:0; height:var(--p,0%); background:linear-gradient(180deg,var(--blue),var(--cyan)); transition:height .2s linear }
.proc-steps{ display:flex; flex-direction:column; gap:8px }
.proc-step{ display:grid; grid-template-columns:1fr 88px 1fr; align-items:center; gap:0 }
.proc-card{
  padding:26px 28px; border:1px solid var(--line); border-radius:var(--r-lg); background:var(--bg-1);
  transition:all .5s var(--ease);
}
.proc-card:hover{ border-color:rgba(227,31,43,.45); transform:translateY(-4px) }
.proc-card h3{ font-size:var(--fs-h3); margin-bottom:8px }
.proc-card p{ color:var(--ink-dim); font-size:.94rem }
.proc-step:nth-child(odd) .proc-card{ grid-column:1 }
.proc-step:nth-child(odd) .proc-r{ grid-column:3 }
.proc-step:nth-child(even) .proc-card{ grid-column:3 }
.proc-node{ grid-column:2; display:grid; place-items:center; position:relative; z-index:2 }
.proc-dot{
  width:60px; height:60px; border-radius:50%; display:grid; place-items:center;
  background:var(--bg-2); border:1px solid var(--line); font-family:var(--display); font-weight:800; font-size:1.1rem;
  color:var(--blue-br); transition:all .5s var(--ease);
}
.proc-step.active .proc-dot{ background:var(--blue); color:#fff; border-color:var(--blue); box-shadow:0 0 0 6px var(--glow-soft), 0 12px 30px -8px var(--glow) }
@media (max-width:760px){
  .proc-line{ left:30px }
  .proc-step{ grid-template-columns:60px 1fr; gap:20px }
  .proc-step:nth-child(odd) .proc-card,.proc-step:nth-child(even) .proc-card{ grid-column:2 }
  .proc-node{ grid-column:1 }
  .proc-r{ display:none }
}

/* ===== GALLERY ===== */
.gal-grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:14px }
.gal-item{ position:relative; border-radius:var(--r); overflow:hidden; border:1px solid var(--line) }
.gal-item image-slot,
.gal-item img{ width:100%; height:100%; object-fit:cover; transition:transform .55s var(--ease) }
.gal-item:hover img{ transform:scale(1.04) }
.gal-item.tall{ grid-row:span 2 }
.gal-item.wide{ grid-column:span 2 }
.gal-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(8,9,12,.55)); opacity:0; transition:opacity .4s; pointer-events:none }
.gal-item:hover::after{ opacity:1 }
.gal-cap{ position:absolute; left:16px; bottom:14px; z-index:2; font-weight:700; font-size:.9rem; opacity:0; transform:translateY(8px); transition:all .4s var(--ease); pointer-events:none }
.gal-item:hover .gal-cap{ opacity:1; transform:none }

/* ===== TESTIMONIALS ===== */
.reviews-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:32px; margin-bottom:clamp(42px,5vw,64px) }
.reviews-head .sec-head{ margin-bottom:0 }
.google-rating-card{
  width:min(100%,360px);
  min-width:280px;
  display:flex;
  align-items:center;
  gap:16px;
  padding:20px 22px;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  background:var(--bg-1);
  box-shadow:0 24px 60px -42px rgba(15,23,42,.42);
  transition:transform .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.google-rating-card:hover{ transform:translateY(-5px); border-color:rgba(227,31,43,.38); box-shadow:0 30px 74px -46px rgba(227,31,43,.32) }
.google-rating-card b{ display:block; font-size:clamp(1.45rem,2.4vw,2rem); line-height:1; color:var(--ink) }
.google-rating-card small{ display:block; margin-top:6px; color:var(--ink-faint); font-weight:700 }
.google-mark{
  width:46px;
  height:46px;
  border-radius:50%;
  background:var(--bg-1);
  border:1px solid var(--line-2);
  display:grid;
  place-items:center;
  flex:none;
  box-shadow:0 14px 34px -22px rgba(15,23,42,.38);
}
.google-mark img{ width:29px; height:29px }
.google-mark.sm{ width:26px; height:26px; box-shadow:none }
.review-source .google-mark.sm{ width:22px; height:22px; border:0; background:transparent; box-shadow:none }
.google-mark.sm img{ width:17px; height:17px }
.review-source .google-mark.sm img{ width:20px; height:20px }
.tst-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px }
.tst-card{ padding:32px 30px; border:1px solid var(--line); border-radius:var(--r-lg); background:var(--bg-1); display:flex; flex-direction:column; transition:all .5s var(--ease) }
a.tst-card{ color:inherit; text-decoration:none; cursor:pointer }
.tst-card:hover{ transform:translateY(-6px); border-color:rgba(227,31,43,.4) }
a.tst-card:focus-visible{ outline:3px solid color-mix(in srgb,var(--blue) 70%,#fff); outline-offset:4px }
.tst-stars{ display:flex; gap:3px; color:var(--blue-br); margin-bottom:18px }
.tst-stars svg{ width:18px; height:18px; fill:currentColor }
.tst-card p{ font-size:1.02rem; color:var(--ink); flex:1; line-height:1.6 }
.google-review-card{ min-height:0 }
.google-reviews-grid.is-slider{
  display:block;
  overflow:hidden;
  margin-inline:calc((100vw - min(100vw, var(--wrap))) / -2);
  padding:6px calc((100vw - min(100vw, var(--wrap))) / 2) 10px;
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
}
.google-reviews-track{
  display:flex;
  width:max-content;
  gap:18px;
  animation:googleReviewsMarquee 46s linear infinite;
  animation-play-state:paused;
  will-change:transform;
}
.google-reviews-grid.is-in-view .google-reviews-track{ animation-play-state:running }
.google-reviews-grid.is-slider:hover .google-reviews-track,
.google-reviews-grid.is-slider:focus-within .google-reviews-track{ animation-play-state:paused }
.google-reviews-grid.is-slider .google-review-card{
  flex:0 0 clamp(292px,31vw,380px);
  width:clamp(292px,31vw,380px);
  min-height:260px;
}
@keyframes googleReviewsMarquee{
  from{ transform:translate3d(0,0,0) }
  to{ transform:translate3d(calc(-50% - 9px),0,0) }
}
.google-review-card.is-featured{
  --featured-pad:clamp(28px,5vw,56px);
  grid-column:1 / -1;
  display:flex;
  flex-direction:column;
  padding:var(--featured-pad);
  border-color:rgba(15,23,42,.08);
  border-radius:calc(var(--r-lg) + 2px);
  background:var(--bg-1);
  box-shadow:0 36px 90px -64px rgba(15,23,42,.32);
}
.featured-review-copy{ display:flex; flex-direction:column; justify-content:center; min-width:0; max-width:880px; padding-right:0 }
.featured-review-badge{
  display:none;
}
.featured-review-quote{
  margin:0;
  padding:0;
}
.featured-review-quote p{
  font-size:clamp(1.18rem,2vw,1.72rem);
  line-height:1.28;
  letter-spacing:0;
  color:var(--ink);
}
.featured-review-media{
  display:none;
}
.featured-review-media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.45) 10%,#000 26%);
  mask-image:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.45) 10%,#000 26%);
}
.featured-review-media::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:linear-gradient(90deg,rgba(12,16,26,0) 62%,rgba(12,16,26,.28) 100%);
}
.featured-review-media figcaption{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  z-index:2;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  padding:clamp(18px,3vw,28px);
  color:#fff;
  background:linear-gradient(180deg,rgba(12,16,26,0) 0%,rgba(12,16,26,.72) 58%,rgba(12,16,26,.88) 100%);
}
.featured-review-media figcaption span{ font-size:clamp(1.35rem,2.5vw,2.2rem); line-height:1; font-weight:800 }
.featured-review-media figcaption small{ color:#fff; font-size:clamp(.86rem,1.2vw,1rem); font-weight:800; white-space:nowrap }
.google-review-card p{
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  line-height:1.55;
  max-height:calc(1.55em * 3);
  overflow:hidden;
}
.google-review-card.is-featured .featured-review-quote p{
  -webkit-line-clamp:5;
  max-height:calc(1.28em * 5);
}
.tst-by{ display:flex; align-items:center; justify-content:flex-start; gap:16px; margin-top:24px; padding-top:20px; border-top:1px solid var(--line-2) }
.review-author{ display:flex; align-items:center; gap:13px; min-width:0 }
.tst-av{ width:46px; height:46px; border-radius:50%; background:linear-gradient(135deg,var(--blue),var(--cyan)); display:grid; place-items:center; font-family:var(--display); font-weight:700; color:#fff; flex:none; overflow:hidden }
.tst-av img{ width:100%; height:100%; object-fit:cover }
.tst-av.has-image{ background:#fff; border:1px solid var(--line-2) }
.tst-av.has-image span{ display:none }
.tst-by b{ font-size:.95rem }
.tst-by span{ font-size:12.5px; color:var(--ink-faint); display:block }
.review-user-meta{ display:block; margin-top:3px; color:var(--ink-faint); font-size:12px; font-weight:700; line-height:1.25 }
.tst-by .review-author-stars{ color:#f6b900; letter-spacing:.08em; font-size:14px; line-height:1.2; margin-top:3px }
.review-source{
  display:inline-flex;
  align-items:center;
  gap:9px;
  width:fit-content;
  margin-left:auto;
  color:var(--ink-dim);
  font-size:.88rem;
  font-weight:800;
  white-space:nowrap;
  flex:none;
  transition:color .25s, transform .25s;
}
.review-source:hover{ color:var(--blue-br); transform:translateX(4px) }
.reviews-cta{ display:flex; justify-content:center; margin-top:34px }

/* ===== TRUST BADGES ===== */
.trust{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px }
.trust-item{ text-align:center; padding:30px 22px; border:1px solid var(--line); border-radius:var(--r-lg); background:var(--bg-1); transition:all .5s var(--ease) }
.trust-item:hover{ border-color:rgba(227,31,43,.4); transform:translateY(-5px) }
.trust-item .ic{ width:50px; height:50px; margin:0 auto 16px; border-radius:14px; background:var(--bg-3); border:1px solid var(--line); display:grid; place-items:center; color:var(--blue-br) }
.trust-item .ic svg{ width:26px; height:26px }
.trust-item b{ font-family:var(--display); display:block; font-size:1.05rem; margin-bottom:5px }
.trust-item span{ font-size:13px; color:var(--ink-dim) }

/* ===== FAQ ===== */
.faq-wrap{ display:grid; grid-template-columns:.8fr 1.2fr; gap:54px; align-items:start }
.faq-list{ display:flex; flex-direction:column; gap:12px }
.faq-q{ border:1px solid var(--line); border-radius:var(--r); background:var(--bg-1); overflow:hidden; transition:border-color .4s }
.faq-q.open{ border-color:rgba(227,31,43,.45) }
.faq-head{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:18px; padding:22px 24px; text-align:left; font-family:var(--display); font-weight:600; font-size:1.08rem }
.faq-ic{ width:30px; height:30px; flex:none; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; transition:all .4s var(--ease); position:relative }
.faq-ic::before,.faq-ic::after{ content:""; position:absolute; background:var(--blue-br); border-radius:2px }
.faq-ic::before{ width:12px; height:2px }
.faq-ic::after{ width:2px; height:12px; transition:transform .4s var(--ease) }
.faq-q.open .faq-ic{ background:var(--blue); border-color:var(--blue) }
.faq-q.open .faq-ic::before,.faq-q.open .faq-ic::after{ background:#fff }
.faq-q.open .faq-ic::after{ transform:rotate(90deg); opacity:0 }
.faq-body{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease) }
.faq-body p{ padding:0 24px 24px; color:var(--ink-dim) }

/* ===== CONTACT / CTA ===== */
.cta-band{ position:relative; overflow:hidden; border-radius:28px; padding:clamp(48px,7vw,90px); background:linear-gradient(135deg,var(--bg-2),var(--bg-1)); border:1px solid var(--line); text-align:center }
.cta-band .glow-blob{ width:560px; height:560px; background:radial-gradient(circle,var(--glow),transparent 65%); top:-260px; left:50%; transform:translateX(-50%) }
.cta-band-grid{ position:absolute; inset:0; background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px); background-size:48px 48px; -webkit-mask-image:radial-gradient(ellipse 60% 80% at 50% 0,#000,transparent 70%); mask-image:radial-gradient(ellipse 60% 80% at 50% 0,#000,transparent 70%) }
.cta-inner{ position:relative; z-index:2 }
.cta-inner .btn{ margin-top:34px }

@media (max-width:980px){
  .hero-in,.why-in,.ba-wrap,.faq-wrap{ grid-template-columns:1fr; gap:42px }
  .why-visual{ width:min(100%,720px); max-height:420px; justify-self:center }
  .image-hero-content{ grid-template-columns:1fr; align-items:center }
  .hero-info-panel{ max-width:560px }
  .svc-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
  }
  .svc-card{ min-height:clamp(300px,42vw,360px) }
  .svc-card:nth-child(n){ grid-column:auto; grid-row:auto }
  .svc-card h3{ font-size:var(--fs-h3) }
  .reviews-head{ display:grid; gap:24px }
  .google-rating-card{ width:min(100%,360px); min-width:0 }
  .google-review-card.is-featured{ --featured-pad:24px; grid-column:1 / -1; padding:var(--featured-pad) }
  .featured-review-copy{ padding-right:0 }
  .tst-grid{ grid-template-columns:1fr 1fr }
  .stats-grid,.trust{ grid-template-columns:1fr 1fr }
  .stat:nth-child(3){ border-left:none }
  .gal-grid{ grid-template-columns:repeat(2,1fr) }
  .hero-badge{ display:none }
}
@media (max-width:620px){
  .svc-grid{
    grid-template-columns:1fr;
    gap:16px;
  }
  .svc-card,
  .svc-card:nth-child(1),
  .svc-card:nth-child(5),
  .svc-card:nth-child(6),
  .svc-card:nth-child(8),
  .svc-card:nth-child(9),
  .svc-card:nth-child(10){
    grid-column:span 1;
    grid-row:auto;
    min-height:330px;
  }
  .svc-copy{ left:24px; right:24px; bottom:26px }
  .svc-card h3{ margin:0 0 8px; font-size:var(--fs-h3); max-width:100% }
  .svc-card p{ margin:0; font-size:.96rem; max-width:100% }
  .svc-card > h3{ margin:auto 24px 8px; max-width:calc(100% - 48px) }
  .svc-card > p{ margin:0 24px 26px; max-width:calc(100% - 48px) }
  .tst-grid,.stats-grid,.trust{ grid-template-columns:1fr }
  .google-rating-card{ width:100% }
  .google-reviews-grid.is-slider{ margin-inline:-20px; padding-inline:20px }
  .google-reviews-grid.is-slider .google-review-card{
    flex-basis:min(82vw,340px);
    width:min(82vw,340px);
    min-height:270px;
  }
  .google-review-card.is-featured{ --featured-pad:22px; grid-column:1 / -1 }
  .featured-review-quote p{ font-size:clamp(1.1rem,6vw,1.42rem); line-height:1.28 }
  .image-hero-section.main-hero{ min-height:auto }
  .image-hero-section{ align-items:end }
  .image-hero-content{ padding-top:96px; padding-bottom:54px }
  .hero-kicker{ gap:10px }
  .hero-status{ font-size:.68rem; min-height:26px; padding:5px 9px }
  .image-hero-content .hero-title{ font-size:clamp(2.15rem,11vw,2.9rem); max-width:12ch }
  .hero-service-pills a{ font-size:.82rem; padding:8px 10px }
  .hero-info-panel{ display:none }
  .stat + .stat{ border-left:none; border-top:1px solid var(--line-2); padding-top:24px }
  .hero-meta{ flex-wrap:wrap; gap:20px }
  .hero-copy,
  .hero h1,
  .hero-actions,
  .hero-frame{ max-width:calc(100vw - 40px) }
  .hero .lead{ max-width:min(31ch, calc(100vw - 40px)); font-size:1rem }
  .hero-actions .btn{ flex:1 1 100%; justify-content:center }
  .image-hero-section{ min-height:680px; align-items:end }
  .image-hero-overlay{ background:linear-gradient(0deg,rgba(8,12,20,.86) 0%,rgba(8,12,20,.48) 62%,rgba(8,12,20,.18) 100%) }
  .image-hero-content h2{ max-width:11ch }
  .image-hero-content .lead{ max-width:31ch; font-size:1rem }
}
@media (prefers-reduced-motion:reduce){
  .google-reviews-grid.is-slider{
    overflow-x:auto;
    -webkit-mask-image:none;
    mask-image:none;
    scroll-snap-type:x mandatory;
  }
  .google-reviews-track{ animation:none }
  .google-reviews-grid.is-slider .google-review-card{ scroll-snap-align:start }
}
