/* ===========================================================
   ProFilm — premium dark automotive tint
   Design system: near-black canvas, white text, single amber accent
   =========================================================== */

:root{
  /* palette */
  --bg:        #020202;
  --bg-raised: #0b0b0d;
  --bg-card:   #101012;
  --bg-card-2: #16161a;
  --white:     #ffffff;
  --ink-80:    rgba(255,255,255,0.80);
  --ink-62:    rgba(255,255,255,0.62);
  --ink-44:    rgba(255,255,255,0.44);
  --ink-30:    rgba(255,255,255,0.30);
  --line:      rgba(255,255,255,0.09);
  --line-2:    rgba(255,255,255,0.14);
  --amber:     #FAA320;
  --amber-deep:#e8901a;
  --amber-ink: #1a1206; /* text on amber */

  /* type */
  --display: 'Archivo', system-ui, sans-serif;
  --body:    'Archivo', system-ui, sans-serif;

  /* metrics */
  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 56px);
  --r-sm: 10px;
  --r:    16px;
  --r-lg: 24px;
  --r-pill: 999px;
  --shadow: 0 24px 60px -20px rgba(0,0,0,0.8);
  --amber-glow: 0 10px 30px -8px rgba(250,163,32,0.45);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--white);
  font-family:var(--body);
  font-size:17px;
  line-height:1.55;
  font-weight:400;
  letter-spacing:0.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
::selection{ background:var(--amber); color:var(--amber-ink); }

/* ---------- layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(64px,9vw,128px); position:relative; }
.section--tight{ padding-block:clamp(48px,6vw,80px); }
.center{ text-align:center; }

/* eyebrow / kicker */
.kicker{
  display:inline-flex; align-items:center; gap:9px;
  font-size:12.5px; font-weight:700; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--amber); margin:0 0 18px;
}
.kicker::before{ content:""; width:22px; height:2px; background:var(--amber); border-radius:2px; }
.center .kicker{ justify-content:center; }

/* ---------- type scale ---------- */
h1,h2,h3,h4{ font-family:var(--display); margin:0; line-height:1.02; letter-spacing:-0.02em; font-weight:800; }
.h-display{
  font-size:clamp(38px, 6.6vw, 66px);
  font-weight:800; line-height:1.0; letter-spacing:-0.035em;
  text-wrap:balance; max-width:16ch;
}
.h-xl{ font-size:clamp(28px,4.4vw,52px); font-weight:800; line-height:1.06; letter-spacing:-0.028em; text-wrap:balance; max-width:18ch; }
.h-lg{ font-size:clamp(24px,3.2vw,38px); font-weight:800; line-height:1.1; letter-spacing:-0.025em; text-wrap:balance; max-width:20ch; }
.center .h-display, .center .h-xl, .center .h-lg{ margin-inline:auto; }
.h-md{ font-size:clamp(20px,2.2vw,26px); font-weight:700; letter-spacing:-0.02em; }
.lede{ font-size:clamp(17px,1.7vw,21px); color:var(--ink-62); line-height:1.55; font-weight:400; text-wrap:pretty; }
.amber{ color:var(--amber); }
.muted{ color:var(--ink-62); }
.nowrap{ white-space:nowrap; }

/* ===========================================================
   LOGO — CSS recreation of the ProFilm wordmark
   =========================================================== */
.logo{ display:inline-flex; align-items:center; font-family:var(--display); font-weight:800;
  letter-spacing:-0.03em; line-height:1; user-select:none; font-size:var(--logo-size,26px); }
.logo .pro{ color:var(--white); padding-right:0.12em; }
.logo .film{
  color:#0c0c0c; background:var(--amber);
  padding:0.16em 0.26em 0.2em; border-radius:0.34em;
  box-shadow:0 2px 0 rgba(0,0,0,0.25);
}

