/* ============================================
   CRUZ DETAILING - DESIGN SYSTEM
   ============================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#000;--dark:#0a0a0a;--darker:#111;--card:#141414;--card-hover:#1a1a1a;
  --silver:#c0c0c0;--light-silver:#e0e0e0;--blue:#00bfff;
  --blue-glow:rgba(0,191,255,.35);--blue-deep:#0077aa;--blue-muted:rgba(0,191,255,.08);
  --chrome:linear-gradient(135deg,#999 0%,#fff 25%,#888 50%,#ddd 75%,#777 100%);
  --text:#ccc;--text-dim:#888;--text-bright:#fff;
  --radius:12px;--radius-lg:16px;
  --nav-h:64px;
}
html{}
body{
  font-family:'Rajdhani',sans-serif;background:var(--black);color:var(--text);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none;transition:color .3s}
a:hover{color:var(--light-silver)}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.container-sm{max-width:800px;margin:0 auto;padding:0 20px}
.container-xs{max-width:640px;margin:0 auto;padding:0 20px}

/* Reveal */
.reveal{opacity:0;transition:opacity .8s ease}
.reveal.visible{opacity:1}

/* ===== NAVIGATION ===== */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(0,0,0,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(0,191,255,.08);transition:all .3s ease;
}
nav.scrolled{background:rgba(0,0,0,.96);box-shadow:0 4px 30px rgba(0,191,255,.08)}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1200px;margin:0 auto;padding:10px 20px;
}
.nav-logo{height:44px;filter:drop-shadow(0 0 6px var(--blue-glow))}
.nav-links{display:flex;gap:24px;list-style:none}
.nav-links a{
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.7rem;letter-spacing:2px;
  text-transform:uppercase;color:var(--silver);position:relative;padding:4px 0;transition:color .3s;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;
  background:var(--blue);transition:width .3s ease;
}
.nav-links a:hover{color:var(--blue)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--blue)}
.nav-links a.active::after{width:100%}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:10px;-webkit-tap-highlight-color:transparent}
.hamburger span{width:22px;height:2px;background:var(--silver);transition:all .3s;border-radius:1px}

/* ===== PAGE HERO (reusable) ===== */
.page-hero{
  position:relative;padding:140px 20px 80px;text-align:center;overflow:hidden;
  min-height:50vh;display:flex;align-items:center;justify-content:center;
}
.page-hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse at 30% 30%,rgba(0,191,255,.06) 0%,transparent 60%),
    radial-gradient(ellipse at 70% 70%,rgba(0,191,255,.04) 0%,transparent 50%),
    linear-gradient(180deg,#000 0%,#050510 50%,#000a14 80%,var(--dark) 100%);
}
.page-hero-img{
  position:absolute;bottom:0;left:0;width:100%;height:100%;
  opacity:.12;z-index:1;pointer-events:none;object-fit:cover;
  mask-image:linear-gradient(to top,transparent 0%,rgba(0,0,0,.5) 20%,rgba(0,0,0,.6) 50%,transparent 85%);
  -webkit-mask-image:linear-gradient(to top,transparent 0%,rgba(0,0,0,.5) 20%,rgba(0,0,0,.6) 50%,transparent 85%);
}
.page-hero-content{position:relative;z-index:2;max-width:700px}
.page-hero-title{
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:clamp(2rem,6vw,3.5rem);
  font-weight:900;letter-spacing:3px;
  background:var(--chrome);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.15;margin-bottom:16px;
}
.page-hero-sub{
  font-size:clamp(1rem,2.5vw,1.2rem);color:var(--text-dim);
  letter-spacing:1px;max-width:500px;margin:0 auto;line-height:1.7;
}
.page-hero-breadcrumb{
  margin-top:20px;font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;
  letter-spacing:2px;text-transform:uppercase;
}
.page-hero-breadcrumb a{color:var(--text-dim)}
.page-hero-breadcrumb span{color:var(--blue)}

/* ===== SECTION COMMON ===== */
.section{padding:80px 0}
.section-dark{background:var(--dark)}
.section-divider{position:relative}
.section-divider::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--blue),transparent);
}
.section-title{
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:clamp(1.4rem,4vw,2.4rem);
  font-weight:900;text-align:center;letter-spacing:3px;margin-bottom:10px;
  background:var(--chrome);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
}
.section-title-left{text-align:left}
.section-subtitle{text-align:center;color:var(--text-dim);font-size:1rem;letter-spacing:1px;margin-bottom:32px}
.section-line{width:50px;height:3px;background:var(--blue);margin:12px auto 16px;border-radius:2px;box-shadow:0 0 8px var(--blue-glow)}

/* ===== BUTTONS ===== */
.btn-primary{
  display:inline-block;padding:14px 40px;
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.8rem;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:#fff;
  background:linear-gradient(135deg,var(--blue-deep),var(--blue));
  border:none;border-radius:50px;cursor:pointer;position:relative;overflow:hidden;
  box-shadow:0 0 25px var(--blue-glow);transition:all .3s;
  -webkit-tap-highlight-color:transparent;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 40px var(--blue-glow);color:#fff}
.btn-primary::before{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,.12) 50%,transparent 60%);
  animation:btn-shine 4s ease-in-out infinite;
}
@keyframes btn-shine{0%,100%{transform:translateX(-100%) rotate(45deg)}50%{transform:translateX(100%) rotate(45deg)}}
.btn-outline{
  display:inline-block;padding:12px 32px;
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.7rem;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;
  color:var(--blue);background:transparent;
  border:1px solid var(--blue);border-radius:50px;cursor:pointer;
  transition:all .3s;-webkit-tap-highlight-color:transparent;
}
.btn-outline:hover{background:var(--blue);color:#000;box-shadow:0 0 20px var(--blue-glow)}

/* ===== CARDS ===== */
.card{
  background:var(--card);border-radius:var(--radius-lg);
  border:1px solid rgba(255,255,255,.06);overflow:hidden;
  transition:all .4s ease;
}
.card:hover{border-color:rgba(0,191,255,.15);box-shadow:0 8px 40px rgba(0,191,255,.08)}
.card-img{height:220px;overflow:hidden;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .card-img img{transform:scale(1.05)}
.card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,var(--card) 0%,transparent 40%);
}
.card-body{padding:24px}

