/* ============================================================
   LUIGI WRAPS — bespoke design system
   Dark automotive aesthetic · electric-blue (#0067FD) on blue-black
   Hand-authored. No framework. Angular motifs echo the LW logo.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --bg:        #05070d;
  --bg-2:      #080b13;
  --surface:   #0d111b;
  --surface-2: #121826;
  --surface-3: #18202f;
  --line:        rgba(255,255,255,.07);
  --line-strong: rgba(255,255,255,.15);

  --brand:        #0067fd;
  --brand-bright: #2f86ff;
  --brand-deep:   #0048b8;
  --brand-glow:   rgba(14,108,255,.45);
  --cyan:         #4cc4ff;

  --white:    #ffffff;
  --text:     #c4cddc;
  --text-dim: #828ea4;
  --text-mute:#525d72;

  --grad-brand: linear-gradient(135deg,#0067fd 0%,#3d8bff 55%,#4cc4ff 100%);
  --grad-text:  linear-gradient(100deg,#ffffff 0%,#9fc2ff 60%,#0067fd 130%);

  --container: 1760px;
  --radius:   14px;
  --radius-lg:20px;

  --shadow:    0 24px 60px -24px rgba(0,0,0,.85);
  --shadow-blue:0 18px 50px -18px var(--brand-glow);

  --ease: cubic-bezier(.16,1,.3,1);
  --ease-out: cubic-bezier(.22,.61,.36,1);

  --font-display:'Saira Condensed', 'Arial Narrow', sans-serif;
  --font-body:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --nav-h: 76px;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul{ list-style:none; padding:0; }
input,select,textarea{ font-family:inherit; font-size:1rem; }
::selection{ background:var(--brand); color:#fff; }

/* page background field */
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(1100px 620px at 78% -8%, rgba(14,108,255,.16), transparent 60%),
    radial-gradient(900px 700px at -10% 12%, rgba(14,108,255,.10), transparent 55%),
    var(--bg);
}
body::after{ /* fine carbon hairline grid */
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 50% 30%, #000 0%, transparent 78%);
}

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:clamp(20px,3vw,48px); }
.section{ position:relative; padding:clamp(72px,9vw,128px) 0; }
.section--tight{ padding:clamp(54px,6vw,88px) 0; }
.center{ text-align:center; }
.relative{ position:relative; }