/* ===========================================================
   BUTTONS
   =========================================================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--display); font-weight:700; font-size:16px; letter-spacing:-0.01em;
  padding:15px 26px; border-radius:var(--r-pill); border:1px solid transparent;
  cursor:pointer; transition:transform .18s ease, box-shadow .25s ease, background .2s ease, border-color .2s ease, color .2s ease;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:18px; height:18px; flex:none; }
.btn--amber{ background:var(--amber); color:var(--amber-ink); box-shadow:var(--amber-glow); }
.btn--amber:hover{ background:#ffb43c; transform:translateY(-2px); box-shadow:0 16px 36px -8px rgba(250,163,32,0.6); }
.btn--ghost{ background:rgba(255,255,255,0.04); color:var(--white); border-color:var(--line-2); }
.btn--ghost:hover{ background:rgba(255,255,255,0.09); border-color:rgba(255,255,255,0.28); transform:translateY(-2px); }
.btn--solid-dark{ background:#fff; color:#0a0a0a; }
.btn--solid-dark:hover{ transform:translateY(-2px); box-shadow:0 16px 36px -10px rgba(255,255,255,0.25); }
.btn--lg{ padding:18px 32px; font-size:17px; }
.btn--block{ width:100%; }
.btn--sm{ padding:11px 18px; font-size:14.5px; }

/* link with arrow */
.tlink{ display:inline-flex; align-items:center; gap:8px; font-weight:700; color:var(--white); font-family:var(--display);
  letter-spacing:-0.01em; transition:gap .2s ease, color .2s ease; }
.tlink .arr{ color:var(--amber); transition:transform .2s ease; }
.tlink:hover{ color:var(--amber); }
.tlink:hover .arr{ transform:translateX(4px); }

/* ===========================================================
   HEADER / NAV
   =========================================================== */
.header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .3s ease, border-color .3s ease, backdrop-filter .3s ease;
  border-bottom:1px solid transparent;
}
.header.scrolled{ background:rgba(4,4,4,0.78); backdrop-filter:blur(14px) saturate(1.2); border-bottom-color:var(--line); }
.nav{ display:flex; align-items:center; justify-content:space-between; height:72px; }
.nav__links{ display:flex; align-items:center; gap:30px; }
.nav__links a{ font-size:15px; font-weight:600; color:var(--ink-62); transition:color .2s ease; white-space:nowrap; }
.nav__phone{ white-space:nowrap; }
.nav__links a:hover{ color:var(--white); }
.nav__cta{ display:flex; align-items:center; gap:14px; }
.nav__phone{ display:inline-flex; align-items:center; gap:8px; font-weight:700; font-family:var(--display); font-size:15px; }
.nav__phone svg{ width:16px; height:16px; color:var(--amber); }
.burger{ display:none; width:44px; height:44px; border-radius:12px; border:1px solid var(--line-2);
  background:rgba(255,255,255,0.04); align-items:center; justify-content:center; cursor:pointer; }
.burger span{ display:block; width:18px; height:2px; background:#fff; position:relative; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:18px; height:2px; background:#fff; transition:.25s; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }

/* mobile menu */
.mobnav{ position:fixed; inset:0; z-index:55; background:rgba(4,4,4,0.97); backdrop-filter:blur(8px);
  display:flex; flex-direction:column; padding:96px var(--gutter) 40px; gap:6px;
  transform:translateY(-100%); opacity:0; pointer-events:none; transition:.35s cubic-bezier(.22,.61,.36,1); }
.mobnav.open{ transform:none; opacity:1; pointer-events:auto; }
.mobnav a{ font-family:var(--display); font-weight:700; font-size:26px; padding:14px 0; border-bottom:1px solid var(--line); letter-spacing:-0.02em; }
.mobnav .btn{ margin-top:22px; }
.mobnav__close{ position:absolute; top:20px; right:var(--gutter); width:44px; height:44px; border-radius:12px;
  border:1px solid var(--line-2); background:transparent; color:#fff; font-size:22px; cursor:pointer; }

/* ===========================================================
   HERO
   =========================================================== */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; padding-bottom:clamp(40px,6vw,72px); }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__bg .ph{ width:100%; height:100%; border-radius:0; }
.hero__bg::after{ /* cinematic vignette + bottom fade for text legibility */
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(2,2,2,0.55) 0%, rgba(2,2,2,0.10) 30%, rgba(2,2,2,0.55) 64%, var(--bg) 99%),
    radial-gradient(120% 80% at 80% 20%, rgba(250,163,32,0.10), transparent 55%);
}
.hero__inner{ position:relative; z-index:2; width:100%; }
.hero__loc{ display:inline-flex; align-items:center; gap:8px; font-size:14px; font-weight:600; color:var(--ink-80);
  background:rgba(255,255,255,0.05); border:1px solid var(--line); padding:8px 14px; border-radius:var(--r-pill); margin-bottom:22px; }