/* ===== FORM ELEMENTS ===== */
.form-label{
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:2px;
  color:var(--text-dim);display:block;margin-bottom:8px;
}
.form-select,.form-input{
  width:100%;padding:13px 18px;background:var(--darker);
  border:1px solid rgba(255,255,255,.08);border-radius:10px;
  color:var(--silver);font-family:'Rajdhani',sans-serif;font-size:1rem;
  transition:all .3s;margin-bottom:14px;
}
.form-select{
  appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2300bfff' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
}
.form-input:focus,.form-select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 12px var(--blue-glow)}
.form-input::placeholder{color:var(--text-dim)}
textarea.form-input{resize:vertical;min-height:120px}

/* ===== FOOTER ===== */
footer{padding:60px 0 24px;border-top:1px solid rgba(0,191,255,.08)}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;
  max-width:1200px;margin:0 auto 40px;padding:0 20px;
}
.footer-brand{display:flex;flex-direction:column;gap:16px}
.footer-logo{height:50px;width:auto;opacity:.8;filter:drop-shadow(0 0 8px var(--blue-glow))}
.footer-brand p{color:var(--text-dim);font-size:.9rem;line-height:1.7;max-width:280px}
.footer-social-row{display:flex;gap:10px}
.footer-col h4{
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:2px;
  color:var(--blue);margin-bottom:16px;text-transform:uppercase;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{color:var(--text-dim);font-size:.9rem;transition:color .3s}
.footer-col a:hover{color:var(--blue)}
.footer-bottom{
  display:flex;flex-direction:column;align-items:center;
  max-width:1200px;margin:0 auto;padding:20px 20px 0;
  border-top:1px solid rgba(255,255,255,.04);text-align:center;gap:0;
}
.footer-socials{display:flex;gap:10px}
.social-icon{
  width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);display:flex;align-items:center;
  justify-content:center;transition:all .3s;cursor:pointer;-webkit-tap-highlight-color:transparent;
}
.social-icon:hover{border-color:var(--blue);background:rgba(0,191,255,.08);transform:translateY(-2px);box-shadow:0 4px 12px var(--blue-glow)}
.social-icon svg{width:14px;height:14px;fill:var(--silver)}
.footer-text{color:var(--text-dim);font-size:.75rem}
.footer-text a{color:var(--blue)}

/* ===== FAQ ===== */
.faq-list{display:flex;flex-direction:column;gap:6px}
.faq-item{
  background:var(--card);border-radius:12px;
  border:1px solid rgba(255,255,255,.04);overflow:hidden;transition:border-color .3s;
}
.faq-item.open{border-color:rgba(0,191,255,.15)}
.faq-question{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;cursor:pointer;gap:16px;-webkit-tap-highlight-color:transparent;
}
.faq-question span{
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.72rem;font-weight:600;
  letter-spacing:1.5px;color:var(--silver);transition:color .3s;
}
.faq-item.open .faq-question span{color:#fff}
.faq-icon{width:24px;height:24px;flex-shrink:0;position:relative}
.faq-icon::before,.faq-icon::after{
  content:'';position:absolute;top:50%;left:50%;
  background:var(--blue);border-radius:1px;transition:transform .3s ease;
}
.faq-icon::before{width:12px;height:2px;transform:translate(-50%,-50%)}
.faq-icon::after{width:2px;height:12px;transform:translate(-50%,-50%)}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-answer{max-height:300px}
.faq-answer-inner{padding:0 22px 20px;color:var(--text-dim);font-size:.92rem;line-height:1.75}

/* ===== TESTIMONIAL CARD ===== */
.testimonial-card{
  background:var(--card);border-radius:var(--radius-lg);
  border:1px solid rgba(255,255,255,.06);padding:32px;transition:all .4s;
}
.testimonial-card:hover{border-color:rgba(0,191,255,.15)}
.testimonial-card .stars{color:#ffd700;margin-bottom:12px;letter-spacing:2px;font-size:.85rem}
.testimonial-card .quote{font-size:.95rem;line-height:1.8;color:var(--text);font-style:italic;margin-bottom:16px}
.testimonial-card .author{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:2px;color:var(--blue)}

/* ===== GALLERY GRID ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-grid-item{
  border-radius:var(--radius);overflow:hidden;position:relative;
  aspect-ratio:16/11;border:1px solid rgba(255,255,255,.05);transition:all .4s;cursor:pointer;
}
.gallery-grid-item:hover{border-color:rgba(0,191,255,.25);box-shadow:0 6px 30px rgba(0,191,255,.12)}
.gallery-grid-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-grid-item:hover img{transform:scale(1.05)}
.gallery-grid-item .overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 50%);
  opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:20px;
}
.gallery-grid-item:hover .overlay{opacity:1}
.overlay-text{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.7rem;letter-spacing:2px;color:var(--blue)}
.gallery-grid-item.featured{grid-column:span 2;aspect-ratio:2/1}

/* ===== STAT COUNTER ===== */
.stats-bar{
  padding:32px 0;
  background:linear-gradient(135deg,rgba(0,30,50,.6),rgba(0,10,20,.8));
  border-top:1px solid rgba(0,191,255,.08);border-bottom:1px solid rgba(0,191,255,.08);
}
.stats-row{display:flex;justify-content:center;gap:48px;flex-wrap:nowrap;padding:0}
.stat{text-align:center;flex:1;min-width:0}
.stat-number{font-family:'Bebas Neue',sans-serif;font-size:3rem;color:var(--blue);letter-spacing:2px;line-height:1}
.stat-label{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--text-dim);margin-top:6px}

/* ===== PROCESS STEPS ===== */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.process-step{text-align:center;padding:32px 20px;position:relative}
.process-step::after{
  content:'';position:absolute;top:40px;right:-12px;width:24px;height:2px;
  background:rgba(0,191,255,.2);
}
.process-step:last-child::after{display:none}
.process-number{width:56px;height:56px;border-radius:50%;background:rgba(0,191,255,.06);border:1px solid rgba(0,191,255,.15);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-family:'Bebas Neue',sans-serif;font-size:1.8rem;color:var(--blue)}
.process-step h3{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:2px;color:var(--light-silver);margin-bottom:8px}
.process-step p{font-size:.88rem;color:var(--text-dim);line-height:1.6}
.step-number{font-family:'Bebas Neue',sans-serif;font-size:2.5rem;color:var(--blue);opacity:.3;line-height:1;margin-bottom:12px}
.step-title{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:2px;color:var(--light-silver);margin-bottom:8px}
.step-desc{font-size:.88rem;color:var(--text-dim);line-height:1.6}

/* ===== LIGHTBOX ===== */
.lightbox{
  display:none;position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,.95);backdrop-filter:blur(20px);
  align-items:center;justify-content:center;
}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:var(--radius);object-fit:contain}
.lightbox-close{
  position:absolute;top:20px;right:20px;width:44px;height:44px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .3s;color:var(--silver);font-size:1.2rem;
}
.lightbox-close:hover{background:rgba(0,191,255,.1);border-color:var(--blue)}
.lightbox-caption{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.7rem;letter-spacing:2px;color:var(--blue);
}

