/* =========================================================
   PHANTOM AUTO DETAILING — Global Styles
   ========================================================= */

:root{
  --bg:        #07070F;
  --bg-soft:   #0D0D1A;
  --bg-card:   #11111F;
  --line:      #1B1B2E;
  --line-2:    #2D1A5C;
  --purple:    #9B4FF4;
  --purple-2:  #7A2EE0;
  --purple-3:  #C49BFF;
  --blue:      #4B8BFF;
  --text:      #F2F2FF;
  --muted:     #8B8BA8;
  --muted-2:   #4A4A6A;
  --danger:    #FF4D6D;
  --ok:        #4BFFB0;

  --font-display: 'Bebas Neue', 'Impact', 'Arial Black', sans-serif;
  --font-ui: 'Orbitron', 'Courier New', monospace;

  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

*{box-sizing:border-box;}
html, body{margin:0;padding:0;max-width:100%;overflow-x:hidden;}
html{scroll-behavior:smooth;}
body{
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-ui);
  font-size:14px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none;}
button{font-family:var(--font-ui);cursor:pointer;border:none;background:none;color:inherit;}
input,textarea,select{font-family:var(--font-ui);color:var(--text);}

/* ---------- type helpers ---------- */
.display{font-family:var(--font-display);letter-spacing:0.02em;line-height:0.95;font-weight:400;}
.eyebrow{
  font-family:var(--font-ui);
  font-size:10px;letter-spacing:4px;
  color:var(--purple);text-transform:uppercase;
  font-weight:600;
}
.muted{color:var(--muted);}
.smoke{
  color:var(--text);
  text-shadow:
    0 2px 0 rgba(0,0,0,0.6),
    0 0 30px rgba(155,79,244,0.25),
    0 0 60px rgba(45,26,92,0.5),
    2px 4px 18px rgba(0,0,0,0.85);
}
.smoke-purple{
  color: var(--purple);
  text-shadow:
    0 2px 0 rgba(0,0,0,0.6),
    0 0 22px rgba(155,79,244,0.55),
    2px 4px 18px rgba(0,0,0,0.85);
}

/* ---------- reusable buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-ui);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;font-weight:600;
  padding:14px 26px;border-radius:4px;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease),
             background .2s var(--ease), border-color .2s var(--ease),
             color .2s var(--ease);
  position:relative;overflow:hidden;
  white-space:nowrap;
  min-height:48px;
}
.btn:hover{transform:translateY(-1px) scale(1.02);}
.btn:active{transform:translateY(0) scale(0.99);}

.btn-primary{
  background: linear-gradient(180deg, var(--purple) 0%, var(--purple-2) 100%);
  color:#fff;
  box-shadow: 0 8px 24px -8px rgba(155,79,244,.6), inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-primary:hover{
  box-shadow: 0 14px 32px -8px rgba(155,79,244,.85), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn:disabled, .btn[disabled]{
  opacity:.4;cursor:not-allowed;transform:none;
  filter:grayscale(.3);
}
.btn:disabled:hover, .btn[disabled]:hover{
  transform:none;box-shadow:none;
}
.btn-outline{
  background:transparent;
  color: var(--text);
  border:1px solid var(--purple);
  box-shadow: inset 0 0 0 0 var(--purple);
}
.btn-outline:hover{
  color:#fff;
  box-shadow: inset 0 0 30px -8px rgba(155,79,244,.45);
  border-color: var(--purple-3);
}
.btn-lg{padding:18px 32px;font-size:12px;}
.btn-block{width:100%;}

.btn-pulse{
  animation: btnPulse 2.4s var(--ease) infinite;
}
@keyframes btnPulse{
  0%, 100%{box-shadow:0 8px 24px -8px rgba(155,79,244,.6), 0 0 0 0 rgba(155,79,244,.5);}
  50%     {box-shadow:0 8px 24px -8px rgba(155,79,244,.8), 0 0 0 14px rgba(155,79,244,0);}
}

/* ---------- general layout ---------- */
section{position:relative;padding:120px 0;}
.container{max-width:1200px;margin:0 auto;padding:0 28px;}
.section-head{text-align:center;margin-bottom:64px;}
.section-head h2{font-size:clamp(48px,7vw,84px);margin:8px 0;}
.section-head .eyebrow{display:inline-block;}
.section-head .sub{color:var(--muted);font-size:11px;letter-spacing:3px;text-transform:uppercase;margin-top:4px;}

.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease-out), transform .9s var(--ease-out);}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal-stagger > *{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);}
.reveal-stagger.in > *{opacity:1;transform:translateY(0);}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s;}
.reveal-stagger.in > *:nth-child(2){transition-delay:.15s;}
.reveal-stagger.in > *:nth-child(3){transition-delay:.25s;}
.reveal-stagger.in > *:nth-child(4){transition-delay:.35s;}
.reveal-stagger.in > *:nth-child(5){transition-delay:.45s;}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:64px;
  background: rgba(7,7,15,0.55);
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  border-bottom:1px solid transparent;
  transition: background .3s var(--ease), border-color .3s var(--ease);
}
.nav.scrolled{
  background: rgba(7,7,15,0.85);
  border-bottom:1px solid var(--line-2);
}
.nav-inner{
  max-width:1200px;margin:0 auto;height:100%;padding:0 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav-logo{
  display:flex;align-items:center;gap:10px;
}
.nav-logo .mark{
  width:28px;height:28px;border-radius:6px;
  background: radial-gradient(circle at 30% 30%, #1a0a3a, #07070F 80%);
  border:1px solid var(--line-2);
  position:relative;
  display:grid;place-items:center;
}
.nav-logo .mark::after{
  content:'';width:8px;height:8px;background:var(--purple);
  transform:rotate(45deg);border-radius:1px;
  box-shadow:0 0 12px var(--purple);
}
.nav-logo .word{font-family:var(--font-display);font-size:24px;letter-spacing:.04em;}
.nav-logo .word small{
  display:block;font-family:var(--font-ui);font-size:7px;letter-spacing:4px;
  color:var(--purple);margin-top:-4px;
}
.nav-links{display:flex;gap:30px;align-items:center;}
.nav-links a{
  font-size:10px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--muted);transition:color .2s var(--ease);
  position:relative;padding:6px 0;
}
.nav-links a:hover{color:var(--text);}
.nav-links a::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--purple);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-cta{padding:10px 18px;font-size:10px;min-height:0;}
.nav-burger{display:none;width:38px;height:38px;align-items:center;justify-content:center;border:1px solid var(--line-2);border-radius:6px;}
.nav-burger span{display:block;width:18px;height:1.5px;background:var(--text);position:relative;}
.nav-burger span::before,.nav-burger span::after{content:'';position:absolute;left:0;width:18px;height:1.5px;background:var(--text);}
.nav-burger span::before{top:-5px;}
.nav-burger span::after{top:5px;}

.mobile-menu{
  position:fixed;top:0;right:0;bottom:0;width:80%;max-width:340px;
  background:rgba(7,7,15,0.97);backdrop-filter:blur(20px);
  z-index:200;
  border-left:1px solid var(--line-2);
  padding:80px 28px 28px;
  transform:translateX(100%);transition:transform .35s var(--ease);
  display:flex;flex-direction:column;gap:8px;
}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{
  padding:18px 0;border-bottom:1px solid var(--line);
  font-size:14px;letter-spacing:2.5px;text-transform:uppercase;
}
.mobile-menu .close{
  position:absolute;top:18px;right:18px;width:38px;height:38px;
  display:grid;place-items:center;border:1px solid var(--line-2);border-radius:6px;
  font-size:22px;line-height:1;
}
.menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:150;opacity:0;pointer-events:none;transition:opacity .3s;}
.menu-overlay.open{opacity:1;pointer-events:auto;}

/* ===== HERO ===== */
.hero{
  min-height:100vh;
  padding:120px 0 80px;
  position:relative;
  overflow:hidden;
  display:flex;align-items:center;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 70% 30%, rgba(155,79,244,0.18), transparent 55%),
    radial-gradient(ellipse at 20% 80%, rgba(75,139,255,0.08), transparent 55%),
    var(--bg);
  z-index:0;
}
.hero-bg::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 50%, rgba(155,79,244,0.12), transparent 35%),
    radial-gradient(circle at 80% 70%, rgba(75,139,255,0.08), transparent 40%);
  animation: hero-mist 14s ease-in-out infinite alternate;
}
@keyframes hero-mist{
  0%  {transform:scale(1) translate(0,0);}
  100%{transform:scale(1.15) translate(-3%, 2%);}
}
#particles{position:absolute;inset:0;z-index:1;pointer-events:none;}

.hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns: 1fr 1fr;gap:56px;align-items:center;
  width:100%;
}
.hero-text{max-width:680px;}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;border:1px solid var(--line-2);
  background:rgba(155,79,244,0.06);
  border-radius:999px;
  font-size:9px;letter-spacing:3px;
  color:var(--purple-3);text-transform:uppercase;
  opacity:0;animation: fadeUp .8s var(--ease-out) .3s forwards;
}
.hero-badge .dot{
  width:6px;height:6px;background:var(--purple);border-radius:50%;
  box-shadow:0 0 10px var(--purple);
  animation:pulseDot 1.6s infinite;
}
@keyframes pulseDot{
  0%,100%{opacity:1;transform:scale(1);}
  50%   {opacity:.5;transform:scale(.85);}
}

.hero h1{
  font-family:var(--font-display);
  font-size: clamp(56px, 9vw, 112px);
  line-height:0.92;letter-spacing:.01em;
  margin:24px 0 0;font-weight:400;
}
.hero h1 .ln1, .hero h1 .ln2, .hero h1 .ln3{
  display:block;opacity:0;transform:translateY(40px);
  animation: heroLine .9s var(--ease-out) forwards;
}
.hero h1 .ln1{animation-delay:.45s;}
.hero h1 .ln2{animation-delay:.65s; padding-left:.5ch;}
.hero h1 .ln3{
  animation-delay:.85s;
  font-size: .68em;
  color: var(--purple-3);
  margin-top:.1em;
  letter-spacing:.01em;
}
.hero h1 .ln3 em{font-style:normal;color:var(--purple);
  text-shadow:0 2px 0 rgba(0,0,0,.7), 0 0 30px rgba(155,79,244,.4);}
.hero h1 .ln2 em{font-style:normal;color:var(--purple);
  text-shadow:0 2px 0 rgba(0,0,0,.7), 0 0 30px rgba(155,79,244,.4);}

@keyframes heroLine{to{opacity:1;transform:translateY(0);}}

.hero p.lead{
  color:var(--muted);font-size:12px;letter-spacing:2px;
  line-height:1.9;text-transform:uppercase;
  margin:28px 0 32px;max-width:440px;
  opacity:0;animation:fadeUp .8s var(--ease-out) 1.05s forwards;
}
.hero-ctas{
  display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;animation:fadeUp .8s var(--ease-out) 1.25s forwards;
}
.hero-trust{
  display:flex;align-items:center;gap:16px;margin-top:32px;
  opacity:0;animation:fadeUp .8s var(--ease-out) 1.5s forwards;
  font-size:10px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;
}
.hero-trust .stars{color:var(--purple);letter-spacing:2px;font-size:12px;}

@keyframes fadeUp{to{opacity:1;transform:translateY(0);}}

/* hero visual side */
.hero-visual{
  position:relative;
  aspect-ratio: 1/1;
  max-width:520px;
  margin-left:auto;
  opacity:0;animation:fadeUp 1.2s var(--ease-out) .9s forwards;
}
.hero-visual .frame{
  position:absolute;inset:0;
  border-radius:50%;
  overflow:hidden;
  box-shadow: 0 30px 80px -20px rgba(155,79,244,.4),
              inset 0 0 0 1px rgba(155,79,244,.25);
  transform: perspective(1200px) rotateY(-6deg) rotateX(3deg);
  transition: transform .6s var(--ease);
}
.hero-visual:hover .frame{transform:perspective(1200px) rotateY(-3deg) rotateX(1deg) scale(1.02);}
.hero-visual .frame img{
  width:100%;height:100%;object-fit:cover;
  filter: brightness(.85) saturate(.95);
}
.hero-visual .ring{
  position:absolute;inset:-2%;border-radius:50%;
  border:1px solid rgba(155,79,244,.35);
  animation:spin 30s linear infinite;
}
.hero-visual .ring::before{
  content:'';position:absolute;top:50%;left:-4px;width:8px;height:8px;
  background:var(--purple);border-radius:50%;box-shadow:0 0 18px var(--purple);
}
.hero-visual .ring-2{
  position:absolute;inset:-6%;border-radius:50%;
  border:1px dashed rgba(75,139,255,.25);
  animation:spin 50s linear infinite reverse;
}
@keyframes spin{to{transform:rotate(360deg);}}

.hero-visual .floater{
  position:absolute;background:var(--bg-soft);
  border:1px solid var(--line-2);border-radius:8px;
  padding:10px 14px;
  display:flex;align-items:center;gap:10px;
  font-size:9px;letter-spacing:2px;text-transform:uppercase;
  backdrop-filter:blur(10px);
  box-shadow: 0 8px 24px rgba(0,0,0,.5);
}
.hero-visual .floater .ico{width:24px;height:24px;border-radius:6px;background:rgba(155,79,244,.18);display:grid;place-items:center;color:var(--purple);}
.hero-visual .f1{top:8%;left:-6%;animation:float1 6s ease-in-out infinite;}
.hero-visual .f2{bottom:14%;right:-8%;animation:float1 7s ease-in-out infinite -2s;}
.hero-visual .f3{bottom:-4%;left:8%;animation:float1 8s ease-in-out infinite -4s;}
@keyframes float1{
  0%,100%{transform:translateY(0);}
  50%    {transform:translateY(-8px);}
}

/* ===== MARQUEE ===== */
.marquee{
  height:44px;
  background:var(--bg-soft);
  border-top:1px solid var(--line-2);
  border-bottom:1px solid var(--line-2);
  overflow:hidden;
  position:relative;
  display:flex;align-items:center;
}
.marquee-track{
  display:flex;gap:48px;
  white-space:nowrap;
  animation: marquee 30s linear infinite;
  font-size:10px;letter-spacing:3px;
  color:var(--purple);font-weight:600;
}
.marquee-track span{display:inline-flex;align-items:center;gap:14px;}
.marquee-track span::after{content:'◆';color:var(--purple-2);font-size:8px;}
@keyframes marquee{
  from{transform:translateX(0);}
  to  {transform:translateX(-33.333%);}
}

/* ===== BEFORE / AFTER ===== */
.ba-wrap{
  position:relative;
  max-width:1100px;margin:0 auto;
  aspect-ratio: 16/9;
  border-radius:14px;overflow:hidden;
  border:1px solid var(--line-2);
  box-shadow: 0 30px 80px -30px rgba(0,0,0,.8);
  user-select:none;touch-action:pan-y;
}
.ba-img{position:absolute;inset:0;background-position:center;background-size:cover;}
.ba-before{filter: grayscale(70%) saturate(.5) brightness(.55) contrast(1.1);}
.ba-after{
  clip-path: inset(0 calc(100% - var(--split-pos, 50%)) 0 0);
}
.ba-label{
  position:absolute;top:18px;
  padding:6px 12px;border-radius:999px;
  font-size:9px;letter-spacing:3px;text-transform:uppercase;
  background:rgba(7,7,15,.7);backdrop-filter:blur(8px);
  border:1px solid var(--line-2);
}
.ba-label.before{left:18px;color:var(--muted);}
.ba-label.after{
  right:18px;color:#fff;background:rgba(155,79,244,.85);
  border-color:rgba(255,255,255,.2);
}
.ba-handle{
  position:absolute;top:0;bottom:0;
  left:var(--split-pos, 50%);
  width:2px;background:rgba(255,255,255,.85);
  transform:translateX(-50%);
  box-shadow:0 0 18px rgba(155,79,244,.6);
  pointer-events:none;
}
.ba-knob{
  position:absolute;top:50%;left:var(--split-pos, 50%);
  width:48px;height:48px;border-radius:50%;
  transform:translate(-50%,-50%);
  background:#fff;
  display:grid;place-items:center;
  cursor:ew-resize;
  box-shadow: 0 0 0 4px rgba(155,79,244,.4), 0 10px 30px rgba(0,0,0,.5);
  z-index:2;
}
.ba-knob::before{
  content:'⟷';font-size:18px;color:var(--bg);font-weight:700;
}

.ba-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px;
  max-width:900px;margin-left:auto;margin-right:auto;
}
.ba-stat{
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-left:2px solid var(--purple);
  border-radius:8px;
  padding:18px 20px;
  display:flex;align-items:center;gap:14px;
}
.ba-stat .ico{
  width:40px;height:40px;border-radius:8px;
  background:rgba(155,79,244,.12);color:var(--purple);
  display:grid;place-items:center;
}
.ba-stat strong{font-family:var(--font-display);font-size:22px;letter-spacing:.02em;display:block;}
.ba-stat span{font-size:9px;letter-spacing:2.5px;color:var(--muted);text-transform:uppercase;}