.hero__loc svg{ width:15px; height:15px; color:var(--amber); }
.hero h1{ max-width:15ch; margin-bottom:22px; }
.hero h1 em{ font-style:normal; color:var(--amber); }
.hero__sub{ max-width:54ch; margin-bottom:34px; }
.hero__cta{ display:flex; flex-wrap:wrap; align-items:center; gap:14px; }
.hero__scroll{ position:absolute; left:50%; bottom:20px; transform:translateX(-50%); z-index:3;
  font-size:11px; letter-spacing:0.25em; text-transform:uppercase; color:var(--ink-44); display:flex; flex-direction:column; align-items:center; gap:8px; }
.hero__scroll .bar{ width:1px; height:34px; background:linear-gradient(var(--amber),transparent); animation:scrolldot 2.4s ease-in-out infinite; }
@keyframes scrolldot{ 0%,100%{ opacity:.3; transform:scaleY(.6); } 50%{ opacity:1; transform:scaleY(1); } }

/* ===========================================================
   TRUST BAR (marquee)
   =========================================================== */
.trust{ border-block:1px solid var(--line); background:linear-gradient(180deg,#070708,#040404); overflow:hidden; }
.trust__track{ display:flex; gap:0; align-items:center; white-space:nowrap; width:max-content; animation:marquee 34s linear infinite; }
.trust:hover .trust__track{ animation-play-state:paused; }
.trust__item{ display:inline-flex; align-items:center; gap:10px; padding:18px 30px; font-weight:600; font-size:15px; color:var(--ink-80); }
.trust__item .dot{ width:4px; height:4px; border-radius:50%; background:var(--ink-30); }
.trust__item .star{ color:var(--amber); }
.trust__item strong{ font-family:var(--display); font-weight:800; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ===========================================================
   FILM STORY
   =========================================================== */
.story__head{ max-width:18ch; }
.values{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:48px; }
.vcard{ background:linear-gradient(180deg,var(--bg-card),var(--bg-raised)); border:1px solid var(--line);
  border-radius:var(--r); padding:26px 22px 24px; transition:transform .3s ease, border-color .3s ease, background .3s ease; }
.vcard:hover{ transform:translateY(-4px); border-color:var(--line-2); }
.vcard__ic{ width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center;
  background:rgba(250,163,32,0.12); border:1px solid rgba(250,163,32,0.25); color:var(--amber); margin-bottom:18px; }
.vcard__ic svg{ width:24px; height:24px; }
.vcard__big{ font-family:var(--display); font-weight:800; font-size:34px; letter-spacing:-0.03em; line-height:1; margin-bottom:6px; }
.vcard__t{ font-family:var(--display); font-weight:700; font-size:17px; margin-bottom:6px; letter-spacing:-0.01em; }
.vcard__d{ font-size:14.5px; color:var(--ink-62); line-height:1.5; }
.story__close{ margin-top:54px; max-width:860px; margin-inline:auto; }
.story__close h3{ font-size:clamp(28px,4.5vw,52px); line-height:1.1; letter-spacing:-0.025em; max-width:none; }
.story__close .h-xl em{ font-style:normal; color:var(--amber); }

/* ===========================================================
   BEFORE / AFTER SLIDER
   =========================================================== */
.ba{ position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line-2);
  aspect-ratio:16/9; box-shadow:var(--shadow); user-select:none; touch-action:pan-y; background:#000; }
.ba__layer{ position:absolute; inset:0; }
.ba__layer .ph{ width:100%; height:100%; border-radius:0; }
.ba__layer img{ width:100%; height:100%; object-fit:cover; display:block; pointer-events:none; }
.ba__after{ /* sits on top, clipped from the left */ }
.ba__before{ }
.ba__tag{ position:absolute; top:16px; z-index:4; font-size:12px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase;
  padding:7px 13px; border-radius:var(--r-pill); backdrop-filter:blur(6px); }
.ba__tag--before{ left:16px; background:rgba(0,0,0,0.55); color:var(--white); border:1px solid var(--line-2); }
.ba__tag--after{ right:16px; background:var(--amber); color:var(--amber-ink); }
.ba__handle{ position:absolute; top:0; bottom:0; width:2px; background:var(--white); z-index:5; left:50%;
  box-shadow:0 0 0 1px rgba(0,0,0,0.3); cursor:ew-resize; }
.ba__grip{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:54px; height:54px; border-radius:50%; background:var(--white); color:#0a0a0a;
  display:flex; align-items:center; justify-content:center; box-shadow:0 8px 24px rgba(0,0,0,0.45); cursor:ew-resize; }
.ba__grip svg{ width:26px; height:26px; }

/* hero CSS background (used when no photo is available) */
.hero__bg--css{
  background:
    radial-gradient(ellipse 80% 60% at 70% 20%, rgba(250,163,32,0.10) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 15% 75%, rgba(250,163,32,0.06) 0%, transparent 50%),
    linear-gradient(180deg, #0a0c12 0%, #060709 50%, #040405 100%);
}
.hero__bg--tesla{
  background:
    radial-gradient(ellipse 70% 50% at 85% 25%, rgba(120,200,255,0.06) 0%, transparent 55%),
    radial-gradient(ellipse 80% 60% at 20% 70%, rgba(250,163,32,0.07) 0%, transparent 50%),
    linear-gradient(180deg, #08090e 0%, #050608 50%, #030405 100%);
}

/* striped image PLACEHOLDER */
.ph{ position:relative; border-radius:var(--r); overflow:hidden;
  background-color:#0e0e10;
  background-image:repeating-linear-gradient(45deg, rgba(255,255,255,0.035) 0 2px, transparent 2px 11px);
  display:flex; align-items:center; justify-content:center; }
.ph::after{ content:attr(data-label); position:absolute; bottom:12px; left:12px;
  font-family:ui-monospace,'SF Mono',Menlo,monospace; font-size:11px; letter-spacing:0.04em;
  color:var(--ink-44); background:rgba(0,0,0,0.5); padding:5px 9px; border-radius:7px; max-width:80%; }
.ph__mark{ font-family:ui-monospace,monospace; font-size:12px; color:var(--ink-30); letter-spacing:0.08em; text-transform:uppercase; }
/* "after" variant — cooler, darker glass feel to sell the tint */
.ph--after{ background-color:#070a0c;
  background-image:repeating-linear-gradient(45deg, rgba(120,180,210,0.05) 0 2px, transparent 2px 11px); }
.ph--warm{ background-color:#141008;
  background-image:repeating-linear-gradient(45deg, rgba(250,163,32,0.06) 0 2px, transparent 2px 11px); }

/* ===========================================================
   SERVICES
   =========================================================== */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:48px; }
.svc{ position:relative; background:linear-gradient(180deg,var(--bg-card),var(--bg-raised)); border:1px solid var(--line);
  border-radius:var(--r); padding:0; overflow:hidden; display:flex; flex-direction:column;
  transition:transform .3s ease, border-color .3s ease; }
.svc:hover{ transform:translateY(-5px); border-color:rgba(250,163,32,0.4); }
.svc__media{ aspect-ratio:16/10; }
.svc__media .ph{ width:100%; height:100%; border-radius:0; }
.svc__body{ padding:24px 24px 26px; display:flex; flex-direction:column; gap:10px; flex:1; }
.svc__t{ font-family:var(--display); font-weight:800; font-size:21px; letter-spacing:-0.02em; }
.svc__d{ font-size:15px; color:var(--ink-62); line-height:1.5; flex:1; }
.svc__foot{ display:flex; align-items:center; justify-content:space-between; padding-top:8px; }
.svc__tag{ font-size:12px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--amber); }

/* ===========================================================
   GALLERY
   =========================================================== */
.gal-grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:14px; margin-top:40px; }
.gal-grid .ph{ width:100%; height:100%; }
.gal-grid .g-wide{ grid-column:span 2; }
.gal-grid .g-tall{ grid-row:span 2; }
/* gallery slot — no text labels, just styled dark atmosphere */
.gal-slot{ border-radius:var(--r); }
/* gallery CTA card */
.gal-cta{
  border-radius:var(--r-lg); overflow:hidden;
  background:radial-gradient(120% 140% at 100% 0%, rgba(250,163,32,0.13), transparent 55%),
             linear-gradient(180deg,#0f0e0b,#080807);
  border:1px solid rgba(250,163,32,0.28);
  display:flex; align-items:center; justify-content:center; padding:28px;
}
.gal-cta__inner{ max-width:26ch; }
.gal-cta__inner .kicker{ margin-bottom:12px; }
/* map iframe */
.map iframe{ width:100%; height:100%; border:0; display:block; border-radius:var(--r); }
.why-media__ph{ aspect-ratio:4/5; border-radius:var(--r-lg); border:1px solid var(--line-2); }

/* ===========================================================
   WHY / PROCESS
   =========================================================== */
.why-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; }
.steps{ display:flex; flex-direction:column; gap:4px; }
.step{ display:grid; grid-template-columns:auto 1fr; gap:20px; padding:22px 0; border-bottom:1px solid var(--line); }
.step:last-child{ border-bottom:0; }
.step__n{ font-family:var(--display); font-weight:800; font-size:18px; color:var(--amber);
  width:44px; height:44px; border-radius:50%; border:1px solid rgba(250,163,32,0.3);
  display:flex; align-items:center; justify-content:center; flex:none; }
.step__t{ font-family:var(--display); font-weight:700; font-size:19px; letter-spacing:-0.01em; margin-bottom:4px; }
.step__d{ font-size:15px; color:var(--ink-62); }
.why-media{ position:relative; }
.why-media .ph{ aspect-ratio:4/5; border-radius:var(--r-lg); border:1px solid var(--line-2); }
.badge-warranty{ position:absolute; bottom:-22px; left:-22px; background:var(--amber); color:var(--amber-ink);
  border-radius:var(--r); padding:18px 22px; box-shadow:var(--amber-glow); max-width:200px; }
.badge-warranty b{ font-family:var(--display); font-weight:800; font-size:30px; display:block; line-height:1; letter-spacing:-0.02em; }
.badge-warranty span{ font-size:13px; font-weight:600; }

/* ===========================================================
   REVIEWS
   =========================================================== */
.rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:44px; }
.rev{ background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r); padding:26px; display:flex; flex-direction:column; gap:16px; }
.rev__stars{ display:flex; gap:3px; color:var(--amber); }
.rev__stars svg{ width:17px; height:17px; }
.rev__q{ font-size:16px; line-height:1.55; color:var(--ink-80); flex:1; }
.rev__by{ display:flex; align-items:center; gap:12px; }
.rev__av{ width:40px; height:40px; border-radius:50%; background:linear-gradient(135deg,#2a2a30,#16161a);
  display:flex; align-items:center; justify-content:center; font-family:var(--display); font-weight:800; font-size:15px; color:var(--amber); border:1px solid var(--line-2); }
.rev__nm{ font-weight:700; font-size:15px; font-family:var(--display); }
.rev__meta{ font-size:12.5px; color:var(--ink-44); }
.gscore{ display:inline-flex; align-items:center; gap:14px; background:var(--bg-card); border:1px solid var(--line);
  border-radius:var(--r-pill); padding:12px 22px; }
.gscore b{ font-family:var(--display); font-size:26px; font-weight:800; letter-spacing:-0.02em; }
.gscore .gstars{ color:var(--amber); display:flex; gap:2px; } .gscore .gstars svg{ width:16px; height:16px; }

/* ===========================================================
   TESLA CALLOUT
   =========================================================== */
.tesla{ position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid rgba(250,163,32,0.3);
  background:radial-gradient(120% 140% at 100% 0%, rgba(250,163,32,0.16), transparent 55%), linear-gradient(180deg,#0d0c0a,#070707);
  padding:clamp(36px,5vw,60px); display:grid; grid-template-columns:1.3fr 1fr; gap:40px; align-items:center; }
.tesla__range{ font-family:var(--display); font-weight:800; font-size:clamp(48px,7vw,84px); letter-spacing:-0.04em; line-height:0.9; color:var(--amber); }
.tesla__range small{ display:block; font-size:15px; font-weight:600; letter-spacing:0; color:var(--ink-62); margin-top:10px; }

/* ===========================================================
   QUOTE FORM
   =========================================================== */
.quote{ display:grid; grid-template-columns:1.15fr 0.85fr; gap:clamp(28px,4vw,52px); align-items:start; }
.form-card{ background:linear-gradient(180deg,var(--bg-card),var(--bg-raised)); border:1px solid var(--line-2);
  border-radius:var(--r-lg); padding:clamp(26px,3.4vw,40px); box-shadow:var(--shadow); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:13px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-62); margin-bottom:9px; }
.field .req{ color:var(--amber); }
.input, .select{ width:100%; box-sizing:border-box; background:#08080a; border:1px solid var(--line-2); border-radius:var(--r-sm);
  color:#fff; font-family:var(--body); font-size:16px; line-height:1.4; height:52px; padding:0 15px;
  transition:border-color .2s ease, box-shadow .2s ease; }
.input::placeholder{ color:var(--ink-30); }
/* select: kill native styling, match inputs, custom chevron */
.select{ appearance:none; -webkit-appearance:none; -moz-appearance:none; cursor:pointer; padding-right:44px;
  background-color:#08080a;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23FAA320' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 15px center; }
.select:invalid{ color:var(--ink-30); }
.select option{ color:#fff; background:#0c0c0e; }
.input:focus, .select:focus{ outline:none; border-color:var(--amber); box-shadow:0 0 0 3px rgba(250,163,32,0.16); }
.row3{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }
.row2{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.checks{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.check{ display:flex; align-items:center; gap:11px; padding:13px 15px; border:1px solid var(--line-2); border-radius:var(--r-sm);
  cursor:pointer; transition:border-color .2s ease, background .2s ease; font-size:15px; font-weight:500; user-select:none; }
.check:hover{ border-color:rgba(255,255,255,0.25); }
.check input{ position:absolute; opacity:0; width:0; height:0; }
.check .box{ width:20px; height:20px; border-radius:6px; border:1.5px solid var(--line-2); flex:none;
  display:flex; align-items:center; justify-content:center; transition:.2s; }
.check .box svg{ width:13px; height:13px; opacity:0; transform:scale(.5); transition:.2s; color:var(--amber-ink); }
.check input:checked ~ .box{ background:var(--amber); border-color:var(--amber); }
.check input:checked ~ .box svg{ opacity:1; transform:none; }
.check input:checked ~ span{ color:#fff; }
.check:has(input:checked){ border-color:rgba(250,163,32,0.5); background:rgba(250,163,32,0.06); }
.upload{ display:flex; align-items:center; gap:12px; padding:15px; border:1px dashed var(--line-2); border-radius:var(--r-sm);
  color:var(--ink-62); font-size:14.5px; cursor:pointer; transition:.2s; }
.upload:hover{ border-color:var(--amber); color:var(--white); }
.upload svg{ width:20px; height:20px; color:var(--amber); flex:none; }
.helper{ font-size:13.5px; color:var(--ink-44); margin-top:12px; text-align:center; }
.helper.ok{ color:var(--amber); font-weight:600; }
.err{ border-color:#ff6b5e !important; }
.field-err{ font-size:12.5px; color:#ff8077; margin-top:6px; display:none; }
.field-err.show{ display:block; }

/* contact rail */
.contact-rail{ display:flex; flex-direction:column; gap:14px; }
.crow{ display:flex; gap:14px; align-items:flex-start; padding:18px; border:1px solid var(--line); border-radius:var(--r); background:var(--bg-card); }
.crow__ic{ width:42px; height:42px; border-radius:11px; background:rgba(250,163,32,0.12); border:1px solid rgba(250,163,32,0.22);
  color:var(--amber); display:flex; align-items:center; justify-content:center; flex:none; }
.crow__ic svg{ width:20px; height:20px; }
.crow__t{ font-family:var(--display); font-weight:700; font-size:16px; }
.crow__d{ font-size:14px; color:var(--ink-62); }
.map .ph{ aspect-ratio:16/10; border-radius:var(--r); border:1px solid var(--line-2); }

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{ border-top:1px solid var(--line); background:#050506; padding-block:clamp(48px,6vw,72px) 32px; }
.footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.footer p{ color:var(--ink-62); font-size:15px; margin:14px 0 0; max-width:38ch; }
.footer h4{ font-size:13px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-44); margin-bottom:16px; font-weight:700; }
.footer ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer ul a{ color:var(--ink-80); font-size:15px; transition:color .2s; }
.footer ul a:hover{ color:var(--amber); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap;
  margin-top:46px; padding-top:24px; border-top:1px solid var(--line); color:var(--ink-44); font-size:13px; }
.footer__bottom a{ color:var(--ink-44); } .footer__bottom a:hover{ color:#fff; }

/* sticky mobile CTA */
.mcta{ position:fixed; left:12px; right:12px; bottom:12px; z-index:50; display:none; gap:10px;
  background:rgba(8,8,10,0.9); backdrop-filter:blur(12px); border:1px solid var(--line-2); border-radius:var(--r-pill); padding:8px; }
.mcta .btn{ flex:1; }

/* ===========================================================
   SCROLL REVEAL
   =========================================================== */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .trust__track{ animation:none; }
  .hero__scroll .bar{ animation:none; }
}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:1024px){
  .values{ grid-template-columns:repeat(2,1fr); }
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .rev-grid{ grid-template-columns:1fr; }
  .gal-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:170px; }
  .gal-grid .g-wide{ grid-column:span 2; }
  .gal-grid .g-tall{ grid-row:span 1; }
  .why-grid{ grid-template-columns:1fr; }
  .why-media{ max-width:440px; }
  .tesla{ grid-template-columns:1fr; }
  .quote{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .nav__links, .nav__phone{ display:none; }
  .burger{ display:flex; }
  .mcta{ display:flex; }
  /* bottom padding so mcta bar doesn't cover submit button */
  .footer{ padding-bottom:88px; }
  #quote{ padding-bottom:calc(clamp(64px,9vw,128px) + 72px); }
  .values{ grid-template-columns:1fr 1fr; gap:12px; }
  .vcard{ padding:20px 16px; }
  .vcard__big{ font-size:28px; }
  .svc-grid{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; gap:30px; }
  .row3{ grid-template-columns:1fr; }
  .checks{ grid-template-columns:1fr; }
  .badge-warranty{ left:0; bottom:-16px; }
  .hero{ min-height:92svh; }
  .step{ grid-template-columns:1fr; gap:10px; }
  .step__n{ width:38px; height:38px; font-size:16px; }
  /* gallery on mobile */
  .gal-grid{ grid-template-columns:1fr 1fr; grid-auto-rows:150px; }
  .gal-cta{ grid-column:span 2; }
  /* map */
  .map{ aspect-ratio:16/9; }
  /* trust bar overflow guard */
  .trust{ max-width:100vw; }
}
@media (max-width:400px){
  .values{ grid-template-columns:1fr; }
  .hero__cta{ flex-direction:column; }
  .hero__cta .btn{ width:100%; }
}
/* iOS input zoom prevention — all inputs/selects must be ≥16px */
input, select, textarea{ font-size:16px; }
/* touch slider: no text selection while dragging */
.ba{ -webkit-user-select:none; user-select:none; }
.ba__handle{ touch-action:none; }