/* ===== CTA BANNER ===== */
.cta-banner{
  text-align:center;padding:80px 20px;
  background:linear-gradient(135deg,rgba(0,30,50,.8),rgba(0,10,20,.9));
  border-top:1px solid rgba(0,191,255,.1);border-bottom:1px solid rgba(0,191,255,.1);
}
.cta-banner h2{
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:clamp(1.3rem,3vw,2rem);
  font-weight:900;letter-spacing:3px;color:var(--light-silver);margin-bottom:12px;
}
.cta-banner p{color:var(--text-dim);margin-bottom:28px;font-size:1rem}

/* ===== ABOUT SECTION ===== */
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;max-width:1100px;margin:0 auto}
.about-photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;justify-items:center}
.about-photo{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;border:1px solid rgba(255,255,255,.06);width:100%}
.about-photo.main-photo{grid-column:span 2;aspect-ratio:16/10;max-width:75%}
.about-photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.about-photo:hover img{transform:scale(1.05)}
.about-photo-tag{
  position:absolute;bottom:10px;left:10px;padding:4px 12px;
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.55rem;letter-spacing:2px;
  background:rgba(0,0,0,.7);backdrop-filter:blur(8px);color:var(--blue);
  border-radius:20px;border:1px solid rgba(0,191,255,.15);
  opacity:0;transform:translateY(6px);transition:all .3s;
}
.about-photo:hover .about-photo-tag{opacity:1;transform:translateY(0)}
.about-text h3.about-name{
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:clamp(1.2rem,3vw,1.6rem);
  font-weight:900;letter-spacing:2px;color:#fff;margin-bottom:4px;
}
.about-name span{
  background:var(--chrome);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
}
.about-role{
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:3px;
  color:var(--blue);margin-bottom:24px;text-transform:uppercase;
}
.about-text p{color:var(--text-dim);font-size:.95rem;line-height:1.8;margin-bottom:14px}
.about-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.about-badge{
  padding:8px 16px;border-radius:50px;font-family:'Orbitron','Orbitron-fallback',sans-serif;
  font-size:.6rem;letter-spacing:1.5px;color:var(--silver);
  background:rgba(0,191,255,.04);border:1px solid rgba(0,191,255,.12);
}

/* ===== PRICING NOTICE ===== */
.pricing-notice{display:flex;align-items:center;gap:16px;padding:20px 28px;border-radius:var(--radius-lg);background:rgba(0,191,255,.04);border:1px solid rgba(0,191,255,.12);margin-bottom:40px;font-size:.9rem;color:var(--silver);line-height:1.6}
.pricing-notice strong{color:#fff}
.pricing-notice-icon{font-size:1.4rem;flex-shrink:0}
.size-examples{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.size-ex{padding:5px 12px;border-radius:6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);font-size:.78rem;color:var(--text-dim);line-height:1.4}
.size-ex strong{color:var(--blue);margin-right:4px;font-size:.7rem;letter-spacing:.5px}

.svc-item-price small{font-size:.55rem;color:var(--text-dim);letter-spacing:1px;font-family:'Rajdhani',sans-serif;vertical-align:middle}
.vat-tag{font-size:.55rem;color:var(--text-dim);letter-spacing:1px;font-family:'Rajdhani',sans-serif}
.svc-size-note{font-size:.72rem;color:var(--text-dim);margin-top:12px;letter-spacing:.5px;opacity:.7}

/* ===== SERVICES CYCLING LAYOUT ===== */
.services-layout{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start;max-width:1000px;margin:0 auto}
.svc-list{display:flex;flex-direction:column;gap:4px}
.svc-item{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-radius:10px;cursor:pointer;border:1px solid rgba(255,255,255,.04);background:var(--card);transition:all .35s ease;-webkit-tap-highlight-color:transparent}
.svc-item:hover{border-color:rgba(0,191,255,.15);background:rgba(0,191,255,.03)}
.svc-item.active{border-color:rgba(0,191,255,.3);background:rgba(0,191,255,.06);box-shadow:0 0 20px rgba(0,191,255,.08)}
.svc-item-left{display:flex;align-items:center;gap:14px}
.svc-number{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;color:rgba(255,255,255,.12);width:28px;transition:color .3s}
.svc-item.active .svc-number{color:var(--blue)}
.svc-item-name{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:1.5px;color:var(--silver);transition:color .3s}
.svc-item.active .svc-item-name{color:#fff}
.svc-item-price{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;color:var(--text-dim);letter-spacing:1px;transition:color .3s}
.svc-item.active .svc-item-price{color:var(--blue)}
.svc-timer-bar{height:2px;background:rgba(255,255,255,.04);border-radius:1px;margin-top:2px;overflow:hidden}
.svc-timer-fill{height:100%;width:0;background:var(--blue);border-radius:1px}
.svc-item.active ~ .svc-timer-bar .svc-timer-fill,.svc-timer-bar:has(~ .svc-item) .svc-timer-fill{}
@keyframes svc-timer{0%{width:0}100%{width:100%}}
.svc-preview{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.06);background:var(--card);box-shadow:0 16px 50px rgba(0,0,0,.4)}
.svc-preview-img{position:relative;height:260px;overflow:hidden}
.svc-preview-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:0;transition:opacity .6s ease,transform .6s ease;transform:scale(1.05)}
.svc-preview-img img.active{opacity:1;transform:scale(1)}
.svc-preview-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--card) 0%,transparent 40%)}
.svc-preview-body{padding:28px}
.svc-preview-name{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:1rem;font-weight:700;letter-spacing:2px;color:#fff;margin-bottom:10px;min-height:1.4em}
.svc-preview-desc{font-size:.95rem;color:var(--text-dim);line-height:1.7;margin-bottom:20px;min-height:3.4em}
.svc-preview-footer{display:flex;align-items:center;justify-content:space-between}
.svc-preview-price{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--blue);letter-spacing:2px}
.svc-preview-btn{padding:10px 24px;background:transparent;border:1px solid var(--blue);color:var(--blue);font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:2px;border-radius:50px;cursor:pointer;transition:all .3s;-webkit-tap-highlight-color:transparent;text-decoration:none}
.svc-preview-btn:hover{background:var(--blue);color:#000;box-shadow:0 0 20px var(--blue-glow)}

/* ===== BEFORE/AFTER SLIDER ===== */
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:1100px;margin:0 auto}
.ba-slider{position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,.08);cursor:col-resize;touch-action:none;-webkit-user-select:none;user-select:none}
.ba-slider img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba-after{clip-path:inset(0 0 0 50%)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:4px;background:var(--blue);z-index:3;transform:translateX(-50%);pointer-events:none;box-shadow:0 0 12px var(--blue-glow)}
.ba-handle::before{content:'';position:absolute;left:50%;top:50%;width:28px;height:28px;background:var(--blue);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 15px var(--blue-glow)}
.ba-labels{position:absolute;bottom:12px;left:0;right:0;display:flex;justify-content:space-between;padding:0 16px;z-index:4;pointer-events:none}
.ba-label{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--blue);background:rgba(0,0,0,.7);padding:4px 10px;border-radius:4px}