/* ===== HOW IT WORKS ===== */
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  position:relative;
}
.steps::before{
  content:'';position:absolute;
  top:60px;left:14%;right:14%;
  border-top:1px dashed rgba(155,79,244,.5);
  z-index:0;
}
.step{
  position:relative;z-index:1;
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-top:1px solid var(--purple);
  border-radius:10px;
  padding:32px 28px;
  transition: transform .3s var(--ease), border-color .3s;
}
.step:hover{transform:translateY(-4px);border-color:var(--purple);}
.step .num{
  font-family:var(--font-display);font-size:14px;color:var(--purple);
  letter-spacing:3px;
}
.step .ico{
  width:56px;height:56px;border-radius:14px;
  background: linear-gradient(135deg, rgba(155,79,244,.2), rgba(75,139,255,.08));
  border:1px solid var(--line-2);
  display:grid;place-items:center;color:var(--purple);
  margin:8px 0 18px;
}
.step h3{
  font-family:var(--font-display);font-size:26px;letter-spacing:.03em;
  margin:0 0 10px;font-weight:400;
}
.step p{color:var(--muted);font-size:11px;letter-spacing:1.2px;line-height:1.8;margin:0;}

/* ===== STATS COUNTER ===== */
.stats-strip{
  background: var(--bg-soft);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:50px 0;
  position:relative;overflow:hidden;
}
.stats-strip::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 50%, rgba(155,79,244,.08), transparent 40%),
    radial-gradient(circle at 80% 50%, rgba(75,139,255,.05), transparent 40%);
  pointer-events:none;
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  position:relative;
}
.stat{
  text-align:center;padding:10px 12px;
  position:relative;
}
.stat + .stat::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;
  width:1px;background:var(--line-2);
}
.stat .num{
  font-family:var(--font-display);font-size:clamp(40px,5vw,64px);
  color:var(--purple);letter-spacing:.02em;line-height:1;
  text-shadow: 0 0 30px rgba(155,79,244,.4);
}
.stat .lbl{
  font-size:9px;letter-spacing:3px;color:var(--muted);
  text-transform:uppercase;margin-top:8px;
}

/* ===== PACKAGES ===== */
.packages{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  align-items:stretch;
}
.pkg{
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-top:1px solid var(--purple);
  border-radius:12px;
  padding:32px 28px;
  display:flex;flex-direction:column;gap:18px;
  position:relative;
  transition: transform .3s var(--ease), border-color .3s, box-shadow .3s;
}
.pkg:hover{
  transform:translateY(-8px);
  border-color:var(--purple);
  box-shadow: 0 30px 60px -30px rgba(155,79,244,.5);
}
.pkg.featured{
  border:1px solid var(--purple);
  background: linear-gradient(180deg, rgba(155,79,244,.05), var(--bg-soft) 30%);
  transform:scale(1.02);
}
.pkg.featured:hover{transform: translateY(-8px) scale(1.02);}
.pkg .badge{
  position:absolute;top:-12px;right:24px;
  background: linear-gradient(180deg, var(--purple), var(--purple-2));
  padding:5px 12px;border-radius:999px;
  font-size:8px;letter-spacing:3px;font-weight:700;
  color:#fff;
  box-shadow: 0 8px 24px -6px rgba(155,79,244,.6);
}
.pkg .ico{
  width:54px;height:60px;
  display:grid;place-items:center;
  background:
    linear-gradient(180deg, rgba(155,79,244,.12), rgba(155,79,244,.04));
  border:1px solid var(--line-2);
  clip-path: polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  color:var(--purple);
}
.pkg .name{font-family:var(--font-display);font-size:36px;letter-spacing:.04em;line-height:1;}
.pkg .price{font-family:var(--font-display);font-size:56px;letter-spacing:.02em;line-height:1;color:var(--purple);}
.pkg .price small{font-size:18px;color:var(--muted);font-family:var(--font-ui);font-weight:300;letter-spacing:2px;}
.pkg .sub{font-size:9px;letter-spacing:3px;color:var(--purple-3);text-transform:uppercase;}
.pkg ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;flex-grow:1;}
.pkg ul li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:11px;color:var(--text);letter-spacing:1px;line-height:1.6;
}
.pkg ul li::before{
  content:'';display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--purple);margin-top:6px;flex-shrink:0;
  box-shadow:0 0 8px var(--purple);
}

.addons{
  display:flex;justify-content:center;gap:12px;flex-wrap:wrap;
  margin-top:36px;
}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 18px;border-radius:999px;
  border:1px solid var(--line-2);
  background:transparent;
  color:var(--text);
  font-size:10px;letter-spacing:2.5px;text-transform:uppercase;
  cursor:pointer;
  transition: all .25s var(--ease);
  min-height:44px;
}
.chip:hover{border-color:var(--purple);}
.chip.on{
  background:var(--purple);border-color:var(--purple);color:#fff;
  box-shadow:0 8px 24px -8px rgba(155,79,244,.6);
}
.chip .price-tag{color:var(--purple-3);font-weight:700;}
.chip.on .price-tag{color:#fff;}

/* floating selection bar */
.float-bar{
  position:fixed;bottom:18px;left:50%;transform:translate(-50%, 120%);
  background: rgba(13,13,26,.92);
  backdrop-filter:blur(16px);
  border:1px solid var(--line-2);
  border-radius:14px;
  padding:14px 14px 14px 22px;
  display:flex;align-items:center;gap:22px;
  box-shadow: 0 30px 80px -10px rgba(0,0,0,.8), 0 0 0 1px rgba(155,79,244,.18);
  z-index:80;
  transition: transform .4s var(--ease);
  max-width:calc(100vw - 32px);
}
.float-bar.show{transform:translate(-50%,0);}
.float-bar .info{
  display:flex;flex-direction:column;gap:2px;
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
}
.float-bar .info .sel{font-family:var(--font-display);font-size:18px;letter-spacing:.04em;color:var(--text);text-transform:none;}
.float-bar .total{font-family:var(--font-display);font-size:24px;color:var(--purple);letter-spacing:.04em;}

/* ===== BOOKING ===== */
.booking-grid{
  display:grid;grid-template-columns: 1.05fr 1fr;gap:32px;
}
.booking-col{
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-radius:12px;
  padding:28px;
}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.cal-head h3{font-family:var(--font-display);font-size:28px;letter-spacing:.04em;margin:0;}
.cal-nav{display:flex;gap:8px;}
.cal-nav button{
  width:38px;height:38px;border:1px solid var(--line-2);border-radius:8px;
  display:grid;place-items:center;color:var(--text);
  transition:all .2s;
}
.cal-nav button:hover{border-color:var(--purple);background:rgba(155,79,244,.08);}
.cal-nav button:disabled{opacity:.3;cursor:not-allowed;}
.cal-weekdays{
  display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:10px;
}
.cal-weekdays div{
  text-align:center;font-size:9px;color:var(--muted);letter-spacing:2px;
  padding:6px 0;text-transform:uppercase;
}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.cal-cell{
  aspect-ratio:1;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:8px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:18px;letter-spacing:.02em;
  cursor:pointer;
  transition:all .2s var(--ease);
  position:relative;
  user-select:none;
  min-height:44px;
}
.cal-cell:not(.disabled):not(.full):hover{
  border-color:var(--purple);
  background:rgba(155,79,244,.08);
  transform:translateY(-2px);
}
.cal-cell.disabled{
  color:var(--muted-2);cursor:not-allowed;
  background:transparent;border-color:transparent;
}
.cal-cell.full{
  color:var(--danger);cursor:not-allowed;
  background:rgba(255,77,109,.08);
  border-color:rgba(255,77,109,.25);
}
.cal-cell.full .tag{
  font-family:var(--font-ui);font-size:7px;letter-spacing:1.5px;color:var(--danger);
}
.cal-cell.selected{
  background: linear-gradient(180deg, var(--purple), var(--purple-2));
  border-color:var(--purple);color:#fff;
  box-shadow: 0 10px 24px -8px rgba(155,79,244,.7), inset 0 1px 0 rgba(255,255,255,.2);
  transform: translateY(-2px) scale(1.02);
}
.cal-cell.today{
  border-color:var(--purple);
}
.cal-cell .dot{
  width:4px;height:4px;border-radius:50%;background:var(--purple);margin-top:2px;opacity:.6;
}

.slots-wrap{
  margin-top:24px;perspective:1000px;
}
.slots-label{
  font-size:9px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;
  margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;
}
.slots-label .selected-date{color:var(--purple-3);}
.slots{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
}
.slot{
  padding:14px 6px;border-radius:8px;
  background:var(--bg-card);
  border:1px solid var(--line-2);
  font-size:11px;letter-spacing:1.5px;
  font-weight:600;
  color:var(--text);
  cursor:pointer;
  transition:all .2s var(--ease);
  display:flex;flex-direction:column;align-items:center;gap:4px;
  min-height:60px;
  opacity:0;transform: translateY(20px) rotateX(-30deg);
  animation: slotIn .4s var(--ease-out) forwards;
}
.slot:nth-child(1){animation-delay:.05s;}
.slot:nth-child(2){animation-delay:.15s;}
.slot:nth-child(3){animation-delay:.25s;}
.slot:nth-child(4){animation-delay:.35s;}
@keyframes slotIn{to{opacity:1;transform:translateY(0) rotateX(0);}}
.slot:hover:not(.taken){background:rgba(155,79,244,.12);border-color:var(--purple);}
.slot.selected{
  background: linear-gradient(180deg, var(--purple), var(--purple-2));
  border-color:var(--purple);color:#fff;
  transform:scale(1.05);
  box-shadow:0 10px 24px -8px rgba(155,79,244,.6);
}
.slot.taken{
  opacity:.45;cursor:not-allowed;
  background:transparent;color:var(--muted);
  border-style:dashed;
}
.slot .tag{font-size:8px;letter-spacing:2px;color:var(--muted);}
.slot.taken .tag{color:var(--danger);}

/* booking form */
.booking-form{
  display:flex;flex-direction:column;gap:16px;
}
.field{display:flex;flex-direction:column;gap:6px;}
.field label{
  font-size:9px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;
}
.field input, .field textarea{
  width:100%;
  padding:14px 14px;
  background:var(--bg-card);
  border:1px solid var(--line-2);
  border-radius:8px;
  color:var(--text);
  font-size:13px;letter-spacing:.5px;
  transition: border-color .2s, box-shadow .2s, background .2s;
}
.field input:focus, .field textarea:focus{
  outline:none;
  border-color:var(--purple);
  background:rgba(155,79,244,.05);
  box-shadow: 0 0 0 4px rgba(155,79,244,.12);
}
.field textarea{resize:vertical;min-height:80px;font-family:var(--font-ui);}
.field.error input, .field.error textarea{border-color:var(--danger);}
.field .err-msg{font-size:9px;color:var(--danger);letter-spacing:2px;text-transform:uppercase;margin-top:2px;display:none;}
.field.error .err-msg{display:block;}

.summary{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:8px;
  padding:14px 16px;
  display:flex;flex-direction:column;gap:8px;
}
.summary-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
}
.summary-row .lbl{color:var(--muted);}
.summary-row .val{color:var(--text);}
.summary-row.total{
  border-top:1px dashed var(--line-2);padding-top:10px;margin-top:4px;
  font-family:var(--font-display);font-size:24px;letter-spacing:.04em;text-transform:none;
}
.summary-row.total .val{color:var(--purple);}

