/* ===== EXCLUSIVE DETAILING — polished mobile-first redesign ===== */
/* Tokens refined against Claude Design prototype */
:root{
  --bg:#05070d;
  --bg-2:#080b15;
  --panel:#0c1120;
  --panel-2:#11172a;
  --line:rgba(255,255,255,.07);
  --line-strong:rgba(255,255,255,.14);
  --text:#f4f6fb;
  --muted:#6b748a;
  --muted-2:#aab2c5;
  --blue:#2b7bff;
  --blue-2:#5a96ff;
  --blue-3:#86c1ff;
  --blue-soft:rgba(43,123,255,.18);
  --blue-ring:rgba(43,123,255,.35);
  --blue-glow:rgba(43,123,255,.45);
  --chrome-1:#f4f6f8;
  --chrome-2:#c2c8d2;
  --chrome-3:#7a8090;
  --chrome-4:#d8dde5;
  --chrome:linear-gradient(180deg,var(--chrome-1) 0%,var(--chrome-2) 35%,var(--chrome-3) 65%,var(--chrome-4) 100%);
  --shadow-card:0 1px 0 rgba(255,255,255,.04) inset, 0 30px 60px -30px rgba(0,0,0,.7);
  --shadow:0 30px 80px -30px rgba(43,123,255,.55);
  --radius-sm:10px;
  --radius:14px;
  --radius-lg:18px;
  --radius-xl:24px;
}