/* ===== BRAND LOGOS ===== */
.brands-row{display:flex;justify-content:center;align-items:center;gap:40px;flex-wrap:wrap;padding:20px 0}
.brand-item{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.7rem;letter-spacing:3px;color:var(--text-dim);opacity:.5;transition:opacity .3s;text-transform:uppercase}
.brand-item:hover{opacity:1;color:var(--blue)}

/* ===== TESTIMONIAL CAROUSEL ===== */
.testimonial-carousel{max-width:700px;margin:0 auto;text-align:center;position:relative;min-height:200px}
.tc-track{position:relative}
.tc-slide{display:none;animation:tc-fade .6s ease}
.tc-slide.active{display:block}
@keyframes tc-fade{0%{opacity:0;transform:translateY(8px)}100%{opacity:1;transform:translateY(0)}}
.tc-google-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:50px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.55rem;letter-spacing:1.5px;color:var(--silver);margin-bottom:20px}
.tc-stars{color:#ffd700;font-size:1.2rem;letter-spacing:3px;margin-bottom:16px}
.tc-quote{font-size:clamp(1rem,2.5vw,1.15rem);color:var(--text);font-style:italic;line-height:1.9;margin-bottom:16px;max-width:600px;margin-left:auto;margin-right:auto}
.tc-author{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.7rem;letter-spacing:3px;color:var(--blue)}
.tc-dots{display:flex;justify-content:center;gap:8px;margin-top:20px}
.tc-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.15);cursor:pointer;transition:all .3s;border:none;padding:0}
.tc-dot.active{background:var(--blue);box-shadow:0 0 8px var(--blue-glow)}
.tc-dot:hover{background:rgba(0,191,255,.4)}

/* ===== GOOGLE REVIEWS BANNER ===== */
.google-reviews-bar{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 20px;flex-wrap:wrap}
.google-reviews-bar .stars{color:#ffd700;font-size:1.2rem;letter-spacing:2px}
.google-reviews-bar .rating-text{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.7rem;letter-spacing:2px;color:var(--silver)}
.google-reviews-bar a{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--blue);border:1px solid rgba(0,191,255,.2);padding:6px 16px;border-radius:50px;transition:all .3s}
.google-reviews-bar a:hover{background:rgba(0,191,255,.1)}