.placeholder-box{
  border:1px dashed var(--line-2);
  border-radius:10px;padding:36px 20px;
  text-align:center;color:var(--muted);
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
}

/* success overlay */
.success-overlay{
  position:fixed;inset:0;z-index:10000;
  background:rgba(7,7,15,.92);
  backdrop-filter:blur(14px);
  display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease);
}
.success-overlay.show{opacity:1;pointer-events:auto;}
.success-card{
  background:var(--bg-soft);
  border:1px solid var(--line-2);
  border-radius:16px;
  padding:48px 36px;
  max-width:520px;width:100%;text-align:center;
  transform:scale(.85);opacity:0;
  transition:opacity .5s var(--ease) .15s, transform .5s var(--ease-out) .15s;
  position:relative;overflow:hidden;
}
.success-overlay.show .success-card{transform:scale(1);opacity:1;}
.success-card::before{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:radial-gradient(circle at 50% 30%, rgba(155,79,244,.25), transparent 40%);
  pointer-events:none;
}
.success-card h2{
  font-family:var(--font-display);font-size:54px;letter-spacing:.03em;margin:0;
  position:relative;
}
.success-card .ghost{font-size:50px;margin-bottom:10px;display:inline-block;animation:floaty 2s ease-in-out infinite;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-6px);}}
.success-card p{color:var(--muted);font-size:11px;letter-spacing:1.5px;line-height:1.8;margin:14px 0;position:relative;}
.success-card .phone{color:var(--purple);font-family:var(--font-display);font-size:24px;letter-spacing:.04em;}
.success-card .close-x{
  position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;
  border:1px solid var(--line-2);display:grid;place-items:center;font-size:18px;color:var(--muted);
}

#confetti{position:absolute;inset:0;pointer-events:none;}

/* ===== ABOUT ===== */
.about-grid{
  display:grid;grid-template-columns: 1fr 1fr;gap:48px;align-items:center;
}
.about-text h2{font-size:clamp(48px,6vw,72px);margin:8px 0 20px;}
.about-text p{color:var(--muted);font-size:12px;letter-spacing:1.2px;line-height:2;margin:0 0 14px;}
.about-icons{
  display:flex;gap:10px;margin-top:24px;flex-wrap:wrap;
}
.about-icon{
  flex:1;min-width:130px;
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-left:2px solid var(--purple);
  border-radius:8px;
  padding:14px;display:flex;align-items:center;gap:10px;
  font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);
}
.about-icon .ico{
  width:32px;height:32px;border-radius:8px;
  background:rgba(155,79,244,.12);color:var(--purple);
  display:grid;place-items:center;flex-shrink:0;
}

.photo-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
  perspective:1000px;
}
.photo-card{
  position:relative;border-radius:12px;overflow:hidden;
  border:1px solid var(--line-2);
  aspect-ratio: 3/4;
  transition: transform .3s var(--ease), border-color .3s, box-shadow .3s;
  transform-style:preserve-3d;
  cursor:pointer;
}
.photo-card.tall{grid-row:span 2;}
.photo-card:hover{
  border-color:var(--purple);
  box-shadow: 0 30px 60px -20px rgba(155,79,244,.45);
}
.photo-card img{
  width:100%;height:100%;object-fit:cover;
  transition: transform .6s var(--ease);
  display:block;
}
.photo-card:hover img{transform:scale(1.05);}
.photo-card .overlay{
  position:absolute;inset:0;
  background: linear-gradient(180deg, transparent 50%, rgba(7,7,15,.85) 100%);
  display:flex;align-items:flex-end;padding:16px;
  font-size:9px;letter-spacing:2px;color:var(--text);text-transform:uppercase;
}