/* ---------- Typography ---------- */
.display{ font-family:var(--font-display); font-weight:800; line-height:.92; letter-spacing:-.01em; text-transform:uppercase; }
h1,h2,h3{ color:var(--white); }
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:600; text-transform:uppercase;
  letter-spacing:.34em; font-size:.74rem; color:var(--brand-bright);
}
.kicker::before{ content:""; width:26px; height:2px; background:var(--grad-brand); }
.kicker--center::after{ content:""; width:26px; height:2px; background:var(--grad-brand); }
.section-title{
  font-family:var(--font-display); font-weight:800; text-transform:uppercase;
  font-size:clamp(2.1rem,5vw,3.6rem); line-height:.95; color:var(--white);
  letter-spacing:-.01em; margin-top:18px;
}
.section-title .accent{
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.lead{ color:var(--text-dim); font-size:1.08rem; max-width:60ch; margin-top:18px; }
.center .lead{ margin-inline:auto; }
.text-brand{ color:var(--brand-bright); }

/* ---------- Buttons ---------- */
.btn{
  --pad:15px 26px;
  position:relative; display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:var(--pad); font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; font-size:.95rem; line-height:1; cursor:pointer;
  border-radius:11px; transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, color .3s, border-color .3s;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 11px),calc(100% - 11px) 100%,0 100%);
  white-space:nowrap; min-height:48px; will-change:transform;
}
.btn svg{ width:18px; height:18px; }
.btn--primary{ background:var(--grad-brand); color:#fff; box-shadow:var(--shadow-blue); }
.btn--primary:hover{ transform:translateY(-3px); box-shadow:0 26px 60px -18px var(--brand-glow); }
.btn--ghost{ background:rgba(255,255,255,.04); color:var(--white); border:1px solid var(--line-strong); }
.btn--ghost:hover{ background:rgba(255,255,255,.09); transform:translateY(-3px); border-color:rgba(255,255,255,.28); }
.btn--outline{ background:transparent; color:var(--white); border:1px solid var(--brand); }
.btn--outline:hover{ background:rgba(14,108,255,.12); transform:translateY(-3px); }
.btn--lg{ --pad:18px 34px; font-size:1.02rem; }
.btn--block{ width:100%; }

.link-arrow{
  display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display);
  font-weight:600; text-transform:uppercase; letter-spacing:.12em; font-size:.82rem;
  color:var(--brand-bright); transition:gap .3s var(--ease), color .3s;
}
.link-arrow svg{ width:15px; height:15px; transition:transform .3s var(--ease); }
.link-arrow:hover{ color:#fff; }
.link-arrow:hover svg{ transform:translateX(5px); }

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed; inset:14px 16px auto; z-index:50; height:var(--nav-h);
  display:flex; align-items:center;
  border:1px solid var(--line); border-radius:16px;
  background:rgba(8,11,19,.55); backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  transition:background .4s var(--ease), border-color .4s, box-shadow .4s, inset .4s var(--ease), height .4s var(--ease);
}
.site-header.scrolled{ inset:0 0 auto; border-radius:0; border-left:0; border-right:0; background:rgba(6,8,14,.86); box-shadow:0 12px 40px -18px #000; height:66px; }
.nav{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:22px; display:flex; align-items:center; gap:28px; }
.brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.brand img{ height:40px; width:auto; transition:height .4s var(--ease); }
.scrolled .brand img{ height:34px; }
.nav-links{ display:flex; align-items:center; gap:6px; margin-left:auto; }
.nav-links a{
  position:relative; padding:10px 14px; font-family:var(--font-display); font-weight:600;
  text-transform:uppercase; letter-spacing:.08em; font-size:.86rem; color:var(--text-dim);
  border-radius:8px; transition:color .25s;
}
.nav-links a::after{
  content:""; position:absolute; left:14px; right:14px; bottom:6px; height:2px; transform:scaleX(0);
  transform-origin:left; background:var(--grad-brand); transition:transform .3s var(--ease);
}
.nav-links a:hover,.nav-links a.active{ color:#fff; }
.nav-links a:hover::after,.nav-links a.active::after{ transform:scaleX(1); }
.nav-cta{ margin-left:18px; }
.nav-actions{ display:flex; align-items:center; gap:14px; margin-left:auto; }
.nav-actions .nav-links{ margin-left:0; }

.nav-ig{ display:none; width:46px; height:46px; border:1px solid var(--line-strong); border-radius:11px; align-items:center; justify-content:center; color:#fff; transition:background .25s var(--ease), border-color .25s, transform .25s var(--ease); flex-shrink:0; }
.nav-ig svg{ width:20px; height:20px; }
.nav-ig:hover{ background:var(--grad-brand); border-color:transparent; transform:translateY(-2px); }
.nav-phone{ display:inline-flex; align-items:center; gap:9px; padding:9px 15px; border:1px solid var(--line-strong); border-radius:11px; color:#fff; font-family:var(--font-display); font-weight:600; letter-spacing:.03em; font-size:.92rem; white-space:nowrap; flex-shrink:0; transition:background .25s var(--ease), border-color .25s, transform .25s var(--ease); }
.nav-phone svg{ width:18px; height:18px; color:var(--brand-bright); flex-shrink:0; }
.nav-phone:hover{ background:rgba(14,108,255,.12); border-color:var(--brand); transform:translateY(-2px); }
.nav-toggle{ display:none; width:46px; height:46px; border:1px solid var(--line-strong); border-radius:11px; align-items:center; justify-content:center; flex-shrink:0; }
.nav-toggle span{ display:block; width:20px; height:2px; background:#fff; position:relative; transition:.3s var(--ease); }
.nav-toggle span::before,.nav-toggle span::after{ content:""; position:absolute; left:0; width:20px; height:2px; background:#fff; transition:.3s var(--ease); }
.nav-toggle span::before{ top:-6px; } .nav-toggle span::after{ top:6px; }
.nav-toggle.open span{ background:transparent; }
.nav-toggle.open span::before{ top:0; transform:rotate(45deg); }
.nav-toggle.open span::after{ top:0; transform:rotate(-45deg); }

/* mobile drawer */
.mobile-menu{
  position:fixed; inset:0; z-index:49; display:flex; flex-direction:column; justify-content:center;
  padding:90px 28px 40px; gap:6px; background:rgba(5,7,13,.97); backdrop-filter:blur(8px);
  transform:translateX(100%); transition:transform .5s var(--ease); visibility:hidden;
}
.mobile-menu.open{ transform:none; visibility:visible; }
.mobile-menu a{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:1.7rem; letter-spacing:.02em; color:#fff; padding:12px 4px; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; }
.mobile-menu a span{ color:var(--brand); font-size:1rem; }
.mobile-menu .btn{ margin-top:26px; }

/* ---------- Hero ---------- */
.hero{ position:relative; padding-top:calc(var(--nav-h) + 70px); padding-bottom:60px; min-height:100svh; display:flex; align-items:center; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; width:100%; }
.hero-eyebrow{ margin-bottom:22px; }
.hero h1{
  font-family:var(--font-display); font-weight:800; text-transform:uppercase;
  font-size:clamp(2.8rem,6.4vw,5.4rem); line-height:.9; letter-spacing:-.015em; color:#fff;
  font-style:italic;
}
.hero h1 .accent{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero-sub{ margin-top:24px; font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.08em; font-size:clamp(1.2rem,2.3vw,1.85rem); color:var(--text); }
.hero-copy{ margin-top:16px; max-width:46ch; color:var(--text-dim); font-size:1.05rem; }
.hero-actions{ margin-top:34px; display:flex; flex-wrap:wrap; gap:14px; }
.hero-trust{ margin-top:34px; display:flex; flex-wrap:wrap; gap:26px; align-items:center; }
.hero-trust .ht{ display:flex; align-items:center; gap:10px; color:var(--text-dim); font-size:.86rem; }
.hero-trust .ht svg{ width:18px; height:18px; color:var(--brand-bright); flex-shrink:0; }

/* hero stage — CSS showroom (works with or without a real photo) */
.stage{ position:relative; aspect-ratio:5/4; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); background:
  radial-gradient(120% 90% at 70% 18%, #16233f 0%, #0a0f1b 46%, #05070d 100%); box-shadow:var(--shadow); }
.stage::before{ /* floor reflection grid */
  content:""; position:absolute; left:-20%; right:-20%; bottom:-2%; height:48%;
  background-image:linear-gradient(rgba(14,108,255,.18) 1px,transparent 1px),linear-gradient(90deg,rgba(14,108,255,.10) 1px,transparent 1px);
  background-size:42px 30px; transform:perspective(420px) rotateX(64deg); transform-origin:bottom;
  mask-image:linear-gradient(#000,transparent 80%); opacity:.7;
}
.stage::after{ /* spotlight */
  content:""; position:absolute; inset:0; background:radial-gradient(60% 50% at 60% 30%, rgba(76,196,255,.16), transparent 70%);
}
.stage-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:3; }
.stage-glow{ position:absolute; width:74%; left:13%; top:30%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle, rgba(14,108,255,.42), transparent 62%); filter:blur(18px); z-index:1; }
.stage-mark{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; z-index:2; }
.stage-mark svg{ width:54%; height:auto; opacity:.96; filter:drop-shadow(0 18px 40px rgba(14,108,255,.5)); }
.stage-beam{ position:absolute; top:-10%; left:30%; width:2px; height:120%; background:linear-gradient(var(--cyan),transparent); transform:rotate(18deg); opacity:.5; z-index:2; }
.stage-beam.b2{ left:62%; transform:rotate(-14deg); opacity:.3; }
.stage-badge{ position:absolute; z-index:4; bottom:18px; left:18px; right:18px; display:flex; justify-content:space-between; align-items:center;
  padding:12px 16px; border:1px solid var(--line-strong); border-radius:12px; background:rgba(7,10,18,.62); backdrop-filter:blur(8px); }
.stage-badge b{ font-family:var(--font-display); color:#fff; text-transform:uppercase; letter-spacing:.06em; }
.stage-badge .chip{ font-family:var(--font-display); font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; color:var(--brand-bright); }

/* hero background video — rendered to a <canvas> so it shows in every renderer */
.hero-bg{ position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none;
  background:#05070d url('../img/hero-poster.jpg') center 38%/cover no-repeat; }
.hero-source, .hero-canvas{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 40%; display:block;
  filter:brightness(1.4) contrast(1.05) saturate(1.16); }
.hero-source{ z-index:0; }
.hero-canvas{ z-index:1; }
.hero-bg::after{ content:""; position:absolute; inset:0; z-index:2;
  background:
    linear-gradient(90deg, rgba(5,7,13,.9) 0%, rgba(5,7,13,.55) 32%, rgba(5,7,13,.12) 62%, rgba(5,7,13,.06) 100%),
    linear-gradient(0deg, rgba(5,7,13,.5) 0%, rgba(5,7,13,0) 38%);
}
.hero .container{ position:relative; z-index:2; }
.hero-logo{ display:flex; align-items:center; justify-content:center; }
.hero-logo img{ width:100%; max-width:520px; filter:drop-shadow(0 26px 70px rgba(14,108,255,.5)); animation:heroFloat 6s var(--ease) infinite; }
@keyframes heroFloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
@media (prefers-reduced-motion:reduce){ .hero-video{ display:none; } .hero-logo img{ animation:none; } }

.scroll-cue{ position:absolute; left:50%; bottom:22px; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--text-mute); font-family:var(--font-display); font-size:.7rem; letter-spacing:.3em; text-transform:uppercase; }
.scroll-cue .mouse{ width:22px; height:34px; border:2px solid var(--text-mute); border-radius:12px; position:relative; }
.scroll-cue .mouse::after{ content:""; position:absolute; left:50%; top:6px; width:3px; height:7px; border-radius:2px; background:var(--brand-bright); transform:translateX(-50%); animation:scrolldot 1.6s var(--ease) infinite; }
@keyframes scrolldot{ 0%{opacity:0;transform:translate(-50%,0)} 40%{opacity:1} 80%{opacity:0;transform:translate(-50%,12px)} }

/* ---------- Marquee ticker ---------- */
.marquee{ border-block:1px solid var(--line); background:linear-gradient(180deg,var(--bg-2),var(--bg)); overflow:hidden; padding:18px 0; }
.marquee-track{ display:flex; gap:48px; width:max-content; animation:marquee 32s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ display:inline-flex; align-items:center; gap:48px; font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.06em; font-size:1.25rem; color:var(--text-mute); }
.marquee-track .dot{ width:8px; height:8px; background:var(--brand); transform:rotate(45deg); }
.marquee-track em{ color:#fff; font-style:normal; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- Feature cards (split) ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.feature{
  position:relative; overflow:hidden; isolation:isolate;
  border:1px solid var(--line); border-radius:var(--radius-lg);
  background:var(--surface); min-height:340px; display:flex; align-items:center;
  transition:border-color .4s, transform .5s var(--ease);
}
.feature:hover{ border-color:var(--brand); transform:translateY(-4px); }
.feature .fbg{ position:absolute; inset:0; z-index:-2; background-size:cover; background-position:center; transition:transform .8s var(--ease); }
.feature:hover .fbg{ transform:scale(1.05); }
.feature::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(90deg, rgba(5,7,13,.97) 0%, rgba(5,7,13,.9) 24%, rgba(5,7,13,.6) 48%, rgba(5,7,13,.28) 72%, rgba(5,7,13,.05) 100%); }
.feature-content{ position:relative; padding:clamp(26px,2.6vw,42px); width:100%; max-width:540px; }
.feature h3{ font-family:var(--font-display); font-weight:800; font-style:italic; text-transform:uppercase; font-size:clamp(1.65rem,2.5vw,2.4rem); line-height:.95; color:#fff; }
.feature h3 .accent{ color:var(--brand-bright); display:block; }
.feature .flist{ display:flex; flex-direction:column; gap:10px; margin:18px 0 24px; }
.feature .flist li{ display:flex; align-items:center; gap:10px; color:#fff; font-size:.95rem; }
.feature .flist svg{ width:16px; height:16px; color:var(--brand-bright); flex-shrink:0; }
@media (max-width:560px){
  .feature{ min-height:400px; align-items:flex-end; }
  .feature::after{ background:linear-gradient(180deg, rgba(5,7,13,.3) 0%, rgba(5,7,13,.55) 45%, rgba(5,7,13,.93) 100%); }
  .feature-content{ max-width:100%; }
}
/* angular finish backgrounds (placeholder visuals, swap with photos via .fbg style) */
.finish-styling{ background:
  radial-gradient(80% 120% at 20% 0%, #1b4dd6 0%, transparent 50%),
  conic-gradient(from 210deg at 70% 60%, #0a1730, #15294f, #0a1730),
  #0a1020; }
.finish-commercial{ background:
  radial-gradient(80% 120% at 80% 0%, #123a8c 0%, transparent 55%),
  linear-gradient(135deg,#0c1322,#0a1830 60%,#091428),#0a1020; }

/* ---------- Services grid ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.svc{
  position:relative; padding:30px 26px; border:1px solid var(--line); border-radius:var(--radius);
  background:linear-gradient(180deg,var(--surface),var(--bg-2)); overflow:hidden;
  transition:border-color .4s, transform .5s var(--ease), background .4s;
}
.svc::before{ content:""; position:absolute; top:0; left:0; width:100%; height:3px; transform:scaleX(0); transform-origin:left; background:var(--grad-brand); transition:transform .4s var(--ease); }
.svc:hover{ transform:translateY(-6px); border-color:var(--line-strong); background:linear-gradient(180deg,var(--surface-2),var(--surface)); }
.svc:hover::before{ transform:scaleX(1); }
.svc .ico{
  width:56px; height:56px; border-radius:13px; display:grid; place-items:center; margin-bottom:20px;
  background:radial-gradient(120% 120% at 30% 20%, rgba(14,108,255,.28), rgba(14,108,255,.06));
  border:1px solid rgba(14,108,255,.35); color:var(--brand-bright);
  transition:transform .5s var(--ease);
}
.svc:hover .ico{ transform:translateY(-3px) rotate(-4deg); }
.svc .ico svg{ width:28px; height:28px; }
.svc h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.02em; font-size:1.32rem; color:#fff; }
.svc p{ margin:10px 0 18px; color:var(--text-dim); font-size:.94rem; }
.svc .num{ position:absolute; top:22px; right:24px; font-family:var(--font-display); font-weight:800; font-size:2.4rem; color:rgba(255,255,255,.05); }

/* service card with photo header */
.svc--media{ padding:0; }
.svc--media .svc-thumb{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.svc--media .svc-thumb i{ position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .7s var(--ease); }
.svc--media:hover .svc-thumb i{ transform:scale(1.06); }
.svc--media .svc-thumb::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(5,7,13,.05) 38%, var(--surface) 100%); }
.svc--media .num{ top:10px; right:18px; font-size:2rem; color:rgba(255,255,255,.85); text-shadow:0 2px 10px rgba(0,0,0,.6); }
.svc--media .svc-content{ position:relative; padding:0 26px 28px; }
.svc--media .ico{ position:relative; z-index:2; margin-top:-42px; background:radial-gradient(120% 120% at 30% 20%, rgba(14,108,255,.45), rgba(14,108,255,.14)), var(--surface-2); box-shadow:0 12px 30px rgba(0,0,0,.5); }

/* video reels band */
.reels-row{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; }
.reel{ position:relative; aspect-ratio:9/16; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); background:#0a1020; transition:border-color .35s, transform .5s var(--ease); }
.reel:hover{ border-color:var(--brand); transform:translateY(-5px); }
.reel video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.reel .play-badge{ position:absolute; top:12px; right:12px; z-index:2; width:34px; height:34px; border-radius:50%; display:grid; place-items:center; background:rgba(5,7,13,.6); border:1px solid var(--line-strong); backdrop-filter:blur(6px); color:#fff; pointer-events:none; }
.reel .play-badge svg{ width:14px; height:14px; margin-left:2px; }
@media (max-width:1024px){ .reels-row{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:560px){ .reels-row{ grid-template-columns:1fr 1fr; gap:12px; } }

/* ---------- Trust badges ---------- */
.trust{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.trust .badge{ padding:26px; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); text-align:left; transition:border-color .35s, transform .4s var(--ease); }
.trust .badge:hover{ border-color:var(--brand); transform:translateY(-4px); }
.trust .badge .ico{ width:48px; height:48px; border-radius:11px; display:grid; place-items:center; margin-bottom:16px; background:rgba(14,108,255,.1); border:1px solid rgba(14,108,255,.3); color:var(--brand-bright); }
.trust .badge .ico svg{ width:24px; height:24px; }
.trust .badge h4{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:#fff; font-size:1.05rem; }
.trust .badge p{ margin-top:8px; color:var(--text-dim); font-size:.9rem; }

/* ---------- Section header helper ---------- */
.sec-head{ max-width:680px; }
.sec-head.center{ margin-inline:auto; }
.sec-head--split{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; max-width:none; flex-wrap:wrap; }

/* ---------- Stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.stat{ text-align:center; padding:30px 18px; border:1px solid var(--line); border-radius:var(--radius); background:linear-gradient(180deg,var(--surface),transparent); }
.stat .num{ font-family:var(--font-display); font-weight:800; font-size:clamp(2.6rem,5vw,3.6rem); line-height:1; color:#fff; }
.stat .num .accent{ color:var(--brand-bright); }
.stat .lbl{ margin-top:8px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.14em; font-size:.76rem; color:var(--text-dim); }

/* ---------- Process / steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; counter-reset:step; }
.step{ position:relative; padding:32px 24px; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); }
.step .sn{ font-family:var(--font-display); font-weight:800; font-size:1rem; color:var(--brand-bright); letter-spacing:.1em; }
.step h4{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; color:#fff; font-size:1.25rem; margin:14px 0 8px; }
.step p{ color:var(--text-dim); font-size:.92rem; }
.step .line{ position:absolute; top:46px; right:-9px; width:18px; height:2px; background:var(--line-strong); z-index:1; }
.steps .step:last-child .line{ display:none; }

/* ---------- Before / After slider ---------- */
.ba{ position:relative; aspect-ratio:16/9; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); user-select:none; touch-action:none; box-shadow:var(--shadow); }
.ba-layer{ position:absolute; inset:0; background-size:cover; background-position:center; display:flex; align-items:flex-end; }
.ba-after{ z-index:1; }
.ba-before{ z-index:2; width:50%; border-right:2px solid #fff; }
.ba-label{ margin:18px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.14em; font-size:.74rem; padding:7px 14px; border-radius:8px; background:rgba(5,7,13,.7); color:#fff; backdrop-filter:blur(6px); }
.ba-after .ba-label{ margin-left:auto; }
.ba-handle{ position:absolute; top:0; bottom:0; left:50%; z-index:3; width:44px; transform:translateX(-50%); display:flex; align-items:center; justify-content:center; cursor:ew-resize; }
.ba-handle .grip{ width:44px; height:44px; border-radius:50%; background:var(--grad-brand); display:grid; place-items:center; box-shadow:0 10px 30px -8px var(--brand-glow), 0 0 0 4px rgba(5,7,13,.6); }
.ba-handle .grip svg{ width:22px; height:22px; color:#fff; }
.ba-handle::before{ content:""; position:absolute; top:0; bottom:0; width:2px; background:#fff; opacity:.85; }
.finish-before{ background:linear-gradient(135deg,#2a2f38,#3a4049 50%,#23272e); }
.finish-after{ background:radial-gradient(90% 120% at 30% 0%, #1b56e0, transparent 55%), linear-gradient(135deg,#0a1730,#123a8c 60%,#0a1730); }
.finish-before::after,.finish-after::after{ content:""; position:absolute; inset:0; background:radial-gradient(70% 80% at 50% 30%, rgba(255,255,255,.06), transparent 60%); }

/* ---------- Gallery ---------- */
.filter-bar{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin:0 auto 38px; }
.filter-bar button{
  padding:10px 20px; border:1px solid var(--line-strong); border-radius:9px; font-family:var(--font-display);
  font-weight:600; text-transform:uppercase; letter-spacing:.08em; font-size:.82rem; color:var(--text-dim);
  transition:.3s var(--ease);
}
.filter-bar button:hover{ color:#fff; border-color:rgba(255,255,255,.3); }
.filter-bar button.active{ color:#fff; background:var(--grad-brand); border-color:transparent; box-shadow:var(--shadow-blue); }
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; grid-auto-flow:dense; }
.gitem{ position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); aspect-ratio:4/3; cursor:pointer; transition:transform .5s var(--ease), border-color .4s; }
.gitem.tall{ grid-row:span 2; aspect-ratio:4/6; }
.gitem.wide{ grid-column:span 2; aspect-ratio:8/3; }
.gitem:hover{ transform:translateY(-4px); border-color:var(--brand); }
.gitem .gbg{ position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .7s var(--ease); }
.gitem:hover .gbg{ transform:scale(1.07); }
.gitem .gover{ position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:20px; background:linear-gradient(to top, rgba(5,7,13,.92), rgba(5,7,13,.1) 60%, transparent); opacity:.92; transition:opacity .4s; }
.gitem .gtag{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.14em; font-size:.68rem; color:var(--brand-bright); }
.gitem .gtitle{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; color:#fff; font-size:1.15rem; line-height:1; margin-top:4px; }
/* video tile inside the gallery */
.gitem--video .gbg{ overflow:hidden; }
.gitem--video video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; transition:transform .7s var(--ease); }
.gitem--video:hover video{ transform:scale(1.05); }
.gitem--video .play-badge{ position:absolute; top:14px; right:14px; z-index:3; width:38px; height:38px; border-radius:50%; display:grid; place-items:center;
  background:rgba(5,7,13,.7); border:1px solid var(--line-strong); backdrop-filter:blur(6px); color:#fff;
  transition:transform .3s var(--ease), background .3s; pointer-events:none; }
.gitem--video:hover .play-badge{ transform:scale(1.08); background:var(--brand); border-color:transparent; }
.gitem--video .play-badge svg{ width:16px; height:16px; margin-left:2px; }

/* finish swatches for placeholder gallery visuals */
.fin-1{ background:linear-gradient(135deg,#05070d,#0a1830 60%,#0d2a66); }
.fin-2{ background:linear-gradient(135deg,#1a1d24,#2b2f38 55%,#0e0f12); }
.fin-3{ background:radial-gradient(80% 100% at 30% 10%,#1f6bff,#062b73 60%,#05070d); }
.fin-4{ background:linear-gradient(135deg,#3a2a12,#7a5a22 50%,#1c140a); }
.fin-5{ background:linear-gradient(135deg,#0c2a22,#11907a 55%,#062019); }
.fin-6{ background:linear-gradient(135deg,#2a0c1c,#a81f55 55%,#1a0712); }
.fin-7{ background:linear-gradient(135deg,#15151a,#3d3d47 50%,#0a0a0d); }
.fin-8{ background:radial-gradient(80% 100% at 70% 10%,#4cc4ff,#0a3a7a 60%,#05070d); }
.fin-9{ background:linear-gradient(135deg,#241a3a,#5e3fb0 55%,#120e22); }

/* ---------- Reviews ---------- */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.review{ padding:30px; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); display:flex; flex-direction:column; gap:16px; transition:border-color .35s, transform .4s var(--ease); }
.review:hover{ border-color:var(--line-strong); transform:translateY(-4px); }
.stars{ display:flex; gap:3px; color:#ffb020; }
.stars svg{ width:18px; height:18px; }
.review p{ color:var(--text); font-size:1rem; }
.review .who{ display:flex; align-items:center; gap:12px; margin-top:auto; }
.review .av{ width:44px; height:44px; border-radius:50%; display:grid; place-items:center; font-family:var(--font-display); font-weight:800; color:#fff; background:var(--grad-brand); font-size:1.05rem; }
.review .who b{ color:#fff; font-family:var(--font-display); letter-spacing:.02em; text-transform:uppercase; font-size:.98rem; display:block; }
.review .who span{ color:var(--text-mute); font-size:.82rem; }
.rating-summary{ display:inline-flex; align-items:center; gap:14px; padding:12px 20px; border:1px solid var(--line-strong); border-radius:12px; background:var(--surface); margin-top:22px; }
.rating-summary b{ font-family:var(--font-display); font-size:1.6rem; color:#fff; }

/* ---------- CTA banner ---------- */
.cta-banner{ position:relative; overflow:hidden; border:1px solid rgba(14,108,255,.4); border-radius:var(--radius-lg);
  padding:clamp(40px,6vw,72px); text-align:center;
  background:radial-gradient(120% 140% at 50% -20%, rgba(14,108,255,.4), transparent 60%), linear-gradient(160deg,#08142e,#060a14); }
.cta-banner::before{ content:""; position:absolute; inset:0; z-index:0; background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px); background-size:48px 48px; mask-image:radial-gradient(circle at 50% 0%,#000,transparent 70%); }
.cta-banner > *{ position:relative; z-index:1; }
.cta-banner h2{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; font-size:clamp(2rem,4.6vw,3.4rem); line-height:.96; color:#fff; }
.cta-banner p{ color:#b9c6e0; max-width:54ch; margin:16px auto 30px; }
.cta-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---------- Contact / quote ---------- */
.contact-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:start; }
.quote-card{ padding:clamp(26px,3vw,40px); border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--surface); box-shadow:var(--shadow); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-size:.74rem; color:var(--text-dim); margin-bottom:8px; }
.field .req{ color:var(--brand-bright); }
.field input,.field select,.field textarea{
  width:100%; padding:14px 16px; border-radius:11px; background:var(--bg-2);
  border:1px solid var(--line-strong); color:#fff; transition:border-color .25s, box-shadow .25s; outline:none;
}
.field textarea{ min-height:120px; resize:vertical; }
.field input::placeholder,.field textarea::placeholder{ color:var(--text-mute); }
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--brand); box-shadow:0 0 0 3px rgba(14,108,255,.2); }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23828ea4' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; padding-right:42px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-note{ font-size:.8rem; color:var(--text-mute); margin-top:6px; }
.form-success{ display:none; text-align:center; padding:30px 10px; }
.form-success.show{ display:block; }
.form-success .check{ width:64px; height:64px; border-radius:50%; display:grid; place-items:center; margin:0 auto 18px; background:rgba(14,108,255,.15); border:1px solid var(--brand); color:var(--brand-bright); }
.form-success h3{ font-family:var(--font-display); text-transform:uppercase; color:#fff; }

.info-list{ display:flex; flex-direction:column; gap:14px; }
.info-item{ display:flex; gap:16px; align-items:flex-start; padding:20px; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); transition:border-color .3s, transform .4s var(--ease); }
.info-item:hover{ border-color:var(--line-strong); transform:translateX(4px); }
.info-item .ico{ width:46px; height:46px; border-radius:11px; flex-shrink:0; display:grid; place-items:center; background:rgba(14,108,255,.12); border:1px solid rgba(14,108,255,.3); color:var(--brand-bright); }
.info-item .ico svg{ width:22px; height:22px; }
.info-item .lbl{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-size:.72rem; color:var(--text-dim); }
.info-item .val{ color:#fff; font-size:1.05rem; font-weight:500; }
.info-item .val a:hover{ color:var(--brand-bright); }
.hours-row{ display:flex; justify-content:space-between; padding:7px 0; border-bottom:1px solid var(--line); font-size:.92rem; }
.hours-row:last-child{ border-bottom:0; }
.hours-row span:first-child{ color:var(--text-dim); }
.hours-row span:last-child{ color:#fff; }

/* ---------- FAQ ---------- */
.faq{ max-width:820px; margin-inline:auto; display:flex; flex-direction:column; gap:12px; }
.faq-item{ border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); overflow:hidden; transition:border-color .3s; }
.faq-item.open{ border-color:var(--line-strong); }
.faq-q{ width:100%; text-align:left; padding:22px 24px; display:flex; align-items:center; justify-content:space-between; gap:18px; font-family:var(--font-display); font-weight:600; text-transform:uppercase; letter-spacing:.02em; font-size:1.08rem; color:#fff; }
.faq-q .pm{ width:26px; height:26px; flex-shrink:0; position:relative; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); background:var(--brand-bright); transition:.3s var(--ease); }
.faq-q .pm::before{ width:14px; height:2px; }
.faq-q .pm::after{ width:2px; height:14px; }
.faq-item.open .pm::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a p{ padding:0 24px 22px; color:var(--text-dim); }

/* ---------- Page hero (subpages) ---------- */
.page-hero{ position:relative; padding:calc(var(--nav-h) + 80px) 0 56px; overflow:hidden; border-bottom:1px solid var(--line); }
.page-hero::before{ content:""; position:absolute; inset:0; z-index:-1; background:radial-gradient(90% 120% at 80% -10%, rgba(14,108,255,.22), transparent 55%); }
.breadcrumb{ display:flex; gap:8px; align-items:center; color:var(--text-mute); font-family:var(--font-display); text-transform:uppercase; letter-spacing:.12em; font-size:.76rem; margin-bottom:18px; }
.breadcrumb a:hover{ color:var(--brand-bright); }
.page-hero h1{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; font-size:clamp(2.6rem,6vw,4.4rem); line-height:.92; color:#fff; }
.page-hero h1 .accent{ color:var(--brand-bright); }
.page-hero p{ color:var(--text-dim); max-width:60ch; margin-top:16px; font-size:1.08rem; }

/* ---------- Service detail blocks ---------- */
.svc-detail{ display:grid; grid-template-columns:1fr 1fr; gap:46px; align-items:center; }
.svc-detail.flip .svc-visual{ order:2; }
.svc-visual{ aspect-ratio:4/3; border-radius:var(--radius-lg); border:1px solid var(--line); overflow:hidden; position:relative; box-shadow:var(--shadow); }
.svc-visual .vbg{ position:absolute; inset:0; background-size:cover; background-position:center; }
.svc-visual .vmark{ position:absolute; inset:0; display:grid; place-items:center; }
.svc-visual .vmark svg{ width:42%; opacity:.9; filter:drop-shadow(0 14px 30px rgba(14,108,255,.5)); }
.svc-detail h2{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; font-size:clamp(1.9rem,3.6vw,2.8rem); line-height:.98; color:#fff; }
.svc-detail .check-list{ display:grid; gap:12px; margin:24px 0; }
.svc-detail .check-list li{ display:flex; gap:12px; align-items:flex-start; color:var(--text); }
.svc-detail .check-list svg{ width:22px; height:22px; color:var(--brand-bright); flex-shrink:0; margin-top:1px; }

/* ---------- Footer ---------- */
.site-footer{ position:relative; border-top:1px solid var(--line); background:linear-gradient(180deg,var(--bg),#03050a); padding-top:72px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:54px; }
.footer-brand img{ height:48px; margin-bottom:18px; }
.footer-brand p{ color:var(--text-dim); max-width:34ch; }
.footer-social{ display:flex; gap:12px; margin-top:22px; }
.footer-social a{ width:42px; height:42px; border-radius:11px; border:1px solid var(--line-strong); display:grid; place-items:center; color:var(--text-dim); transition:.3s var(--ease); }
.footer-social a:hover{ color:#fff; background:var(--grad-brand); border-color:transparent; transform:translateY(-3px); }
.footer-social svg{ width:20px; height:20px; }
.footer-col h5{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.14em; font-size:.8rem; color:#fff; margin-bottom:18px; }
.footer-col a, .footer-col p{ display:block; color:var(--text-dim); padding:6px 0; font-size:.94rem; transition:color .25s; }
.footer-col a:hover{ color:var(--brand-bright); }
.footer-bottom{ border-top:1px solid var(--line); padding:22px 0; display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; color:var(--text-mute); font-size:.84rem; }
.footer-bottom a:hover{ color:var(--text); }

/* ---------- Scroll reveal ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.08s; }
.reveal[data-delay="2"]{ transition-delay:.16s; }
.reveal[data-delay="3"]{ transition-delay:.24s; }
.reveal[data-delay="4"]{ transition-delay:.32s; }
.reveal[data-delay="5"]{ transition-delay:.4s; }

/* progress bar */
.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; z-index:60; background:var(--grad-brand); transition:width .1s linear; }

/* skip link */
.skip-link{ position:absolute; left:-999px; top:0; z-index:100; background:var(--brand); color:#fff; padding:12px 18px; border-radius:0 0 10px 0; font-family:var(--font-display); }
.skip-link:focus{ left:0; }

/* floating quote (mobile) */
.float-cta{ position:fixed; right:18px; bottom:18px; z-index:45; display:none; }

/* focus visibility */
:focus-visible{ outline:2px solid var(--brand-bright); outline-offset:3px; border-radius:4px; }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .stage{ max-width:560px; }
  .hero-logo img{ max-width:340px; }
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .trust,.stats,.steps{ grid-template-columns:repeat(2,1fr); }
  .reviews{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .svc-detail{ grid-template-columns:1fr; gap:30px; }
  .svc-detail.flip .svc-visual{ order:0; }
}
@media (max-width:860px){
  .nav{ gap:9px; }
  .nav-links{ display:none; }
  .nav-cta{ display:none; }
  .nav-phone{ width:46px; height:46px; padding:0; gap:0; justify-content:center; margin-left:auto; }
  .nav-phone span{ display:none; }
  .nav-phone svg{ color:#fff; }
  .nav-phone:hover{ background:var(--grad-brand); border-color:transparent; }
  .nav-ig{ display:inline-flex; margin-left:0; }
  .nav-toggle{ display:flex; }
  .split{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; gap:28px; }
  .step .line{ display:none; }
  .float-cta{ display:block; }
}
@media (max-width:560px){
  .gallery{ grid-template-columns:1fr 1fr; }
  .gitem.wide{ grid-column:span 2; }
  .reviews{ grid-template-columns:1fr; }
  .trust,.stats,.steps,.svc-grid{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; gap:34px; }
  .footer-col a,.footer-col p{ word-break:break-word; }
  .sec-head--split{ flex-direction:column; align-items:flex-start; }
  .hero-trust{ gap:14px 22px; }
  .stat .num{ font-size:3rem; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  .marquee-track,.scroll-cue .mouse::after{ animation:none !important; }
  *{ transition-duration:.01ms !important; }
}