/* ===== STICKY MOBILE CTA ===== */
.sticky-mobile-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:999;
  padding:10px 16px;background:rgba(0,0,0,.95);backdrop-filter:blur(20px);
  border-top:1px solid rgba(0,191,255,.15);
}
.sticky-mobile-cta .sticky-inner{display:flex;gap:8px}
.sticky-mobile-cta a{flex:1;text-align:center;padding:12px 8px;border-radius:10px;font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:1.5px;font-weight:600;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:4px}
.sticky-cta-call,.sticky-btn-call{background:transparent;border:1px solid var(--blue);color:var(--blue)}
.sticky-cta-quote,.sticky-btn-book{background:linear-gradient(135deg,var(--blue-deep),var(--blue));color:#fff;border:none}
.sticky-btn-wa{background:#1da851;color:#fff;border:none;font-weight:700}
.sticky-mobile-cta a svg{width:16px;height:16px;vertical-align:middle;margin-right:4px;fill:currentColor;stroke:currentColor}

/* ===== PRODUCTS SHOWCASE ===== */
.products-showcase{display:grid;grid-template-columns:280px 1fr;gap:36px;align-items:center;max-width:900px;margin:0 auto}
.product-img-wrap{border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,.06);aspect-ratio:3/4}
.product-feature-img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.product-img-wrap:hover .product-feature-img{transform:scale(1.04)}
.brands-col{display:flex;flex-direction:column}

/* ===== CTA BANNER ===== */
.cta-banner{text-align:center;padding:80px 20px;background:linear-gradient(180deg,rgba(0,10,20,.8),rgba(0,0,0,.95))}
.cta-banner h2{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:clamp(1.2rem,3vw,1.8rem);font-weight:900;letter-spacing:2px;background:var(--chrome);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}
.cta-banner p{color:var(--text-dim);font-size:1rem;margin-bottom:28px}
.btn-green{
  display:inline-flex;align-items:center;gap:8px;padding:14px 32px;
  font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.7rem;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;
  color:#fff;background:#25d366;
  border:none;border-radius:50px;cursor:pointer;
  transition:all .3s;text-decoration:none;
}
.btn-green svg{width:20px;height:20px;fill:#fff;flex-shrink:0}
.btn-green:hover{background:#1eba56;box-shadow:0 0 20px rgba(37,211,102,.4)}
.btn-sm{padding:10px 20px;font-size:.6rem;letter-spacing:1.5px}
.service-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

/* ===== INSTAGRAM FEED ===== */
.ig-handle{color:var(--blue);font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.75rem;letter-spacing:1.5px;transition:color .3s}
.ig-handle:hover{color:#e1306c}
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-top:24px}
.ig-post{position:relative;aspect-ratio:1;overflow:hidden;border-radius:6px;display:block}
.ig-post img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,filter .5s ease}
.ig-post:hover img{transform:scale(1.08);filter:brightness(.7)}
.ig-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;background:rgba(0,0,0,.2)}
.ig-post:hover .ig-overlay{opacity:1}
@media(max-width:768px){.ig-grid{grid-template-columns:repeat(3,1fr);gap:4px}}
@media(max-width:480px){.ig-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== CHATBOT (styles in chatbot.js) ===== */
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 30px rgba(37,211,102,.5)}
.whatsapp-float svg{width:28px;height:28px;fill:#fff}

/* ===== VOUCHER CARD ===== */
.voucher-preview{
  max-width:500px;margin:0 auto;background:linear-gradient(135deg,#0a1a2a,#0d0d1a);
  border:2px solid rgba(0,191,255,.2);border-radius:var(--radius-lg);
  padding:40px;text-align:center;position:relative;overflow:hidden;
}
.voucher-preview::before{content:'';position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(0,191,255,.06),transparent 60%)}
.voucher-preview .voucher-amount{font-family:'Bebas Neue',sans-serif;font-size:4rem;color:var(--blue);letter-spacing:4px;text-shadow:0 0 30px var(--blue-glow)}
.voucher-preview .voucher-label{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.7rem;letter-spacing:3px;color:var(--silver);margin-top:8px}

/* ===== BLOG CARDS ===== */
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.blog-card{
  background:var(--card);border-radius:var(--radius-lg);
  border:1px solid rgba(255,255,255,.06);overflow:hidden;transition:all .4s;
  display:flex;flex-direction:column;
}
.blog-card:hover{border-color:rgba(0,191,255,.2);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,191,255,.08)}
.blog-card-img{height:200px;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-card-body .blog-tag{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.55rem;letter-spacing:2px;color:var(--blue);margin-bottom:8px}
.blog-card-body h3{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.82rem;letter-spacing:1.5px;color:var(--light-silver);margin-bottom:10px;line-height:1.4}
.blog-card-body p{font-size:.9rem;color:var(--text-dim);line-height:1.7;flex:1;margin-bottom:16px}
.blog-card-body .blog-link{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--blue)}

/* ===== BLOG ARTICLE ===== */
.article-content{max-width:740px;margin:0 auto}
.article-content h2{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:1rem;letter-spacing:2px;color:var(--light-silver);margin:32px 0 12px}
.article-content p{color:var(--text-dim);font-size:1rem;line-height:1.85;margin-bottom:16px}
.article-content strong{color:var(--silver)}
.article-meta{text-align:center;margin-bottom:32px}
.article-meta span{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--text-dim)}

/* ===== COVERAGE AREAS ===== */
.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.area-card{
  background:var(--card);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.04);
  padding:28px;transition:all .4s;text-align:center;
}
.area-card:hover{border-color:rgba(0,191,255,.2);background:rgba(0,191,255,.03)}
.area-card h3{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.8rem;letter-spacing:2px;color:var(--light-silver);margin-bottom:8px}
.area-card p{font-size:.88rem;color:var(--text-dim);line-height:1.7}

/* ===== BOOKING CALENDAR ===== */
.booking-card{max-width:600px;margin:0 auto;background:var(--card);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.06);padding:36px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center;margin:16px 0}
.cal-header{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.55rem;letter-spacing:2px;color:var(--text-dim);padding:8px 0}
.cal-day{padding:10px 4px;border-radius:8px;cursor:pointer;transition:all .2s;font-size:.9rem;color:var(--silver);-webkit-tap-highlight-color:transparent}
.cal-day:hover{background:rgba(0,191,255,.08);color:var(--blue)}
.cal-day.selected{background:var(--blue);color:#000;font-weight:700}
.cal-day.disabled{opacity:.2;cursor:default;pointer-events:none}
.cal-day.empty{pointer-events:none}
.cal-nav{display:flex;justify-content:space-between;align-items:center}
.cal-nav button{background:none;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--blue);padding:8px 14px;cursor:pointer;font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:2px;transition:all .3s}
.cal-nav button:hover{border-color:var(--blue);background:rgba(0,191,255,.08)}
.cal-nav span{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.75rem;letter-spacing:2px;color:var(--silver)}
.time-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:16px 0}
.time-slot{padding:10px;text-align:center;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;font-size:.85rem;color:var(--silver);transition:all .2s;-webkit-tap-highlight-color:transparent}
.time-slot:hover{border-color:var(--blue);color:var(--blue)}
.time-slot.selected{background:var(--blue);color:#000;border-color:var(--blue);font-weight:700}
.booking-summary{background:rgba(0,191,255,.03);border:1px solid rgba(0,191,255,.1);border-radius:12px;padding:20px;margin-top:16px;display:none}
.booking-summary.show{display:block}
.booking-summary p{font-size:.88rem;color:var(--text-dim);margin-bottom:6px}
.booking-summary strong{color:var(--blue)}

/* ===== REFERRAL/LOYALTY ===== */
.referral-card{
  max-width:600px;margin:0 auto;text-align:center;padding:40px;
  background:var(--card);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.06);
}
.referral-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:28px 0}
.ref-step{padding:16px}
.ref-step .ref-icon{font-size:2rem;margin-bottom:10px}
.ref-step h4{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:2px;color:var(--silver);margin-bottom:6px}
.ref-step p{font-size:.85rem;color:var(--text-dim);line-height:1.6}

/* ===== WHAT TO EXPECT ===== */
.expect-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.expect-card{background:var(--card);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.04);padding:28px;text-align:center}
.expect-card .expect-icon{font-size:1.8rem;margin-bottom:12px}
.expect-card h4{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.68rem;letter-spacing:2px;color:var(--silver);margin-bottom:8px}
.expect-card p{font-size:.88rem;color:var(--text-dim);line-height:1.7}