/* ===== PHOTO GALLERY STRIP ===== */
.gallery-strip{
  display:flex;gap:0;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  -ms-overflow-style:none;
  cursor:grab;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.gallery-strip::-webkit-scrollbar{display:none;}
.gallery-strip.grabbing{cursor:grabbing;}
.gallery-strip .gimg{
  flex:0 0 auto;
  height:280px;width:auto;
  scroll-snap-align:start;
  position:relative;
}
.gallery-strip .gimg img{height:100%;width:auto;display:block;}
.gallery-strip .gimg::after{
  content:'PHANTOM AUTO DETAILING';
  position:absolute;left:14px;bottom:10px;
  font-family:var(--font-ui);font-size:7px;letter-spacing:3px;
  color:rgba(255,255,255,.35);
}
.gallery-strip .gimg::before{
  content:'';position:absolute;inset:0;
  background: linear-gradient(180deg, transparent 60%, rgba(7,7,15,.7) 100%);
  pointer-events:none;
}

/* ===== FINAL CTA + FOOTER ===== */
.final-cta{
  padding:100px 0;text-align:center;position:relative;overflow:hidden;
}
.final-cta::before{
  content:'';position:absolute;inset:0;
  background: radial-gradient(ellipse at 50% 50%, rgba(155,79,244,.15), transparent 60%);
  pointer-events:none;
}
.final-cta h2{font-size:clamp(40px,6vw,72px);margin:0 0 24px;}
.contact-row{
  display:flex;justify-content:center;gap:28px;margin-top:40px;
  font-size:11px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;flex-wrap:wrap;
}
.contact-row a{display:inline-flex;gap:8px;align-items:center;color:var(--text);transition:color .2s;}
.contact-row a:hover{color:var(--purple);}

.footer{
  background: var(--bg-soft);
  border-top:1px solid var(--line);
  padding:60px 0 24px;
}
.footer-cols{
  display:grid;grid-template-columns: 1.2fr 1fr 1fr;gap:48px;
  margin-bottom:48px;
}
.footer-col h4{
  font-size:9px;letter-spacing:3px;color:var(--purple);text-transform:uppercase;
  margin:0 0 16px;font-weight:600;
}
.footer-col a, .footer-col p{
  display:block;color:var(--muted);font-size:10px;
  letter-spacing:1.2px;line-height:2;margin:0;
}
.footer-col a:hover{color:var(--text);}
.footer-logo .word{font-family:var(--font-display);font-size:32px;letter-spacing:.04em;}
.footer-logo small{
  display:block;font-size:8px;letter-spacing:4px;color:var(--purple);margin-top:-2px;
}
.footer-bottom{
  border-top:1px solid var(--line);
  padding-top:20px;
  display:flex;justify-content:space-between;gap:16px;
  font-size:8px;letter-spacing:2px;color:var(--muted-2);text-transform:uppercase;flex-wrap:wrap;
}
.footer-bottom a{color:var(--purple);}
.footer-bottom a:hover{color:var(--purple-3);}

/* ===== ADMIN PANEL ===== */
.admin-panel{
  position:fixed;inset:0;z-index:10001;
  background:rgba(7,7,15,.96);backdrop-filter:blur(20px);
  display:none;flex-direction:column;
  padding:24px;overflow:auto;
}
.admin-panel.open{display:flex;}
.admin-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:24px;
  padding-bottom:16px;border-bottom:1px solid var(--line-2);
}
.admin-header h2{font-family:var(--font-display);font-size:32px;margin:0;letter-spacing:.04em;}
.admin-actions{display:flex;gap:10px;}
.admin-btn{
  padding:8px 14px;border:1px solid var(--line-2);border-radius:6px;
  font-size:9px;letter-spacing:2px;text-transform:uppercase;
  color:var(--text);transition:all .2s;
}
.admin-btn:hover{border-color:var(--purple);background:rgba(155,79,244,.1);}
.admin-btn.danger{border-color:rgba(255,77,109,.4);color:var(--danger);}
.admin-table{
  width:100%;border-collapse:collapse;
  font-size:11px;
}
.admin-table th{
  text-align:left;padding:10px 12px;
  font-size:9px;letter-spacing:2px;color:var(--purple);text-transform:uppercase;
  border-bottom:1px solid var(--line-2);
}
.admin-table td{padding:14px 12px;border-bottom:1px solid var(--line);vertical-align:middle;}
.admin-table tr:hover{background:rgba(155,79,244,.04);}
.admin-table .pill{
  display:inline-block;padding:3px 8px;border-radius:999px;
  font-size:8px;letter-spacing:2px;
}
.admin-table .pill.pending{background:rgba(155,79,244,.18);color:var(--purple-3);}
.admin-table .pill.completed{background:rgba(75,255,176,.18);color:var(--ok);}
.admin-table .pill.cancelled{background:rgba(255,77,109,.15);color:var(--danger);}
.admin-empty{text-align:center;padding:80px 20px;color:var(--muted);font-size:11px;letter-spacing:2px;text-transform:uppercase;}
.admin-hint{
  position:fixed;bottom:18px;right:18px;z-index:90;
  background:var(--bg-soft);border:1px solid var(--line-2);
  padding:8px 12px;border-radius:8px;
  font-size:8px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.admin-hint.show{opacity:1;}

/* =========================================================
   HERO STAGE — photo card (right side of hero)
   ========================================================= */
.hero-stage{
  position:relative;
  width:100%;
  max-width:540px;
  aspect-ratio: 4/5;
  margin-left:auto;
  opacity:0;animation:fadeUp 1.2s var(--ease-out) .8s forwards;
  transition: transform .6s var(--ease);
}

.hero-photo-card{
  position:absolute;inset:0;
  border-radius:14px;
  overflow:hidden;
  background:#000;
  box-shadow:
    0 40px 80px -30px rgba(0,0,0,.85),
    0 0 0 1px rgba(155,79,244,.25),
    inset 0 0 0 1px rgba(255,255,255,.04);
  animation: heroPhotoFloat 6s ease-in-out infinite;
}
@keyframes heroPhotoFloat{
  0%,100%{ transform: translateY(0); }
  50%   { transform: translateY(-10px); }
}
.hero-photo-card img{
  width:100%;height:100%;
  object-fit:cover;
  object-position: 70% center;
  display:block;
  filter: contrast(1.08) saturate(.88) brightness(.92);
  transform: scale(1.04);
  transition: transform 1.2s var(--ease);
}
.hero-stage:hover .hero-photo-card img{ transform: scale(1.08); }

/* purple color grade overlay */
.hero-photo-tint{
  position:absolute;inset:0;
  background: linear-gradient(160deg,
    rgba(80,40,160,.18) 0%,
    rgba(20,10,40,.05) 45%,
    rgba(155,79,244,.16) 100%);
  mix-blend-mode: color;
  pointer-events:none;
}
/* dark cinematic vignette — edges dark, center clear */
.hero-photo-vignette{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 50% 45%,
      transparent 0%,
      transparent 35%,
      rgba(7,7,15,.4) 70%,
      rgba(7,7,15,.85) 100%),
    linear-gradient(180deg,
      rgba(7,7,15,.45) 0%,
      transparent 18%,
      transparent 70%,
      rgba(7,7,15,.7) 100%);
  pointer-events:none;
  mix-blend-mode: multiply;
}

/* corner accent brackets — premium frame feel */
.hero-photo-corner{
  position:absolute;width:28px;height:28px;
  border:1.5px solid var(--purple);
  pointer-events:none;
  opacity:.85;
}
.hero-photo-corner.tl{ top:14px;    left:14px;    border-right:none; border-bottom:none; }
.hero-photo-corner.tr{ top:14px;    right:14px;   border-left:none;  border-bottom:none; }
.hero-photo-corner.bl{ bottom:14px; left:14px;    border-right:none; border-top:none; }
.hero-photo-corner.br{ bottom:14px; right:14px;   border-left:none;  border-top:none; }