*{box-sizing:border-box;min-width:0}
html,body{margin:0;padding:0;max-width:100vw;overflow-x:hidden;overflow-wrap:break-word;word-wrap:break-word}
html{scroll-behavior:smooth}
img,svg,video{max-width:100%;height:auto}
body{
  background:
    radial-gradient(900px 600px at 80% -10%, rgba(43,123,255,.10), transparent 60%),
    radial-gradient(700px 500px at 0% 30%, rgba(43,123,255,.06), transparent 60%),
    var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;
  font-size:16px;line-height:1.55;
  letter-spacing:-0.005em;
  font-feature-settings:'ss01','cv11';
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  padding-bottom:env(safe-area-inset-bottom);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* ---------- INSTALL BANNER ---------- */
/* Sits BELOW the nav so it never covers nav links/phone CTA. z-index:45 < nav's 50. */
.install-banner{
  position:fixed;top:72px;left:50%;transform:translateX(-50%);
  z-index:45;
  display:flex;align-items:center;gap:10px;
  padding:8px 10px 8px 10px;border-radius:14px;
  background:linear-gradient(135deg,rgba(43,123,255,.22),rgba(10,16,32,.96));
  border:1px solid var(--blue-ring);
  backdrop-filter:blur(16px);
  box-shadow:0 18px 50px -20px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.03) inset;
  max-width:calc(100% - 20px);
  width:min(440px,calc(100% - 20px));
  animation:slideDown .35s ease both;
}
@keyframes slideDown{from{opacity:0;transform:translate(-50%,-12px)}to{opacity:1;transform:translate(-50%,0)}}
@media(max-width:760px){
  .install-banner{top:64px}
}
.install-banner img{width:36px;height:36px;flex-shrink:0;filter:drop-shadow(0 4px 10px var(--blue-glow))}
.install-text{flex:1;display:flex;flex-direction:column;min-width:0;gap:2px}
.install-banner strong{font-size:14px}
.install-banner span{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.install-have{
  margin-top:6px;align-self:flex-start;
  background:none;border:none;
  padding:4px 0;min-height:30px;
  font-size:12.5px;color:var(--blue-2);font-weight:700;
  text-decoration:underline;text-underline-offset:2px;
  cursor:pointer;
  -webkit-tap-highlight-color:rgba(43,123,255,.2);
}
.install-have:hover,.install-have:active{color:var(--blue-3)}
.install-banner .btn{padding:9px 16px;font-size:12px;letter-spacing:.4px;min-height:38px}
.install-x{
  width:38px;height:38px;border-radius:10px;border:0;
  background:rgba(255,255,255,.08);color:var(--text);font-size:22px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  -webkit-tap-highlight-color:rgba(255,255,255,.15);
}
.install-x:hover,.install-x:active{background:rgba(255,118,118,.18);color:var(--red)}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;
  backdrop-filter:blur(16px);
  background:linear-gradient(180deg,rgba(4,6,12,.88),rgba(4,6,12,.55));
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.5px}
.brand img{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 4px 8px var(--blue-glow))}
.brand span{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:2px}
.brand em{font-style:normal;color:var(--blue-2);margin-left:4px}
.nav-links{display:flex;gap:24px}
.nav-links a{font-size:14px;color:var(--muted-2);transition:color .2s;font-weight:500}
.nav-links a:hover{color:var(--text)}
.phone{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border-radius:999px;
  background:linear-gradient(135deg,var(--blue),#1e5bcc);
  color:#fff !important;font-weight:600;font-size:13.5px;
  box-shadow:0 8px 30px -8px var(--blue-glow);
  transition:transform .2s, box-shadow .2s;
}
.phone:hover{transform:translateY(-1px);box-shadow:0 12px 36px -8px var(--blue-glow)}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;padding:120px 24px 100px;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.35;transform:scale(1.05)}
.hero-grad{
  position:absolute;inset:0;
  background:
    radial-gradient(60% 80% at 50% 30%, rgba(43,123,255,.22), transparent 70%),
    linear-gradient(180deg, rgba(4,6,12,.5) 0%, rgba(4,6,12,.95) 75%, var(--bg) 100%);
}
.hero-inner{position:relative;z-index:1;max-width:1100px;width:100%;text-align:center}
.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11.5px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--blue-3);font-weight:700;
  padding:7px 16px;border-radius:999px;
  background:rgba(43,123,255,.10);border:1px solid var(--blue-ring);
  margin-bottom:22px;
  box-shadow:var(--shadow-card);
}
.hero-tag .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--blue-2);
  box-shadow:0 0 12px var(--blue-2);
  animation:dotPulse 2.4s ease-in-out infinite;
}
@keyframes dotPulse{0%,100%{opacity:.5;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}
.hero-logo{
  width:min(320px,55vw);margin:0 auto 20px;
  filter:drop-shadow(0 20px 50px rgba(43,123,255,.5));
  animation:floaty 6s ease-in-out infinite;
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero h1{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(40px,9.5vw,140px);
  line-height:.92;letter-spacing:1px;margin:0 0 22px;
  text-transform:uppercase;
  text-shadow:0 30px 60px rgba(0,0,0,.4);
  overflow-wrap:break-word;
}
.chrome{
  background:var(--chrome);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 8px 24px rgba(255,255,255,.18));
}
.hero .lede{
  color:var(--muted-2);max-width:600px;margin:0 auto 32px;
  font-size:clamp(15px,1.6vw,18px);
}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  max-width:540px;margin:0 auto;
}
.hero-stats div{
  padding:18px 12px;border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,0));
  border:1px solid var(--line);
}
.hero-stats strong{display:block;font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--blue-2);letter-spacing:1px}
.hero-stats span{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}
.scroll-cue{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  z-index:2;opacity:.6;
}
.scroll-cue span{
  display:block;width:24px;height:36px;border:2px solid var(--muted);border-radius:14px;position:relative;
}
.scroll-cue span::after{
  content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:4px;height:8px;background:var(--blue-2);border-radius:2px;
  animation:cue 1.6s ease-in-out infinite;
}
@keyframes cue{0%,100%{transform:translate(-50%,0);opacity:.4}50%{transform:translate(-50%,8px);opacity:1}}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border-radius:999px;
  font-weight:700;font-size:13.5px;letter-spacing:.5px;
  cursor:pointer;border:none;text-transform:uppercase;
  transition:transform .18s, box-shadow .2s, background .2s, border-color .2s;
  text-align:center;justify-content:center;
}
.btn.sm{padding:8px 14px;font-size:12px}
.btn.big{padding:18px 28px;font-size:14.5px}
.btn.primary{
  background:linear-gradient(135deg,var(--blue) 0%,#1850b8 100%);
  color:#fff;
  box-shadow:0 12px 40px -10px var(--blue-glow), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn.primary:hover{transform:translateY(-2px);box-shadow:0 18px 50px -10px var(--blue-glow)}
.btn.ghost{
  background:rgba(255,255,255,.05);color:var(--text);
  border:1px solid var(--line-strong);
}
.btn.ghost:hover{background:rgba(255,255,255,.09);border-color:rgba(78,160,255,.4)}

/* ---------- SECTIONS ---------- */
.section{padding:120px 28px;max-width:1200px;margin:0 auto;position:relative}
.section-head{text-align:center;max-width:680px;margin:0 auto 58px}
.eyebrow{
  display:inline-block;font-size:11.5px;letter-spacing:3px;text-transform:uppercase;
  color:var(--blue-2);margin-bottom:14px;font-weight:700;
}
.eyebrow.light{color:#bcd2ff}
h2{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(28px,6vw,64px);
  line-height:1;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase;
  overflow-wrap:break-word;
}
.section-head p{color:var(--muted-2);font-size:17px}

/* ---------- SERVICES ---------- */
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px}
.card{
  position:relative;padding:28px 24px;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);
  border:1px solid var(--line);
  transition:transform .25s, border-color .25s;
  overflow:hidden;
  box-shadow:var(--shadow-card);
}
.card::before{
  content:"";position:absolute;inset:0;border-radius:var(--radius);
  background:radial-gradient(120% 80% at 0% 0%, rgba(43,123,255,.18), transparent 50%);
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.card:hover{transform:translateY(-4px);border-color:rgba(78,160,255,.4)}
.card:hover::before{opacity:1}
.card-icon{font-size:30px;margin-bottom:14px;filter:drop-shadow(0 4px 10px var(--blue-glow))}
.card h3{font-size:19px;margin:0 0 8px;font-weight:700}
.card p{color:var(--muted-2);font-size:14.5px;margin:0;line-height:1.55}
.card.highlight{
  background:linear-gradient(180deg,rgba(43,123,255,.15) 0%,var(--panel-2) 100%);
  border-color:rgba(78,160,255,.32);
}

/* ---------- BAND ---------- */
.band{
  position:relative;display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:#000;overflow:hidden;
}
.band img{height:100%;width:100%;object-fit:cover;min-height:420px;opacity:.85}
.band-text{
  padding:80px 60px;display:flex;flex-direction:column;justify-content:center;
  background:linear-gradient(135deg, rgba(43,123,255,.18) 0%, transparent 100%), var(--bg-2);
  border-left:1px solid var(--line);
}
.band-text p{color:var(--muted-2);font-size:17px;max-width:480px;margin:0 0 26px}
.band-text strong{color:var(--blue-2)}
@media(max-width:780px){.band{grid-template-columns:1fr}.band-text{padding:48px 28px;border-left:none;border-top:1px solid var(--line)}}

/* ---------- PRICING ---------- */
.pricing{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.price{
  position:relative;padding:28px 24px 26px;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);
  border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .25s, border-color .25s;
  box-shadow:var(--shadow-card);
}
.price:hover{transform:translateY(-4px);border-color:rgba(78,160,255,.4)}
.price h3{font-size:20px;margin:0 0 10px;font-weight:700}
.price .includes{color:var(--muted);font-size:13.5px;margin:0 0 18px;line-height:1.55}
.price-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0;border-bottom:1px solid var(--line);
}
.price-row:last-of-type{border-bottom:none;margin-bottom:18px}
.price-row span{color:var(--muted);font-size:13px;letter-spacing:.4px}
.price-row strong{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:1px;color:var(--text)}
.price .btn{margin-top:auto;justify-content:center}
.price .tag{
  position:absolute;top:-12px;right:18px;
  background:linear-gradient(135deg,var(--blue),#1850b8);
  color:#fff;font-size:11px;letter-spacing:2px;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;font-weight:700;
}
.price.popular{border-color:rgba(78,160,255,.5);box-shadow:var(--shadow)}
.price.popular .price-row strong{color:var(--blue-2)}
.price.signature{
  background:
    radial-gradient(120% 80% at 100% 0%, rgba(43,123,255,.22), transparent 60%),
    linear-gradient(180deg,var(--panel) 0%,#0a1024 100%);
  border-color:rgba(78,160,255,.35);
}
.price.signature .tag{background:var(--chrome);color:#0b1226}
.price.signature .price-row strong{color:var(--blue-2)}

/* ---------- ADDONS ---------- */
.addons{
  margin-top:42px;padding:32px;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);
  border:1px solid var(--line);
  box-shadow:var(--shadow-card);
}
.addons h3{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:2px;margin:0 0 18px;text-transform:uppercase}
.addons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:14px}
.addon{
  display:block;cursor:pointer;
  padding:14px 16px;border-radius:var(--radius-sm);
  background:rgba(0,0,0,.3);border:1px solid var(--line);
  transition:border-color .2s, background .2s;
}
.addon:hover{border-color:rgba(78,160,255,.4)}
.addon input{accent-color:var(--blue);margin-right:10px;transform:translateY(2px)}
.addon span{display:inline-flex;flex-direction:column;gap:3px;vertical-align:top}
.addon strong{font-size:14px;font-weight:600}
.addon em{font-style:normal;color:var(--blue-2);font-size:13px;font-weight:700}
.addon input:checked + span strong{color:var(--blue-2)}
.addon:has(input:checked){background:rgba(43,123,255,.12);border-color:rgba(78,160,255,.55)}
.addons small{display:block;color:var(--muted);font-size:13px}

/* ---------- GALLERY ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;gap:14px}
.gallery figure{margin:0;border-radius:14px;overflow:hidden;position:relative;border:1px solid var(--line)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.gallery figure:hover img{transform:scale(1.05)}
.g1{grid-column:span 2;grid-row:span 2}
.g2,.g3,.g4,.g5{grid-column:span 1;grid-row:span 1}
.g6,.g7{grid-column:span 2;grid-row:span 1}
@media(max-width:780px){.gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}.g1,.g6,.g7{grid-column:span 2}}

/* ---------- CALENDAR ---------- */
.cal{
  background:rgba(0,0,0,.35);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:18px;display:flex;flex-direction:column;gap:14px;
  box-shadow:var(--shadow-card);
}
.cal-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.cal-month{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:2px;text-transform:uppercase;color:var(--text);flex:1;text-align:center}
.cal-nav{
  width:36px;height:36px;border-radius:10px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--text);
  font-size:20px;cursor:pointer;line-height:1;
  transition:background .2s, border-color .2s;
}
.cal-nav:hover{background:rgba(43,123,255,.15);border-color:rgba(78,160,255,.5)}
.cal-nav:disabled{opacity:.3;cursor:not-allowed}
.cal-dows{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);text-align:center;font-weight:700}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-cell{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:600;border-radius:10px;
  background:rgba(255,255,255,.03);border:1px solid transparent;
  cursor:pointer;transition:background .15s, border-color .15s, color .15s;
  color:var(--text);
}
.cal-cell.empty{background:transparent;cursor:default;pointer-events:none}
.cal-cell:hover:not(.disabled):not(.empty){background:rgba(43,123,255,.18);border-color:rgba(78,160,255,.4)}
.cal-cell.disabled{color:rgba(140,155,180,.3);cursor:not-allowed;background:transparent}
.cal-cell.today{border-color:rgba(78,160,255,.5)}
.cal-cell.selected{background:linear-gradient(135deg,var(--blue),#1850b8);color:#fff;border-color:transparent;box-shadow:0 8px 24px -8px var(--blue-glow)}
.cal-times-label{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin:14px 0 10px}
.cal-times-label span{color:var(--blue-2);margin-left:6px;letter-spacing:.5px}
.cal-times-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:8px}
.cal-time{
  padding:10px 12px;border-radius:10px;
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  font-size:13px;font-weight:600;color:var(--text);cursor:pointer;text-align:center;
  transition:background .15s, border-color .15s;
}
.cal-time:hover{background:rgba(43,123,255,.18);border-color:rgba(78,160,255,.4)}
.cal-time.selected{background:linear-gradient(135deg,var(--blue),#1850b8);color:#fff;border-color:transparent}

/* ---------- BOOK ---------- */
.book{padding-top:60px}
.book-head{margin-bottom:30px}
.book-chips{
  display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:18px;
}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:999px;
  background:rgba(43,123,255,.08);border:1px solid var(--blue-ring);
  color:var(--blue-3);font-size:12px;font-weight:600;letter-spacing:.2px;
}
.chip svg{flex-shrink:0;opacity:.85}

.book-card{
  max-width:680px;margin:0 auto;
  background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);
  border:1px solid var(--line);border-radius:var(--radius-xl);
  padding:32px;
  box-shadow:var(--shadow-card);
  display:flex;flex-direction:column;gap:20px;
}

.step{display:flex;flex-direction:column;gap:14px}
.step-head{display:flex;align-items:center;gap:12px;margin-bottom:2px}
.step-num{
  width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),#1850b8);color:#fff;
  font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 16px -4px var(--blue-glow);flex-shrink:0;
}
.step-title{
  font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--text);
}
.step-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.step-fields .full{grid-column:span 2}