/* ===== MOBILE ===== */
@media(max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .process-grid{grid-template-columns:1fr 1fr}
  .process-step::after{display:none}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-grid-item.featured{grid-column:span 2}
  .blog-grid{grid-template-columns:1fr 1fr}
  .area-grid{grid-template-columns:1fr 1fr}
  .expect-grid{grid-template-columns:1fr 1fr}
  .services-layout{grid-template-columns:1fr;gap:24px}
  .svc-preview{order:-1}
  .svc-preview-img{height:220px}
  .about-layout{grid-template-columns:1fr;gap:32px}
  .about-text{text-align:center}
  .about-badges{justify-content:center}
  .products-showcase{grid-template-columns:1fr;gap:24px;text-align:center}
  .product-img-wrap{max-width:250px;margin:0 auto}
  .brands-col{align-items:center}
  .brands-row{justify-content:center}
}
@media(max-width:768px){
  .hamburger{display:flex}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;background:rgba(0,0,0,.96);
    padding:16px 20px;gap:12px;border-bottom:1px solid rgba(0,191,255,.08);
  }
  .nav-links.open{display:flex}
  .page-hero{padding:110px 20px 60px;min-height:40vh}
  .page-hero-content{text-align:center}
  .footer-grid{grid-template-columns:1fr}
  .footer-col{text-align:center}
  .footer-brand{align-items:center;text-align:center}
  .footer-brand p{max-width:none}
  .footer-logo{margin:0 auto}
  .footer-social-row{justify-content:center}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-grid-item.featured{grid-column:span 2}
  .stats-bar{padding:24px 0}
  .stats-row{gap:12px;padding:0 8px}
  .stat-number{font-size:1.6rem;letter-spacing:1px}
  .stat-label{font-size:.45rem;letter-spacing:1px}
  .sticky-mobile-cta{display:block}
  body{padding-bottom:62px}
  .wa-float{display:none}
  .whatsapp-float{display:none}
  .blog-grid{grid-template-columns:1fr}
  .area-grid{grid-template-columns:1fr}
  .expect-grid{grid-template-columns:1fr}
  .referral-steps{grid-template-columns:1fr}
  .time-slots{grid-template-columns:repeat(2,1fr)}

  /* Center all section content */
  .section{text-align:center}
  .section .container{text-align:center}

  /* Buttons - consistent sizing on mobile */
  .btn-primary{display:block;width:100%;max-width:320px;margin:0 auto;padding:16px 20px;font-size:.7rem;box-sizing:border-box}
  .btn-outline{display:block;width:100%;max-width:320px;margin:0 auto;padding:14px 20px;font-size:.65rem;box-sizing:border-box}
  .hero-cta .btn-primary{width:auto;display:inline-block;max-width:none;padding:14px 40px}

  /* About section mobile */
  .about-photo.main-photo{max-width:100%}
  .about-text{text-align:center}
  .about-text p{text-align:center}
  .about-badges{justify-content:center}
  .about-role{text-align:center}
  .about-name{text-align:center}

  /* Services page detail cards */

  /* Testimonials */
  .tc-quote{font-size:.9rem;padding:0 10px}
  .tc-author{font-size:.8rem}

  /* Referral card */
  .referral-card{padding:32px 20px;text-align:center}
  .referral-card p{text-align:center}

  /* FAQ */
  .faq-item{text-align:left}

  /* Forms */
  .form-group{text-align:left}
  .form-group input,.form-group textarea,.form-group select{width:100%;box-sizing:border-box}
  .checkbox-group{justify-content:center}

  /* Contact info cards */
  .contact-grid{text-align:center}
  .contact-card{text-align:center}

  /* Blog article */
  .article-body{text-align:left}
  .article-body p{text-align:left}

  /* Voucher */
  .voucher-options{flex-direction:column;align-items:center}

  /* Loyalty tiers */
  .loyalty-tiers{text-align:center}

  /* Before/after */
  .ba-slider{max-width:100%}
  .ba-grid{grid-template-columns:1fr}
  .ba-slider{aspect-ratio:1/1}

  /* Area cards */
  .area-card{text-align:center}
}
@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr}
  .gallery-grid-item.featured{grid-column:span 1}
  .process-grid{grid-template-columns:1fr}
  .checkbox-group{grid-template-columns:1fr}
  .stat-number{font-size:1.4rem}
  .stat-label{font-size:.4rem}
  .stats-row{gap:8px;padding:0 4px}
  .svc-item{padding:14px 16px}
  .svc-item-name{font-size:.65rem}
  .svc-item-price{font-size:1rem}
  .svc-number{font-size:1.1rem}
  .tc-quote{font-size:.85rem}
  .about-photo-grid{gap:8px}
  .brands-row{gap:6px}
  .brand-item{font-size:.55rem;padding:6px 12px}
}

/* ===== BLOG DATES ===== */
.blog-date{display:block;font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.5rem;letter-spacing:2px;color:var(--text-dim);margin-bottom:4px;text-transform:uppercase}
.article-date{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--text-dim);display:block;margin-bottom:8px}

/* Content visibility for below-fold sections */
.section{content-visibility:auto;contain-intrinsic-size:auto 600px}