/* location badge */
.hero-photo-badge{
  position:absolute;
  bottom:24px;left:24px;
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;
  border-radius:999px;
  background: rgba(7,7,15,.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border:1px solid var(--purple);
  font-family:var(--font-ui);
  font-size:9px;letter-spacing:2.5px;
  text-transform:uppercase;
  color:#fff;
  box-shadow: 0 8px 24px rgba(0,0,0,.6), 0 0 0 4px rgba(155,79,244,.08);
}
.hero-photo-badge .ghost{
  font-size:13px;
  filter: drop-shadow(0 0 8px rgba(155,79,244,.6));
  animation: badgeGhost 3s ease-in-out infinite;
}
@keyframes badgeGhost{
  0%,100%{ transform: translateY(0) rotate(-3deg); }
  50%   { transform: translateY(-2px) rotate(3deg); }
}

/* shared phantom photo tone for new real-photo placements */
.phantom-tone{ filter: contrast(1.08) saturate(.88) brightness(.92); }
.phantom-tone-img{ filter: contrast(1.08) saturate(.88) brightness(.92); }

/* =========================================================
   SLOT COUNTER + new SLOT GRID + SLOT STATES
   ========================================================= */
.slots-counter{
  display:flex;align-items:center;gap:8px;
  font-size:9px;letter-spacing:2.5px;color:var(--purple-3);text-transform:uppercase;
  background: rgba(155,79,244,.08);
  border:1px solid var(--line-2);
  border-radius:8px;
  padding:8px 12px;
  margin-bottom:14px;
}
.slots-counter .dot{
  width:7px;height:7px;border-radius:50%;background:var(--purple);
  box-shadow:0 0 8px var(--purple);
  animation:pulseDot 1.6s infinite;
}
.slots-counter.full{
  color:var(--danger);background:rgba(255,77,109,.08);
  border-color:rgba(255,77,109,.3);
}
.slots-counter.full .dot{background:var(--danger);box-shadow:0 0 8px var(--danger);}

.slots{
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px;
}
.slot{
  padding:10px 8px;
  border-radius:8px;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  min-height:54px;
  text-align:center;
}
.slot .t{font-size:11px;letter-spacing:1px;font-weight:600;color:var(--text);}
.slot .tag{font-size:7px;letter-spacing:2px;color:var(--muted);}
.slot.taken{opacity:.5;cursor:not-allowed;background:transparent;border-style:dashed;}
.slot.taken .t{color:var(--muted);}
.slot.booked .t{color:var(--danger);}
.slot.booked .tag{color:var(--danger);}
.slot.blocked .tag{color:var(--purple-3);}
.slot.past{opacity:.3;font-style:italic;}
.slot.selected{
  background: linear-gradient(180deg, var(--purple), var(--purple-2));
  border-color:var(--purple);color:#fff;
  transform:scale(1.03);
  box-shadow:0 10px 24px -8px rgba(155,79,244,.7);
}
.slot.selected .t, .slot.selected .tag{color:#fff;}

.slots-note{
  margin-top:12px;font-size:9px;letter-spacing:1.5px;
  color:var(--muted);font-style:italic;text-align:center;
  padding:8px;border-top:1px dashed var(--line-2);
}
.hint-up{
  font-size:9px;letter-spacing:2px;color:var(--purple-3);
  text-transform:uppercase;text-align:center;
  padding:8px;background:rgba(155,79,244,.08);border-radius:6px;
}

/* =========================================================
   SUCCESS overlay extra
   ========================================================= */
.success-summary{
  text-align:left;margin:20px auto 18px;max-width:380px;
}
.success-summary .summary-row .lbl{display:flex;align-items:center;gap:6px;}
.phone-link{
  display:inline-block;
  color:var(--purple);
  font-family:var(--font-display);
  font-size:28px;
  letter-spacing:.04em;
  padding:8px 18px;
  border-radius:8px;
  border:1px solid var(--line-2);
  background:rgba(155,79,244,.08);
  margin-top:6px;
  transition:all .2s var(--ease);
}
.phone-link:hover{background:rgba(155,79,244,.18);border-color:var(--purple);}
.success-actions{
  display:flex;gap:10px;justify-content:center;margin-top:22px;flex-wrap:wrap;
}
.success-actions .btn{min-width:180px;}

/* spinner inside submit button */
.spinner{
  display:inline-block;width:14px;height:14px;
  border:2px solid rgba(255,255,255,.3);
  border-top-color:#fff;
  border-radius:50%;
  animation:spin 0.6s linear infinite;
}

/* admin extras */
.admin-table-wrap{overflow-x:auto;}
.admin-select{
  background:var(--bg-card);
  border:1px solid var(--line-2);
  color:var(--text);
  border-radius:6px;
  padding:6px 8px;
  font-size:9px;letter-spacing:1.5px;text-transform:uppercase;
  font-family:var(--font-ui);
}

/* =========================================================
   MOBILE STICKY BOTTOM BAR
   ========================================================= */
.mobile-bottom-bar{
  display:none;
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:9999;
  height:calc(64px + env(safe-area-inset-bottom));
  padding-bottom: env(safe-area-inset-bottom);
  background: var(--purple);
  border-top:1px solid rgba(255,255,255,.15);
  box-shadow: 0 -10px 30px -10px rgba(0,0,0,.6);
}
.mb-half{
  flex:1;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-ui);
  font-weight:700;
  color:#fff;
  text-transform:uppercase;
  letter-spacing:1.5px;
  transition: transform .15s var(--ease), background .15s var(--ease);
}
.mb-call{
  background: #7B2FD4;
  border-right:1px solid rgba(255,255,255,.15);
  font-size:11px;
}
.mb-call .mb-ico{font-size:14px;}
.mb-book{ background: var(--purple); font-size:12px; }
.mb-half:active{ transform: scale(.97); }
@media (max-width: 768px){
  .mobile-bottom-bar{display:flex;}
  body{ padding-bottom:64px; }
  .float-bar{ bottom: calc(80px + env(safe-area-inset-bottom)); }
}

/* ===== RESPONSIVE ===== */
@media (max-width: 960px){
  section{padding:80px 0;}
  .container{padding:0 20px;}
  .nav-links{display:none;}
  .nav-cta{display:none;}
  .nav-burger{display:flex;}
  .hero{padding:96px 0 60px;min-height:auto;}
  .hero-inner{grid-template-columns:1fr;gap:24px;}
  .hero-stage{max-width:480px;margin:0 auto;order:-1;width:95%;}
  .ba-stats{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .steps::before{display:none;}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:24px 0;}
  .stat:nth-child(3)::before, .stat:nth-child(odd)::before{display:none;}
  .packages{grid-template-columns:1fr;}
  .pkg.featured{transform:none;}
  .pkg.featured:hover{transform:translateY(-8px);}
  .booking-grid{grid-template-columns:1fr;}
  .about-grid{grid-template-columns:1fr;gap:40px;}
  .footer-cols{grid-template-columns:1fr;gap:32px;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .gallery-strip .gimg{height:200px;}
  .float-bar{padding:12px 14px;gap:12px;border-radius:10px;left:14px;right:14px;transform:translateY(120%);max-width:none;}
  .float-bar.show{transform:translateY(0);}
  .float-bar .total{font-size:18px;}
  .float-bar .info .sel{font-size:14px;}
  .float-bar .btn{padding:10px 14px;font-size:9px;min-height:40px;}
}
@media (max-width: 768px){
  .hero h1{font-size:54px;line-height:.92;}
  .hero p.lead br{display:none;}
  .hero-ctas{flex-direction:column;align-items:stretch;}
  .hero-ctas .btn{width:100%;}
  .nav{height:56px;}
  .nav-inner{padding:0 18px;}
  .hero-photo-card{ border-radius:12px; }
  .hero-photo-badge{ bottom:18px; left:18px; font-size:8px; padding:7px 12px; }
  .hero-photo-corner{ width:22px; height:22px; }
  /* edge-to-edge gallery */
  .gallery-strip .gimg{height:220px;}
  /* taller calendar cells for touch */
  .cal-cell{min-height:48px;font-size:16px;}
  /* slots stay 2-col already */
  /* package: smaller padding */
  .pkg{padding:24px 20px;}
  .pkg .price{font-size:48px;}
  .pkg .name{font-size:30px;}
  /* section heads tighter */
  section{padding:64px 0;}
  .section-head{margin-bottom:40px;}
  .section-head h2{font-size:clamp(40px,8vw,60px);}
  /* before/after taller */
  .ba-wrap{aspect-ratio: 3/4;}
  .ba-knob{width:52px;height:52px;}
  .ba-knob::before{font-size:20px;}
}
@media (max-width: 520px){
  .container{padding:0 16px;}
  .hero h1{font-size:46px;}
  .slots{grid-template-columns:1fr;}
  .slot{flex-direction:row;justify-content:space-between;padding:14px 16px;}
  .slot .tag{font-size:8px;}
  .photo-grid{grid-template-columns:1fr 1fr;}
  .photo-card.tall{grid-row:auto;aspect-ratio:3/4;}
  .float-bar{flex-wrap:wrap;justify-content:space-between;}
  .booking-col{padding:20px 16px;}
  .success-card{padding:36px 22px;}
  .success-card h2{font-size:44px;}
  .success-actions .btn{width:100%;min-width:0;}
  .phone-link{font-size:24px;}
  .contact-row{flex-direction:column;gap:12px;}
}


/* =========================================================
   FINAL AUDIT ADDITIONS
   ========================================================= */

/* Confirmation code on success screen */
.conf-code{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  margin:18px auto 12px;
  padding:18px 22px;
  background: linear-gradient(180deg, rgba(155,79,244,.18), rgba(155,79,244,.06));
  border:1px solid var(--purple);
  border-radius:12px;
  max-width:340px;
  box-shadow: 0 8px 24px -8px rgba(155,79,244,.4), inset 0 1px 0 rgba(255,255,255,.06);
}
.conf-code-lbl{
  font-size:9px;letter-spacing:3px;color:var(--purple-3);text-transform:uppercase;
}
.conf-code-val{
  font-family:var(--font-display);
  font-size:38px;letter-spacing:.08em;
  color:#fff;line-height:1;
  text-shadow: 0 0 20px rgba(155,79,244,.6);
}
.conf-code-note{
  font-size:9px;letter-spacing:1.2px;color:var(--muted);
  text-align:center;line-height:1.5;margin-top:4px;
  font-style:italic;
}

/* Discount banner inside booking form */
.discount-banner{
  background: linear-gradient(135deg, rgba(75,255,176,.15), rgba(155,79,244,.12));
  border:1px solid #4BFFB0;
  border-radius:10px;
  padding:14px 16px;
  font-size:12px;letter-spacing:1px;color:var(--text);
  display:flex;align-items:center;gap:8px;
  margin-bottom:6px;
  animation: bannerPop .6s var(--ease-out);
}
.discount-banner strong{color:#4BFFB0;font-weight:700;}
@keyframes bannerPop{
  0%   { opacity:0; transform: translateY(-8px) scale(.96); }
  100% { opacity:1; transform: translateY(0) scale(1); }
}

/* Discount row on success screen */
.discount-applied{
  background: rgba(75,255,176,.1);
  border:1px solid rgba(75,255,176,.3);
  border-radius:10px;
  padding:12px 14px;margin:6px auto 14px;
  max-width:340px;
  font-size:11px;letter-spacing:1px;color:#4BFFB0;
}
.discount-applied strong{color:#4BFFB0;}

/* Service area note in form */
.service-area-note{
  font-size:10px;letter-spacing:2px;color:var(--purple-3);text-transform:uppercase;
  padding:8px 10px;
  background:rgba(155,79,244,.05);
  border:1px dashed rgba(155,79,244,.3);
  border-radius:6px;
  display:flex;align-items:center;gap:6px;
  margin-top:-6px;
}

/* Admin stats row */
.admin-stats{
  display:grid;grid-template-columns:repeat(5,1fr);gap:10px;
  margin-bottom:18px;
}
.astat{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:8px;padding:14px 16px;
  text-align:center;
}
.astat .albl{
  font-size:9px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;
  margin-bottom:4px;
}
.astat .aval{
  font-family:var(--font-display);font-size:26px;letter-spacing:.04em;color:var(--text);
}

/* Mobile-first input + calendar + slot improvements */
@media (max-width: 768px){
  /* 16px font on inputs prevents iOS Safari zoom on focus */
  .field input, .field textarea{
    font-size:16px !important;
    padding:16px 14px;
    min-height:56px;
  }
  .field textarea{ min-height:80px; }
  .field label{ font-size:10px; }

  /* Calendar: 7 columns must fit phone width with 44px touch targets */
  .cal-grid{ gap:4px; }
  .cal-weekdays{ gap:4px; }
  .cal-cell{
    min-height:48px;
    font-size:18px;
    border-radius:6px;
  }
  .cal-cell .tag{ font-size:6px; letter-spacing:1px; }

  /* Time slots: full-width list, 64px height, single-line text */
  .slots{ grid-template-columns:1fr; gap:8px; }
  .slot{
    flex-direction:row;justify-content:space-between;
    min-height:64px;
    padding:14px 16px;
  }
  .slot .t{ font-size:clamp(13px, 3.5vw, 15px); white-space:nowrap; }
  .slot .tag{ font-size:9px; }

  /* CONFIRM button full width 64px */
  .booking-form .btn-block{
    min-height:64px;
    font-size:13px;
  }

  /* Footer clears the 64px sticky bar */
  .footer{ padding-bottom:90px; }

  /* Admin stats responsive */
  .admin-stats{ grid-template-columns:repeat(2,1fr); }
  .astat{ padding:10px 12px; }
  .astat .aval{ font-size:20px; }

  /* Hero ln3 sizing on mobile */
  .hero h1 .ln3{ font-size:.7em; }
}

/* Calendar cell sizing for very narrow viewports */
@media (max-width: 380px){
  .cal-cell{ min-height:44px; font-size:15px; }
  .cal-grid, .cal-weekdays{ gap:3px; }
  .booking-col{ padding:18px 14px; }
  .conf-code-val{ font-size:32px; }
}

/* Z-index hierarchy reinforcement */
.mobile-bottom-bar{ z-index:9999; }
.float-bar{ z-index:80; }
.menu-overlay{ z-index:1500; }
.mobile-menu{ z-index:2000; }

/* Reduced motion — kill all decorative animations */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
  #particles{ display:none; }
  .marquee-track{ animation: none !important; }
}

/* While scrolling, pause expensive animations */
body.is-scrolling .hero-photo-card,
body.is-scrolling .marquee-track{
  animation-play-state: paused !important;
}


/* =========================================================
   v3: $10 OFF banners, status pills, admin filters,
   custom select, success notification buttons
   ========================================================= */

/* The "$10 OFF" badge that lives below section heads */
.discount-pill{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:18px;
  padding:10px 18px;
  background: linear-gradient(135deg, rgba(75,255,176,.16), rgba(155,79,244,.16));
  border: 1px solid #4BFFB0;
  border-radius: 999px;
  font-family: var(--font-ui);
  font-size: 11px; letter-spacing: 1.5px;
  color: var(--text);
  text-transform: uppercase;
  box-shadow: 0 8px 24px -8px rgba(75,255,176,.4),
              inset 0 1px 0 rgba(255,255,255,.06);
  animation: discountFloat 3s ease-in-out infinite;
}
.discount-pill span:first-child{ font-size:14px; filter: drop-shadow(0 0 6px rgba(75,255,176,.6)); }
.discount-pill strong{
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: .04em;
  color: #4BFFB0;
  line-height: 1;
  text-shadow: 0 0 16px rgba(75,255,176,.5);
}
@keyframes discountFloat{
  0%,100%{ transform: translateY(0); box-shadow: 0 8px 24px -8px rgba(75,255,176,.4), inset 0 1px 0 rgba(255,255,255,.06); }
  50%   { transform: translateY(-3px); box-shadow: 0 14px 32px -8px rgba(75,255,176,.6), inset 0 1px 0 rgba(255,255,255,.1); }
}

/* Custom select to match form inputs */
.phantom-select{
  width: 100%;
  padding: 14px 14px;
  background: var(--bg-card);
  border: 1px solid var(--line-2);
  border-radius: 8px;
  color: var(--text);
  font-family: var(--font-ui);
  font-size: 13px;
  letter-spacing: .5px;
  appearance: none;
  -webkit-appearance: none;
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239B4FF4' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 40px;
  cursor: pointer;
  transition: border-color .2s, box-shadow .2s, background .2s;
}
.phantom-select:focus{
  outline: none;
  border-color: var(--purple);
  background-color: rgba(155,79,244,.05);
  box-shadow: 0 0 0 4px rgba(155,79,244,.12);
}
@media (max-width: 768px){
  .phantom-select{ font-size: 16px !important; padding: 16px 14px; padding-right: 40px; min-height: 56px; }
}

/* Status pill in admin */
.status-pill{
  display:inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-family: var(--font-ui);
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 2px;
  text-align: center;
}
.status-pill.status-confirmed{
  background: rgba(255, 214, 107, .14);
  color: #FFD66B;
  border: 1px solid rgba(255, 214, 107, .3);
}
.status-pill.status-completed{
  background: rgba(75, 255, 176, .14);
  color: #4BFFB0;
  border: 1px solid rgba(75, 255, 176, .3);
}
.status-pill.status-cancelled{
  background: rgba(255, 77, 109, .14);
  color: var(--danger);
  border: 1px solid rgba(255, 77, 109, .3);
  text-decoration: line-through;
}
.admin-table tr.row-cancelled{ opacity: .55; }
.admin-table tr.row-cancelled td:not(:last-child){ text-decoration: line-through; }
.admin-table tr.row-completed{ background: rgba(75, 255, 176, .02); }

/* Admin filter chips */
.admin-filters{
  display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;
}
.admin-chip{
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--bg-card);
  border: 1px solid var(--line-2);
  font-family: var(--font-ui);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  cursor: pointer;
  transition: all .2s var(--ease);
}
.admin-chip:hover{ border-color: var(--purple); color: var(--text); }
.admin-chip.on{
  background: var(--purple);
  border-color: var(--purple);
  color: #fff;
  box-shadow: 0 6px 18px -4px rgba(155,79,244,.55);
}

/* Notes column in admin: wrap long text */
.admin-table td{ vertical-align: top; }
.admin-table td:nth-child(6){ white-space: normal; line-height: 1.5; }


/* =========================================================
   PAYMENT METHODS — form box + success compact strip
   ========================================================= */
.payment-box{
  background: linear-gradient(180deg, rgba(11,11,22,.95), rgba(7,7,15,.92));
  border: 1px solid var(--line-2);
  border-radius: 12px;
  padding: 18px 18px 14px;
  margin-top: 14px;
  position: relative;
}
.payment-header{
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-ui);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--purple);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.payment-dot{
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--purple);
  box-shadow: 0 0 8px var(--purple);
  animation: pulseDot 1.6s infinite;
}
.payment-pills{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 14px;
}
.pay-pill{
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 10px 8px;
  background: #0A0612;
  border: 1px solid var(--line-2);
  border-radius: 8px;
  font-family: var(--font-ui);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 1.5px;
  color: var(--text);
  text-transform: uppercase;
  transition: border-color .2s, background .2s, transform .2s;
  white-space: nowrap;
}
.pay-pill:hover{
  border-color: var(--purple);
  background: rgba(155,79,244,.06);
  transform: translateY(-1px);
}
.pay-pill svg{ flex-shrink: 0; }
.pay-pill .pay-label{ line-height: 1; }