.book-card label{
  display:flex;flex-direction:column;gap:6px;
  font-size:11px;letter-spacing:1px;text-transform:uppercase;
  color:var(--muted-2);font-weight:700;
}
.book-card label .opt{
  text-transform:none;letter-spacing:0;color:var(--muted);font-weight:500;
  margin-left:4px;font-size:11.5px;
}
.book-card input,.book-card select,.book-card textarea{
  background:rgba(0,0,0,.35);border:1px solid var(--line);border-radius:12px;
  padding:13px 14px;color:var(--text);font-size:15px;font-family:inherit;
  transition:border-color .2s, background .2s;
  min-height:46px;
}
.book-card select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%235a96ff'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;background-size:18px;
  padding-right:38px;
}
.book-card textarea{min-height:90px;resize:vertical}
.book-card input:focus,.book-card select:focus,.book-card textarea:focus{
  outline:none;border-color:var(--blue-2);background:rgba(0,0,0,.55);
}

.confirm-btn{margin-top:6px;width:100%}
#bookStatus{color:var(--muted);font-size:12.5px;text-align:center;margin-top:-6px}
#bookStatus strong{color:var(--blue-2)}
#bookStatus.success{color:#5ee07d}
#bookStatus.error{color:#ff7676}

.book-contact{
  display:flex;align-items:center;gap:14px;padding:14px;
  border-radius:14px;background:rgba(0,0,0,.3);border:1px solid var(--line);
  margin-top:6px;
}
.book-contact img{width:42px;height:42px;flex-shrink:0;object-fit:contain}
.book-contact > div{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.book-contact .lbl{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:700}
.book-contact .num{color:var(--blue-2);font-weight:700;font-size:17px;letter-spacing:.5px}

@media(max-width:520px){
  .book-card{padding:22px 18px;gap:18px;border-radius:18px}
  .step-fields{grid-template-columns:1fr;gap:10px}
  .step-fields .full{grid-column:span 1}
  .step-title{font-size:18px}
  .book-contact{padding:12px;gap:10px}
  .book-contact img{width:36px;height:36px}
  .book-contact .num{font-size:15px}
}

/* ---------- FOOT ---------- */
.foot{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;
  padding:36px 28px;border-top:1px solid var(--line);
  max-width:1200px;margin:60px auto 0;
}
.foot > div:first-child{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:14px}
.foot img{width:40px;height:40px}
.foot-links{display:flex;gap:22px;font-size:14px;color:var(--muted);flex-wrap:wrap}
.foot-links a:hover{color:var(--text)}

/* ---------- MOBILE STICKY ACTION BAR ---------- */
.mobile-bar{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;
  padding:10px 12px calc(10px + env(safe-area-inset-bottom)) 12px;
  background:linear-gradient(180deg,rgba(4,6,12,.55),rgba(4,6,12,.92));
  backdrop-filter:blur(16px);
  border-top:1px solid var(--line);
  gap:10px;
}
.mbtn{
  flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 8px;border-radius:14px;
  background:rgba(255,255,255,.06);
  color:var(--text);font-weight:700;font-size:13px;letter-spacing:.5px;
  border:1px solid var(--line-strong);
  text-transform:uppercase;
}
.mbtn.primary{
  background:linear-gradient(135deg,var(--blue) 0%,#1850b8 100%);color:#fff;
  border-color:transparent;
  box-shadow:0 10px 30px -10px var(--blue-glow);
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:760px){
  .nav-links{display:none}
  .nav{padding:12px 16px}
  .phone span{display:none}
  .phone{padding:9px 12px}
  .hero{padding:100px 18px 140px}
  .section{padding:64px 16px}
  .hero-stats{gap:8px}
  .hero-stats div{padding:14px 6px}
  .hero-stats strong{font-size:22px}
  .hero-stats span{font-size:10px;letter-spacing:1px}
  .mobile-bar{display:flex}
  body{padding-bottom:74px}
  .foot{margin-bottom:60px;padding:32px 16px}
  .book-card{padding:24px 18px;gap:18px}
  .book-card label{font-size:11px;letter-spacing:1px}
  .price{padding:22px 18px}
  .price-row strong{font-size:20px}
  .card{padding:22px 18px}
  .addons{padding:22px 18px}
  .addons-grid{gap:8px}
  .addon{padding:12px 14px}
  .hero-logo{width:min(240px,60vw)}
  .hero-tag{font-size:10.5px;letter-spacing:2px;padding:6px 12px}
  .section-head{margin-bottom:40px}
}

/* Aggressive lockdown for narrow phones (iPhone SE, etc.) */
@media(max-width:420px){
  .hero h1{font-size:38px;letter-spacing:.5px}
  .hero .lede{font-size:14px}
  .hero-cta{flex-direction:column;gap:10px;width:100%}
  .hero-cta .btn{width:100%}
  .hero-stats strong{font-size:20px}
  .hero-stats span{font-size:9.5px}
  h2{font-size:26px}
  .section-head p{font-size:15px}
  .price h3,.card h3{font-size:17px}
  .price .includes,.card p{font-size:13px}
  .price-row span{font-size:12px}
  .price-row strong{font-size:18px}
  .section{padding:48px 14px}
  .book-card{padding:20px 16px;border-radius:18px}
  .step-title{font-size:17px}
  .step-num{width:24px;height:24px;font-size:12px}
  .book-contact .num{font-size:15px}
  .addons h3{font-size:22px}
  .cal{padding:14px}
  .cal-month{font-size:18px;letter-spacing:1.5px}
  .cal-cell{font-size:13px}
  .cal-time{font-size:12px;padding:9px 8px}
  .band-text{padding:36px 18px}
  .install-banner{padding:8px 8px}
  .install-banner img{width:32px;height:32px}
  .install-banner strong{font-size:13px}
  .install-banner span{font-size:11px}
}

/* ---------- Recent Work / Before & After ---------- */
.recent-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:18px;
}
.ba-card,.ba-single{
  margin:0;
  background:#0a0f1c;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 10px 40px -20px rgba(0,0,0,.6);
}
.ba-single img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover}
.ba-card .ba-wrap{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;user-select:none;cursor:ew-resize;--ba-pos:50%}
.ba-card .ba-after,.ba-card .ba-before{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;
}
.ba-card .ba-before-wrap{position:absolute;inset:0;width:100%;clip-path:inset(0 calc(100% - var(--ba-pos)) 0 0);pointer-events:none}
.ba-handle{
  position:absolute;top:0;bottom:0;left:var(--ba-pos,50%);width:3px;background:#fff;
  transform:translateX(-50%);border:none;padding:0;cursor:ew-resize;
  box-shadow:0 0 12px rgba(0,0,0,.6);
}
.ba-handle::before,.ba-handle::after{
  content:'';position:absolute;left:50%;top:50%;width:36px;height:36px;
  transform:translate(-50%,-50%);
  background:#fff;border-radius:50%;box-shadow:0 4px 18px rgba(0,0,0,.5);
}
.ba-handle::after{
  width:18px;height:18px;background:transparent;
  border-left:2px solid var(--blue-2);border-right:2px solid var(--blue-2);
}
.ba-tag{
  position:absolute;top:10px;padding:4px 10px;font-size:11px;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;border-radius:99px;background:rgba(0,0,0,.6);color:#fff;backdrop-filter:blur(6px);
  pointer-events:none;
}
.ba-tag-before{left:10px}
.ba-tag-after{right:10px;background:rgba(38,109,255,.85)}
.ba-card figcaption,.ba-single figcaption{
  padding:10px 14px;font-size:13.5px;color:var(--muted);border-top:1px solid rgba(255,255,255,.06);
}
@media(max-width:640px){
  .recent-grid{grid-template-columns:1fr;gap:14px}
  .ba-handle::before{width:30px;height:30px}
}