/* ===== HOMEPAGE-SPECIFIC STYLES ===== */
.home-hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding:100px 20px 60px}
.home-hero-bg{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse at 30% 20%,rgba(0,191,255,.08) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(0,191,255,.05) 0%,transparent 50%),linear-gradient(180deg,#000 0%,#050510 40%,#000a14 70%,#000 100%)}
.home-hero .page-hero-img{opacity:.18;object-position:center 60%}
.hero-particles{position:absolute;inset:0;z-index:1;pointer-events:none}
.particle{position:absolute;width:2px;height:2px;background:var(--blue);border-radius:50%;opacity:0;animation:float-up linear infinite}
@keyframes float-up{0%{opacity:0;transform:translateY(100vh) scale(0)}10%{opacity:1}90%{opacity:1}100%{opacity:0;transform:translateY(-10vh) scale(1)}}
.hero-content{position:relative;z-index:2;max-width:900px;display:flex;flex-direction:column;align-items:center}
.hero-logo-wrap{display:inline-block;margin-bottom:40px;margin-top:-6vh;animation:logo-entrance 1.5s cubic-bezier(.16,1,.3,1) forwards;opacity:0}
@keyframes logo-entrance{0%{opacity:0;transform:scale(.7) translateY(30px)}100%{opacity:1;transform:scale(1) translateY(0)}}
.hero-logo{width:240px;margin:0 auto;filter:drop-shadow(0 0 25px var(--blue-glow)) drop-shadow(0 0 50px rgba(0,191,255,.12))}
.sparkle-container{position:relative;display:inline-block}
.sparkle{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--blue);pointer-events:none;animation:sparkle 2s ease-in-out infinite}
@keyframes sparkle{0%,100%{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}
.hero-tagline{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:clamp(1.5rem,5vw,3.2rem);font-weight:900;letter-spacing:2px;background:var(--chrome);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2;margin-bottom:10px;animation:tagline-in 1s .5s both;min-height:2.4em}
@keyframes tagline-in{0%{opacity:0;transform:translateY(20px);filter:blur(10px)}100%{opacity:1;transform:translateY(0);filter:blur(0)}}
.hero-sub{font-size:clamp(.9rem,2vw,1.2rem);color:var(--text-dim);letter-spacing:1px;margin-bottom:32px;animation:tagline-in 1s .8s both}
.hero-cta{animation:tagline-in 1s 1.1s both}
.scroll-indicator{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:2;animation:bounce 2s infinite 3s;cursor:pointer;display:block}
.scroll-indicator svg{width:22px;height:22px;stroke:var(--blue);opacity:.4}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* Gallery Strip / Marquee */
.gallery-strip{padding:12px 0;overflow:hidden;position:relative}
.gallery-strip::before,.gallery-strip::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.gallery-strip::before{left:0;background:linear-gradient(to right,var(--dark),transparent)}
.gallery-strip::after{right:0;background:linear-gradient(to left,var(--dark),transparent)}
.gallery-track{display:flex;gap:16px;animation:scroll-gallery 70s linear infinite;width:max-content}
.gallery-track:hover{animation-play-state:paused}
@keyframes scroll-gallery{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.g-item{flex-shrink:0;width:340px;height:220px;border-radius:var(--radius);overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.06);transition:all .4s}
.g-item:hover{border-color:rgba(0,191,255,.3);box-shadow:0 8px 35px rgba(0,191,255,.15);transform:translateY(-3px)}
.g-item img{width:100%;height:100%;object-fit:cover;object-position:center 40%;transition:transform .6s}
.g-item:hover img{transform:scale(1.06)}
.g-item .g-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 50%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:16px}
.g-item:hover .g-overlay{opacity:1}
.g-overlay span{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:2px;color:var(--blue)}

/* Service Cards (homepage 3-col grid) */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{background:var(--card);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.04);padding:32px 24px;text-align:center;transition:all .4s;color:inherit;text-decoration:none;display:block}
.svc-card:hover{border-color:rgba(0,191,255,.2);background:rgba(0,191,255,.03);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,191,255,.08);color:inherit}
.svc-card-icon{font-size:2rem;margin-bottom:12px}
.svc-card h3{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.75rem;letter-spacing:2px;color:var(--light-silver);margin-bottom:8px}
.svc-card p{font-size:.88rem;color:var(--text-dim);line-height:1.6;margin-bottom:16px}
.svc-card .price{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:var(--blue)}

/* Why Cruz Cards */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.why-card{padding:28px;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.04);background:var(--card);text-align:center;transition:all .4s}
.why-card:hover{border-color:rgba(0,191,255,.15);transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,191,255,.06)}
.why-icon{width:48px;height:48px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(0,191,255,.06);border:1px solid rgba(0,191,255,.12)}
.why-icon svg{width:22px;height:22px;color:var(--blue)}
.why-card h3{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:2px;color:var(--blue);margin-bottom:10px}
.why-card p{font-size:.85rem;color:var(--text-dim);line-height:1.7}

/* Homepage responsive overrides */
@media(max-width:900px){.why-grid{grid-template-columns:1fr 1fr}.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:768px){
  .why-grid{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .g-item{width:280px;height:180px}
  .home-hero{min-height:100svh;padding:90px 20px 50px}
  .hero-logo{width:160px}
  .hero-logo-wrap{margin-top:-2vh;margin-bottom:28px}
  .hero-tagline{font-size:clamp(1.3rem,5vw,2rem);min-height:auto}
  .hero-sub{font-size:.85rem;margin-bottom:24px}
  .home-hero .page-hero-img{object-position:center 55%}
}

/* Content visibility for below-fold performance */
.section{content-visibility:auto;contain-intrinsic-size:auto 600px}

/* Service detail structured descriptions */
.svc-section-label::after{content:'';flex:1;height:1px;background:rgba(0,191,255,.12)}
.extras-list li strong{color:var(--blue)}

/* ===== GALLERY FILTER BUTTONS ===== */
.gallery-filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}
.filter-btn{padding:8px 20px;background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:50px;color:var(--silver);font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:2px;cursor:pointer;transition:all .3s;text-transform:uppercase}
.filter-btn:hover{border-color:rgba(0,191,255,.3);color:var(--blue)}
.filter-btn.active{background:rgba(0,191,255,.08);border-color:var(--blue);color:var(--blue);box-shadow:0 0 15px rgba(0,191,255,.1)}

/* ===== SERVICE DETAIL (desktop 2-col layout) ===== */
.addon-tag{display:inline-block;padding:4px 14px;background:rgba(0,191,255,.08);border:1px solid rgba(0,191,255,.15);border-radius:50px;font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.55rem;letter-spacing:2px;color:var(--blue);margin-bottom:12px;text-transform:uppercase}

/* ===== QUOTE PAGE ===== */
.quote-card{background:var(--card);border-radius:var(--radius-lg);padding:40px;border:1px solid rgba(255,255,255,.06)}
.form-group{margin-bottom:20px}
.form-label{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:2px;color:var(--text-dim);margin-bottom:8px;display:block;text-transform:uppercase}
.quote-result{text-align:center;padding:20px;margin-top:12px;background:rgba(0,191,255,.03);border-radius:12px;border:1px solid rgba(0,191,255,.1)}
.quote-total{font-family:'Bebas Neue',sans-serif;font-size:3rem;color:var(--blue);letter-spacing:3px;text-shadow:0 0 25px var(--blue-glow)}

/* ===== REVIEWS CAROUSEL ===== */
.reviews-carousel{position:relative;max-width:700px;margin:0 auto;overflow:hidden}
.reviews-track{display:flex;transition:transform .5s ease}
.reviews-carousel .testimonial-card{flex:0 0 100%;padding:0 10px;box-sizing:border-box}
.reviews-dots{display:flex;justify-content:center;gap:8px;margin-top:20px}
.reviews-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.15);border:none;cursor:pointer;transition:all .3s;padding:0}
.reviews-dot.active{background:var(--blue);box-shadow:0 0 10px var(--blue-glow)}