.pay-zelle{ border-color: rgba(109,30,212,.5); }
.pay-zelle:hover{ border-color: #6D1ED4; }
.pay-cash{ border-color: rgba(75,184,122,.5); }
.pay-cash:hover{ border-color: #4BB87A; }
.pay-cashapp{ border-color: rgba(0,214,50,.5); }
.pay-cashapp:hover{ border-color: #00D632; }
.pay-apple{ border-color: rgba(255,255,255,.4); }
.pay-apple:hover{ border-color: #fff; }

.payment-handles{
  display: flex; flex-direction: column; gap: 4px;
  padding: 10px 12px;
  background: rgba(155,79,244,.04);
  border: 1px solid rgba(155,79,244,.16);
  border-radius: 6px;
  margin-bottom: 10px;
}
.pay-handle{
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--text);
  letter-spacing: .3px;
}
.pay-handle .pay-h-lbl{
  display: inline-block; min-width: 76px;
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--purple-3);
}
.pay-handle a{
  color: var(--text);
  border-bottom: 1px dashed var(--line-2);
}
.pay-handle a:hover{ color: var(--purple); border-color: var(--purple); }

.payment-foot{
  font-family: var(--font-ui);
  font-size: 9px;
  letter-spacing: 1.2px;
  color: var(--muted);
  font-style: italic;
  text-align: center;
  padding-top: 6px;
  border-top: 1px dashed var(--line);
}

/* compact variant for success overlay */
.payment-compact{
  max-width: 380px;
  margin: -8px auto 18px;
  padding: 14px 16px;
  background: rgba(155,79,244,.06);
  border: 1px solid var(--line-2);
  border-radius: 10px;
  text-align: left;
}
.payment-compact-hdr{
  font-family: var(--font-ui);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2.5px;
  color: var(--purple);
  text-transform: uppercase;
  margin-bottom: 10px;
  text-align: center;
}
.payment-compact-pills{
  display: flex; flex-wrap: wrap; gap: 6px;
  justify-content: center;
  margin-bottom: 10px;
}
.pay-pill.sm{
  padding: 6px 10px;
  font-size: 9px;
  letter-spacing: 1.2px;
  gap: 6px;
}
.payment-compact-handles{
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--font-ui);
  font-size: 10px;
  color: var(--text);
  letter-spacing: .3px;
  padding: 8px 10px;
  background: rgba(0,0,0,.25);
  border-radius: 6px;
}
.payment-compact-handles strong{ color: var(--purple-3); font-weight: 700; }
.payment-compact-handles span{ display: flex; gap: 8px; }
.payment-compact-foot{
  font-family: var(--font-ui);
  font-size: 8px;
  letter-spacing: 1.2px;
  color: var(--muted);
  font-style: italic;
  text-align: center;
  margin-top: 8px;
}

@media (max-width: 768px){
  .payment-pills{ grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .pay-pill{ font-size: 10px; padding: 12px 6px; min-height: 48px; }
  .pay-handle .pay-h-lbl{ min-width: 70px; }
  .payment-compact{ margin: -4px 12px 18px; max-width: none; }
}
@media (max-width: 380px){
  .pay-pill{ font-size: 9px; }
}


/* =========================================================
   FIX — dropdown option visibility (white-on-white bug)
   ========================================================= */
select,
.phantom-select{
  background-color: #0D0D1A !important;
  color: #F2F2FF !important;
  border: 1px solid #2D1A5C;
  color-scheme: dark;        /* makes the native dropdown popup honor dark mode */
}
select option,
.phantom-select option{
  background-color: #0D0D1A !important;
  color: #F2F2FF !important;
  padding: 8px 10px;
}
select option:checked,
.phantom-select option:checked,
select option:hover,
.phantom-select option:hover{
  background-color: #9B4FF4 !important;
  color: #FFFFFF !important;
}
select option:disabled,
.phantom-select option:disabled{
  color: #4A4A6A !important;
}

/* belt-and-suspenders: enforce input text/placeholder colors everywhere */
input, textarea, select{
  color: var(--text);
  background-color: var(--bg-card);
}
input::placeholder, textarea::placeholder{
  color: var(--muted-2);
  opacity: 1;
}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill{
  -webkit-text-fill-color: var(--text) !important;
  -webkit-box-shadow: 0 0 0 1000px var(--bg-card) inset !important;
  caret-color: var(--text);
}

/* iOS Safari dark date/select chevron */
select::-ms-expand{ display: none; }


/* =========================================================
   SUCCESS — extra sections (social, share, review seed)
   ========================================================= */
.success-section{
  margin: 22px auto 0;
  max-width: 380px;
  text-align: center;
}
.success-section-hdr{
  font-family: var(--font-ui);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2.5px;
  color: var(--purple);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.success-section-hdr.muted{ color: var(--muted); }

.social-row{
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.social-btn{
  display: flex; align-items: center; gap: 10px;
  min-height: 56px;
  padding: 10px 12px;
  background: #0D0D1A;
  border: 1px solid #2D1A5C;
  border-radius: 10px;
  color: var(--text);
  text-align: left;
  transition: border-color .2s, background .2s, transform .15s;
  text-decoration: none;
}
.social-btn:hover{
  border-color: var(--purple);
  background: rgba(155,79,244,.06);
  transform: translateY(-2px);
}
.social-btn:active{ transform: translateY(0); }
.social-btn svg{ flex-shrink: 0; color: var(--purple); }
.social-meta{ display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.social-label{
  font-family: var(--font-ui);
  font-size: 9px;
  letter-spacing: 2px;
  font-weight: 700;
  color: var(--text);
}
.social-handle{
  font-family: var(--font-ui);
  font-size: 9px;
  color: var(--purple-3);
  letter-spacing: .5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.social-ig svg{ color: #E1306C; }
.social-tt svg{ color: #25F4EE; }

.share-btn{
  width: 100%;
  min-height: 56px;
  font-size: 12px;
  letter-spacing: 2px;
}

.review-seed{
  font-family: var(--font-ui);
  font-size: 9px;
  letter-spacing: 1.4px;
  color: #3A3A60;
  text-align: center;
  margin: 26px auto 18px;
  max-width: 340px;
  line-height: 1.6;
  text-transform: none;
}

.book-another{
  max-width: 380px;
  width: 100%;
  margin: 0 auto;
  display: block;
}

@media (max-width: 520px){
  .social-row{ grid-template-columns: 1fr; }
  .social-btn{ min-height: 52px; }
  .social-handle{ font-size: 10px; }
  .social-label{ font-size: 10px; }
}

/* Make success-actions stack full-width on mobile */
@media (max-width: 768px){
  .success-actions{ flex-direction: column; }
  .success-actions .btn{ width: 100%; min-width: 0; }
}


/* Stat card subtitle — small honest line under "10+ Cars Detailed" */
.stat .sublbl{
  font-family: var(--font-ui);
  font-size: 7px;
  letter-spacing: 1.8px;
  color: #3A3A60;
  text-transform: uppercase;
  margin-top: 4px;
  line-height: 1.4;
}


/* Utility note row inside success summary (water + outlet reminder) */
.summary-row.utility-note{
  background: rgba(155,79,244,.06);
  border: 1px dashed rgba(155,79,244,.25);
  border-radius: 6px;
  padding: 8px 10px;
  margin: 2px 0;
  justify-content: flex-start;
}
.summary-row.utility-note .lbl{
  font-family: var(--font-ui);
  font-size: 9px;
  letter-spacing: 1.2px;
  color: #4A4A6A !important;
  text-transform: uppercase;
  font-style: italic;
  font-weight: 500;
  line-height: 1.5;
  text-align: left;
}

/* Update service-area-note color to muted purple */
.service-area-note{
  color: #6B4AAA !important;
  font-size: 11px;
  letter-spacing: 1.3px;
  line-height: 1.5;
  text-transform: none;
  font-style: italic;
}