/* ===== SERVICE DETAIL - DESKTOP ===== */
.service-detail{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;padding:60px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.service-detail:nth-child(even){direction:rtl}
.service-detail:nth-child(even) > *{direction:ltr}
.service-detail-img{border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,.06);aspect-ratio:4/3;position:sticky;top:90px}
.service-detail-img img{width:100%;height:100%;object-fit:cover}
.service-detail-body h3{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:clamp(1.2rem,3vw,1.6rem);font-weight:700;letter-spacing:2px;color:#fff;margin-bottom:8px}
.service-detail-body .price{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--blue);letter-spacing:2px;margin-bottom:4px}
.service-detail-body .price-note{font-size:.78rem;color:var(--text-dim);margin-bottom:16px}
.service-detail-body p{font-size:.92rem;color:var(--text-dim);line-height:1.7;margin-bottom:12px}
.service-detail-body ul{columns:2;column-gap:24px;margin-bottom:16px}
.service-detail-body li{break-inside:avoid;padding:5px 0;font-size:.85rem}
.svc-section-label{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.55rem;letter-spacing:2px;text-transform:uppercase;color:var(--blue);margin:18px 0 8px;display:flex;align-items:center;gap:8px}
.svc-section-label::after{content:'';flex:1;height:1px;background:rgba(0,191,255,.12)}
.extras-list{list-style:none;padding:0}
.extras-list li{padding:8px 12px;margin-bottom:6px;background:rgba(0,191,255,.04);border:1px solid rgba(0,191,255,.08);border-radius:8px;font-size:.85rem;color:var(--silver)}
.extras-list li strong{color:var(--blue)}

/* ===== SERVICE DETAIL - MOBILE ===== */
@media(max-width:768px){
  .service-detail{grid-template-columns:1fr;gap:0;padding:30px 0;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.06);overflow:hidden;margin-bottom:24px;background:var(--card)}
  .service-detail-img{border-radius:0;aspect-ratio:16/9;position:static}
  .service-detail-body{padding:20px}
  .service-detail-body h3{font-size:1.1rem;text-align:left}
  .service-detail-body .price-note{font-size:.72rem}
  .service-detail-body p{font-size:.85rem;line-height:1.6;text-align:left}
  .service-detail-body ul{columns:1;margin-bottom:12px;padding-left:18px}
  .service-detail-body li{padding:3px 0;font-size:.8rem}
  .svc-section-label{font-size:.5rem;margin:14px 0 6px}
  .service-cta-row{justify-content:center}
  .addon-tag{margin-bottom:12px;font-size:.5rem}
}

/* ===== QUOTE CALCULATOR ===== */
.quote-card{background:var(--card);border-radius:var(--radius-lg);padding:40px;border:1px solid rgba(255,255,255,.06);max-width:700px;margin:0 auto}
.form-group{margin-bottom:24px}
.form-label{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.65rem;letter-spacing:2px;color:var(--text-dim);margin-bottom:10px;display:block;text-transform:uppercase}
.checkbox-group{display:flex;flex-direction:column;gap:10px}
.checkbox-item{position:relative}
.checkbox-item input{display:none}
.checkbox-item label{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.08);border-radius:12px;cursor:pointer;transition:all .3s;-webkit-tap-highlight-color:transparent}
.checkbox-item label:hover{border-color:rgba(0,191,255,.2);background:rgba(0,191,255,.03)}
.checkbox-item input:checked + label{border-color:var(--blue);background:rgba(0,191,255,.08);box-shadow:0 0 20px rgba(0,191,255,.1)}
.cb-name{font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.8rem;font-weight:600;letter-spacing:1.5px;color:var(--silver);transition:color .3s}
.checkbox-item input:checked + label .cb-name{color:#fff}
.cb-price{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--blue);letter-spacing:1px}
.cb-price small{font-size:.6rem;color:var(--text-dim);letter-spacing:1px;font-family:'Rajdhani',sans-serif;vertical-align:middle;margin-left:2px}
.quote-result{text-align:center;padding:24px;margin-top:16px;background:rgba(0,191,255,.03);border-radius:12px;border:1px solid rgba(0,191,255,.1)}
.quote-total{font-family:'Bebas Neue',sans-serif;font-size:3.5rem;color:var(--blue);letter-spacing:3px;text-shadow:0 0 25px var(--blue-glow)}
@media(max-width:480px){
  .quote-card{padding:24px 18px}
  .checkbox-item label{padding:16px 18px}
  .cb-name{font-size:.7rem}
  .cb-price{font-size:1.2rem}
  .quote-total{font-size:2.8rem}
}

/* Quote checkbox visual check */
.cb-left{display:flex;align-items:center;gap:14px}
.cb-check{width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}
.cb-check::after{content:'';width:6px;height:10px;border:solid transparent;border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px);transition:border-color .3s}
.checkbox-item input:checked + label .cb-check{border-color:var(--blue);background:var(--blue)}
.checkbox-item input:checked + label .cb-check::after{border-color:#000}

/* ===== CONTACT PAGE ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;max-width:900px;margin:0 auto}
.contact-info-card,.contact-form-card{background:var(--card);border-radius:var(--radius-lg);padding:32px;border:1px solid rgba(255,255,255,.06)}
.contact-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.04);text-decoration:none;transition:background .3s;border-radius:6px;margin:0 -8px;padding-left:8px;padding-right:8px}
a.contact-row:hover{background:rgba(0,191,255,.04)}
.contact-icon{width:42px;height:42px;border-radius:10px;background:rgba(0,191,255,.06);border:1px solid rgba(0,191,255,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-label{display:block;font-family:'Orbitron','Orbitron-fallback',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--text-dim);margin-bottom:2px;text-transform:uppercase}
.contact-value{display:block;color:var(--silver);font-size:.92rem}
@media(max-width:768px){
  .contact-grid{grid-template-columns:1fr;gap:20px}
  .contact-info-card{padding:20px}
  .contact-form-card{padding:24px}
  .contact-row{padding:12px 8px}
  .contact-icon{width:38px;height:38px}
  .contact-value{font-size:.85rem}
  .map-wrap iframe{height:280px}
}
@media(max-width:480px){
  .contact-info-card{padding:16px}
  .contact-form-card{padding:18px}
  .contact-value{font-size:.8rem}
}
