/* ============================================================
   HEADLIGHT RESCUE — Design System (Red · Black · White)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800;900&display=swap');

:root {
  --red:        #e31d1a;
  --red-dark:   #b91514;
  --red-light:  #ff3b38;
  --red-glow:   rgba(227,29,26,0.25);
  --black:      #0a0a0a;
  --black-2:    #111111;
  --black-3:    #1a1a1a;
  --white:      #ffffff;
  --white-90:   rgba(255,255,255,0.9);
  --white-60:   rgba(255,255,255,0.6);
  --white-20:   rgba(255,255,255,0.12);
  --white-10:   rgba(255,255,255,0.07);
  --white-5:    rgba(255,255,255,0.04);
  --gray-100:   #f5f5f5;
  --gray-200:   #e8e8e8;
  --gray-400:   #a0a0a0;
  --gray-600:   #555555;
  --font-display: 'Bebas Neue', sans-serif;
  --font-head:    'Outfit', sans-serif;
  --font-body:    'Inter', sans-serif;
  --r-sm: 6px; --r-md: 10px; --r-lg: 16px; --r-xl: 24px; --r-full: 9999px;
  --t-fast: 150ms ease; --t-base: 250ms ease; --t-slow: 400ms ease;
  --shadow-red: 0 0 30px rgba(227,29,26,0.3);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.5);
}

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--black);color:var(--white);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:var(--red);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--red-light)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button{cursor:pointer;border:none;outline:none;font-family:var(--font-body)}

/* ── Typography ── */
h1,h2,h3,h4{font-family:var(--font-head);font-weight:800;line-height:1.15;color:var(--white)}
h1{font-size:clamp(2.4rem,5.5vw,4.2rem);font-weight:900}
h2{font-size:clamp(1.8rem,3.5vw,3rem);font-weight:800}
h3{font-size:clamp(1.1rem,2vw,1.5rem);font-weight:700}
p{color:var(--white-60);line-height:1.7}

.text-red{color:var(--red)}
.text-dark{color:var(--black)!important}
.text-dark-secondary{color:var(--gray-600)!important}
.text-white-outline{
  -webkit-text-stroke:2px var(--white);
  -webkit-text-fill-color:transparent;
}

/* ── Layout ── */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}
.section{padding:6rem 0}
.section-dark{background:var(--black-2)}
.section-white{background:var(--white)}

.section-header{text-align:center;margin-bottom:4rem}
.section-header p{margin-top:1rem;font-size:1.1rem;max-width:600px;margin-left:auto;margin-right:auto}

.section-label{
  display:inline-block;font-family:var(--font-head);font-size:0.75rem;font-weight:700;
  text-transform:uppercase;letter-spacing:3px;color:var(--red);
  padding:0.3rem 1rem;background:rgba(227,29,26,0.08);
  border:1px solid rgba(227,29,26,0.25);border-radius:var(--r-full);margin-bottom:1rem;
}
.section-label-dark{color:var(--red-dark);background:rgba(227,29,26,0.06)}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;
  padding:0.75rem 1.75rem;font-size:0.95rem;font-weight:600;border-radius:var(--r-md);
  transition:all var(--t-base);text-decoration:none;border:none;cursor:pointer;font-family:var(--font-head);letter-spacing:0.5px;
}
.btn-xl{padding:1.1rem 2.5rem;font-size:1.05rem;border-radius:var(--r-lg)}
.btn-sm{padding:0.5rem 1.25rem;font-size:0.85rem}
.btn-full{width:100%;justify-content:center}

.btn-red{background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;box-shadow:var(--shadow-red)}
.btn-red:hover{background:linear-gradient(135deg,var(--red-light),var(--red));box-shadow:0 0 45px rgba(227,29,26,0.5);transform:translateY(-2px);color:#fff}

.btn-white-outline{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,0.4)}
.btn-white-outline:hover{background:rgba(255,255,255,0.08);border-color:var(--white);transform:translateY(-2px);color:var(--white)}

.btn-outline-red{background:transparent;color:var(--red);border:2px solid var(--red)}
.btn-outline-red:hover{background:rgba(227,29,26,0.08);transform:translateY(-2px);color:var(--red)}

.pulse-btn{animation:pulse-red 2.5s ease-in-out infinite}
@keyframes pulse-red{0%,100%{box-shadow:0 0 20px rgba(227,29,26,0.4)}50%{box-shadow:0 0 50px rgba(227,29,26,0.7),0 0 80px rgba(227,29,26,0.3)}}

/* ── Navbar ── */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1rem 0;transition:background var(--t-base),box-shadow var(--t-base),padding var(--t-base);
}
.navbar.scrolled{
  background:rgba(10,10,10,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 2px 30px rgba(0,0,0,0.5),0 1px 0 rgba(227,29,26,0.2);padding:0.6rem 0;
}
.navbar .container{display:flex;align-items:center;justify-content:space-between}

.nav-logo{
  display:flex;align-items:center;gap:0.5rem;font-family:var(--font-head);
  font-weight:800;font-size:1.4rem;color:var(--white);text-decoration:none;
}
.nav-logo img{
  width:76px;height:76px;border-radius:0;
  object-fit:contain;background:none;
  mix-blend-mode:lighten;
  filter:brightness(1.2) contrast(1.1) drop-shadow(0 2px 10px rgba(227,29,26,0.6));
  transform:scale(1.05);
}
.nav-logo span{color:var(--red)}

.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{color:var(--white-60);font-weight:500;font-size:0.9rem;position:relative;transition:color var(--t-fast)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--red);transition:width var(--t-base)}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;padding:0.5rem}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:all var(--t-base)}

/* ── Hero ── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}

.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:0.3}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(135deg,rgba(0,0,0,0.92) 0%,rgba(140,10,10,0.18) 50%,rgba(0,0,0,0.88) 100%);
}
.hero::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;z-index:10;
  background:linear-gradient(90deg,transparent,var(--red),var(--red-light),var(--red),transparent);
}
.hero-glow{
  position:absolute;width:600px;height:600px;border-radius:50%;z-index:1;
  background:radial-gradient(circle,rgba(227,29,26,0.12) 0%,transparent 70%);
  top:10%;right:0;animation:pulse-glow 5s ease-in-out infinite;
}
.hero-glow-2{
  position:absolute;width:350px;height:350px;border-radius:50%;z-index:1;
  background:radial-gradient(circle,rgba(227,29,26,0.07) 0%,transparent 70%);
  bottom:15%;left:5%;animation:pulse-glow 7s ease-in-out infinite reverse;
}
@keyframes pulse-glow{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.2);opacity:1}}

.hero .container{position:relative;z-index:2;padding-top:6rem;padding-bottom:4rem}
.hero-content{max-width:780px}

.hero-tagline{
  display:inline-flex;align-items:center;gap:0.75rem;font-family:var(--font-head);
  font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:4px;
  color:var(--red-light);margin-bottom:1.5rem;
}
.tagline-dot{width:6px;height:6px;border-radius:50%;background:var(--red);display:inline-block}

.hero-content h1{margin-bottom:1.25rem;letter-spacing:-1px}
.hero-sub{font-size:1.2rem;color:var(--white-60);margin-bottom:2rem;max-width:580px}

.hero-badges{display:flex;flex-wrap:wrap;gap:0.75rem;margin-bottom:2.5rem}
.trust-badge{
  display:inline-flex;align-items:center;gap:0.5rem;padding:0.5rem 1rem;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--r-full);font-size:0.85rem;font-weight:600;color:var(--white-90);
  backdrop-filter:blur(8px);transition:all var(--t-base);
}
.trust-badge:hover{background:rgba(227,29,26,0.1);border-color:rgba(227,29,26,0.3);transform:translateY(-2px)}
.badge-icon{font-size:1rem}

.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}

.hero-scroll-indicator{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:0.5rem;z-index:2;
  animation:bounce-down 2s ease-in-out infinite;
}
.scroll-text{font-size:0.75rem;text-transform:uppercase;letter-spacing:2px;color:var(--white-60)}
.scroll-arrow{color:var(--red);display:flex}
@keyframes bounce-down{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ── Scroll Animations ── */
[data-animate]{opacity:0;transform:translateY(30px);transition:opacity 0.7s ease,transform 0.7s ease}
[data-animate].animated{opacity:1;transform:none}

/* ── Comparison Slider ── */
.comparison-container{max-width:900px;margin:0 auto 3rem;text-align:center}
.comparison-slider{
  position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--r-lg);
  overflow:hidden;cursor:ew-resize;user-select:none;box-shadow:var(--shadow-lg);
}
.comparison-after,.comparison-before{position:absolute;inset:0}
.comparison-after img,.comparison-before img{width:100%;height:100%;object-fit:cover}

.comparison-before{width:50%;overflow:hidden}
.comparison-before img{width:200%;max-width:none}

.comparison-tag{
  position:absolute;top:1rem;padding:0.4rem 1rem;border-radius:var(--r-full);
  font-size:0.75rem;font-weight:700;font-family:var(--font-head);letter-spacing:2px;text-transform:uppercase;
}
.tag-after{right:1rem;background:var(--red);color:#fff}
.tag-before{left:1rem;background:rgba(0,0,0,0.7);color:var(--white-90);border:1px solid rgba(255,255,255,0.2)}

.comparison-handle{
  position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;z-index:10;
}
.handle-bar{flex:1;width:3px;background:var(--white)}
.handle-circle{
  width:48px;height:48px;border-radius:50%;background:var(--white);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(0,0,0,0.4);color:var(--black);flex-shrink:0;
}
.comparison-hint{font-size:0.85rem;color:var(--white-60);margin-top:0.75rem;letter-spacing:1px}

.results-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.result-card{
  padding:2rem;background:var(--white-10);border:1px solid var(--white-20);
  border-radius:var(--r-lg);text-align:center;transition:all var(--t-base);
}
.result-card:hover{background:rgba(227,29,26,0.07);border-color:rgba(227,29,26,0.3);transform:translateY(-4px)}
.result-icon{font-size:2.2rem;margin-bottom:1rem}
.result-card h3{margin-bottom:0.5rem;font-size:1.1rem}
.result-card p{font-size:0.9rem}

/* ── Benefits ── */
.benefits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.benefit-item{
  display:flex;gap:1.25rem;align-items:flex-start;padding:1.75rem;
  background:var(--gray-100);border-radius:var(--r-lg);border:1px solid var(--gray-200);
  transition:all var(--t-base);
}
.benefit-item:hover{box-shadow:0 8px 30px rgba(227,29,26,0.08);transform:translateY(-3px);border-color:rgba(227,29,26,0.2)}
.benefit-icon-wrap{
  width:52px;height:52px;border-radius:var(--r-md);background:rgba(227,29,26,0.08);
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;
}
.benefit-item h3{font-size:1rem;margin-bottom:0.4rem}
.benefit-item p{font-size:0.9rem}

/* ── Why Choose Us ── */
.why-us-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.why-us-content .section-label{margin-bottom:1rem;display:block}
.why-us-content h2{margin-bottom:1rem}
.why-us-content>p{margin-bottom:2rem}

.why-features{display:flex;flex-direction:column;gap:1.25rem}
.why-feature{
  display:flex;gap:1rem;align-items:flex-start;padding:1.25rem;
  background:var(--white-5);border:1px solid var(--white-10);border-radius:var(--r-md);
  transition:all var(--t-base);
}
.why-feature:hover{background:rgba(227,29,26,0.05);border-color:rgba(227,29,26,0.2)}
.check-icon{
  width:28px;height:28px;border-radius:50%;background:var(--red);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.85rem;flex-shrink:0;margin-top:2px;
}
.why-feature strong{display:block;margin-bottom:0.25rem;color:var(--white);font-size:0.95rem}
.why-feature p{font-size:0.85rem;color:var(--white-60)}

.stat-card-group{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.big-stat{
  padding:2rem;background:var(--white-5);border:1px solid var(--white-10);
  border-radius:var(--r-lg);text-align:center;transition:all var(--t-base);
}
.big-stat:hover{background:rgba(227,29,26,0.06);border-color:rgba(227,29,26,0.25);transform:translateY(-4px)}
.stat-num{
  display:block;font-family:var(--font-head);font-size:2.2rem;font-weight:900;
  color:var(--red);margin-bottom:0.5rem;
}
.stat-desc{font-size:0.8rem;color:var(--white-60);line-height:1.4}

/* ── Services ── */
.services-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.svc-card{
  padding:2rem;background:var(--gray-100);border:1px solid var(--gray-200);
  border-radius:var(--r-lg);transition:all var(--t-base);position:relative;
}
.svc-card:hover{box-shadow:0 10px 40px rgba(227,29,26,0.1);transform:translateY(-4px);border-color:rgba(227,29,26,0.2)}
.svc-icon-wrap{font-size:2.2rem;margin-bottom:1.25rem}
.svc-card h3{margin-bottom:0.75rem;font-size:1.1rem}
.svc-card p{font-size:0.9rem;margin-bottom:1.25rem}
.svc-link{
  font-family:var(--font-head);font-weight:700;font-size:0.9rem;color:var(--red);
  letter-spacing:0.5px;transition:all var(--t-fast);
}
.svc-link:hover{color:var(--red-dark);letter-spacing:1px}

.svc-card-featured{
  background:linear-gradient(135deg,var(--red-dark),var(--red));
  border-color:var(--red);color:#fff;
}
.svc-card-featured h3,.svc-card-featured p{color:#fff}
.svc-card-featured p{color:rgba(255,255,255,0.8)}
.svc-card-featured:hover{box-shadow:0 10px 50px rgba(227,29,26,0.4)}
.svc-link-white{color:#fff}
.svc-link-white:hover{color:rgba(255,255,255,0.8)}
.svc-featured-badge{
  position:absolute;top:1rem;right:1rem;background:#fff;color:var(--red);
  font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;
  padding:0.2rem 0.6rem;border-radius:var(--r-full);
}

/* ── Testimonials ── */
.testimonials-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.testi-card{
  padding:2.25rem;background:var(--black-3);border:1px solid var(--white-10);
  border-radius:var(--r-lg);transition:all var(--t-base);
}
.testi-card:hover{border-color:rgba(227,29,26,0.25);transform:translateY(-4px);box-shadow:0 10px 40px rgba(227,29,26,0.07)}
.testi-stars{font-size:1.1rem;color:#f59e0b;letter-spacing:3px;margin-bottom:1rem}
.testi-card blockquote{font-size:0.97rem;color:var(--white-60);font-style:italic;line-height:1.7;margin-bottom:1.5rem}
.testi-author{display:flex;align-items:center;gap:1rem}
.testi-avatar{
  width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--red),var(--red-dark));
  display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;color:#fff;
}
.testi-author strong{display:block;font-size:0.9rem;color:var(--white)}
.testi-author span{font-size:0.8rem;color:var(--white-60)}

/* ── Pricing ── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.pricing-card{
  padding:2.5rem 2rem;background:var(--white);border:2px solid var(--gray-200);
  border-radius:var(--r-xl);transition:all var(--t-base);position:relative;
}
.pricing-card:hover{box-shadow:0 12px 40px rgba(227,29,26,0.1);transform:translateY(-4px);border-color:var(--red)}
.pricing-featured{
  background:linear-gradient(160deg,#0a0a0a 0%,#1a0404 100%);
  border:2px solid var(--red);color:#fff;transform:scale(1.04);
}
.pricing-featured h3{color:#fff}
.pricing-featured:hover{transform:scale(1.04) translateY(-4px);box-shadow:0 16px 60px rgba(227,29,26,0.35)}
.pricing-popular-badge{
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  background:var(--red);color:#fff;font-size:0.7rem;font-weight:700;
  text-transform:uppercase;letter-spacing:1.5px;padding:0.3rem 1.2rem;
  border-radius:0 0 var(--r-md) var(--r-md);
}
.pricing-tier-label{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--red);margin-bottom:0.5rem}
.pricing-card h3{margin-bottom:1.5rem;font-size:1.2rem}
.pricing-amount{margin-bottom:1.75rem}
.price-from{display:block;font-size:0.85rem;color:var(--gray-400);margin-bottom:0.25rem}
.pricing-featured .price-from{color:rgba(255,255,255,0.5)}
.price-value{font-family:var(--font-head);font-size:3rem;font-weight:900;color:var(--red);letter-spacing:-1px}
.price-per{font-size:0.9rem;color:var(--gray-400);margin-left:0.25rem}
.pricing-featured .price-per{color:rgba(255,255,255,0.5)}
.pricing-features{margin-bottom:2rem}
.pricing-features li{
  display:flex;align-items:flex-start;gap:0.6rem;padding:0.6rem 0;
  border-bottom:1px solid var(--gray-200);font-size:0.9rem;color:var(--gray-600);
}
.pricing-featured .pricing-features li{border-color:rgba(255,255,255,0.08);color:rgba(255,255,255,0.7)}
.pricing-features li:last-child{border-bottom:none}
.pf-check{color:var(--red);font-weight:700;flex-shrink:0}
.pricing-note{text-align:center;margin-top:2rem;font-size:0.85rem;color:var(--gray-400);font-style:italic}

/* ── CTA Section ── */
.cta-section{
  position:relative;padding:8rem 0;background:var(--black);text-align:center;overflow:hidden;
}
.cta-bg{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(227,29,26,0.15) 0%,transparent 70%);
}
.cta-section::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
}
.cta-section::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
}
.cta-content{position:relative;z-index:1;max-width:700px;margin:0 auto}
.cta-badge{
  display:inline-block;font-size:0.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:3px;color:var(--red);border:1px solid rgba(227,29,26,0.3);
  padding:0.3rem 1rem;border-radius:var(--r-full);margin-bottom:1.5rem;
}
.cta-content h2{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:1.25rem}
.cta-content p{font-size:1.1rem;margin-bottom:2.5rem}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ── Contact ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-info .section-label{margin-bottom:1rem;display:block}
.contact-info h2{margin-bottom:1rem}
.contact-info>p{margin-bottom:2rem}
.contact-details{display:flex;flex-direction:column;gap:1rem}
.contact-item{
  display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;
  background:var(--white-5);border:1px solid var(--white-10);border-radius:var(--r-md);
  color:var(--white);transition:all var(--t-base);
}
.contact-item:hover{background:rgba(227,29,26,0.06);border-color:rgba(227,29,26,0.2);color:var(--white)}
.contact-icon{font-size:1.5rem;flex-shrink:0}
.contact-item strong{display:block;font-size:0.8rem;text-transform:uppercase;letter-spacing:1px;color:var(--white-60);margin-bottom:0.2rem;font-family:var(--font-head)}
.contact-item span{font-size:0.9rem;color:var(--white)}

.contact-cta-box{
  padding:2.5rem;background:linear-gradient(160deg,rgba(227,29,26,0.07) 0%,rgba(0,0,0,0) 100%);
  border:1px solid rgba(227,29,26,0.2);border-radius:var(--r-xl);
}
.contact-cta-box h3{margin-bottom:0.75rem}
.contact-cta-box p{margin-bottom:2rem}
.contact-social{margin-top:1.5rem;display:flex;align-items:center;gap:0.75rem;justify-content:center}
.social-link{
  display:inline-flex;align-items:center;gap:0.5rem;font-size:0.85rem;
  color:var(--white-60);transition:color var(--t-fast);
}
.social-link:hover{color:var(--red)}
.contact-handle{
  margin-top:0.75rem;text-align:center;font-size:0.85rem;font-weight:600;
  color:var(--red);letter-spacing:0.5px;
  font-family:var(--font-head);
}

/* ── Footer ── */
.footer{background:var(--black-2);border-top:1px solid var(--white-10);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand p{margin-top:1rem;font-size:0.88rem;color:var(--white-60)}
.footer .nav-logo img{width:64px;height:64px;border-radius:0;object-fit:contain;background:none;mix-blend-mode:screen;filter:brightness(1.05)}
.footer-col h4{font-size:0.8rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--white-60);margin-bottom:1.25rem;font-family:var(--font-head)}
.footer-col ul li{margin-bottom:0.6rem}
.footer-col ul li a{font-size:0.88rem;color:var(--white-60);transition:color var(--t-fast)}
.footer-col ul li a:hover{color:var(--red)}
.footer-col ul li span{font-size:0.88rem;color:var(--white-60)}
.footer-social{display:flex;gap:0.75rem;margin-top:1.25rem}
.footer-social-link{
  width:36px;height:36px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;
  background:var(--white-10);color:var(--white-60);border:1px solid var(--white-10);transition:all var(--t-base);
}
.footer-social-link:hover{background:rgba(227,29,26,0.15);color:var(--red);border-color:rgba(227,29,26,0.3)}
.footer-bottom{
  border-top:1px solid var(--white-10);padding-top:1.5rem;display:flex;
  justify-content:space-between;align-items:center;font-size:0.82rem;color:var(--white-60);
}
.footer-tagline{color:var(--red)}

/* ── Form (booking page) ── */
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:0.88rem;font-weight:500;color:var(--white-60);margin-bottom:0.5rem}
.form-input{
  width:100%;padding:0.75rem 1rem;background:var(--black-3);
  border:1.5px solid var(--white-10);border-radius:var(--r-md);
  color:var(--white);font-size:0.95rem;transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.form-input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(227,29,26,0.1)}
.form-input::placeholder{color:var(--white-60)}
textarea.form-input{resize:vertical;min-height:100px}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23a0a0a0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.form-error{color:var(--red);font-size:0.8rem;margin-top:0.25rem}

/* Cards, modals, toast, admin — preserved from previous */
.card{
  background:rgba(18,18,18,0.85);backdrop-filter:blur(12px);border:1px solid var(--white-10);
  border-radius:var(--r-lg);padding:2rem;transition:all var(--t-base);
}
.card:hover{border-color:rgba(227,29,26,0.2);box-shadow:0 8px 40px rgba(227,29,26,0.08);transform:translateY(-4px)}

.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--r-full);font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.badge-success{background:rgba(34,197,94,.12);color:#22c55e}
.badge-warning{background:rgba(245,158,11,.12);color:#f59e0b}
.badge-danger{background:rgba(239,68,68,.12);color:#ef4444}

.toast-container{position:fixed;top:1.5rem;right:1.5rem;z-index:3000;display:flex;flex-direction:column;gap:.5rem}
.toast{background:var(--black-2);border:1px solid var(--white-10);border-radius:var(--r-md);padding:.75rem 1.25rem;display:flex;align-items:center;gap:.75rem;min-width:280px;box-shadow:var(--shadow-lg);animation:slideInRight .3s ease}
.toast.success{border-left:3px solid #22c55e}
.toast.error{border-left:3px solid var(--red)}
.toast.warning{border-left:3px solid #f59e0b}
@keyframes slideInRight{from{opacity:0;transform:translateX(80px)}to{opacity:1;transform:none}}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:2000;display:none;align-items:center;justify-content:center;padding:1.5rem}
.modal-overlay.active{display:flex;animation:fadeIn .2s ease}
.modal{background:var(--black-2);border:1px solid rgba(227,29,26,.2);border-radius:var(--r-xl);padding:2.5rem;max-width:500px;width:100%;animation:slideUp .3s ease;position:relative}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;color:var(--white-60);font-size:1.5rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--t-fast)}
.modal-close:hover{background:var(--white-10);color:var(--white)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:none}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* Page header */
.page-header{padding:calc(80px + 3rem) 0 2.5rem;text-align:center;background:linear-gradient(to bottom,var(--black-2),var(--black));border-bottom:1px solid var(--white-10)}

/* Booking steps */
.booking-steps{display:flex;justify-content:center;gap:.5rem;margin-bottom:3rem}
.step-indicator{display:flex;align-items:center;gap:.5rem}
.step-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:.85rem;font-weight:700;background:var(--black-3);color:var(--white-60);border:2px solid var(--white-10);transition:all var(--t-base)}
.step-indicator.active .step-dot{background:var(--red);color:#fff;border-color:var(--red);box-shadow:var(--shadow-red)}
.step-indicator.completed .step-dot{background:var(--red-dark);color:#fff;border-color:var(--red-dark)}
.step-label{font-size:.85rem;color:var(--white-60);font-weight:500;transition:color var(--t-base)}
.step-indicator.active .step-label{color:var(--red)}
.step-connector{width:50px;height:2px;background:var(--white-10);align-self:center;margin-top:-20px}
.step-connector.completed{background:var(--red)}
.booking-step-content{display:none;animation:fadeInUp .4s ease}
.booking-step-content.active{display:block}

/* Calendar */
.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:1.5rem}
.calendar-day-label{text-align:center;font-size:.75rem;font-weight:600;color:var(--white-60);text-transform:uppercase;padding:.5rem}
.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);font-size:.9rem;font-weight:500;cursor:default;color:var(--white-60);transition:all var(--t-fast)}
.calendar-day.available{cursor:pointer;color:var(--white);background:var(--black-3);border:1px solid var(--white-10)}
.calendar-day.available:hover{border-color:var(--red);background:rgba(227,29,26,.08)}
.calendar-day.selected{background:var(--red);color:#fff;font-weight:700;border-color:var(--red)}
.calendar-day.today{border:2px solid var(--red)}
.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.5rem}
.time-slot{padding:.5rem 1rem;background:var(--black-3);border:1.5px solid var(--white-10);border-radius:var(--r-md);text-align:center;font-size:.9rem;font-weight:500;color:var(--white-60);cursor:pointer;transition:all var(--t-fast)}
.time-slot:hover{border-color:var(--red);color:var(--white);background:rgba(227,29,26,.06)}
.time-slot.selected{background:var(--red);color:#fff;font-weight:700;border-color:var(--red)}
.time-slot.booked{opacity:.35;cursor:not-allowed;text-decoration:line-through}

/* Booking Summary */
.booking-summary{background:var(--black-3);border:1px solid rgba(227,29,26,.15);border-radius:var(--r-lg);padding:1.5rem}
.summary-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--white-10)}
.summary-row:last-child{border-bottom:none}
.summary-row .label{color:var(--white-60);font-size:.9rem}
.summary-row .value{font-weight:600;color:var(--white);font-size:.9rem}

/* Success / ref */
.success-icon{width:80px;height:80px;border-radius:50%;background:rgba(34,197,94,.1);border:2px solid #22c55e;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:2rem;color:#22c55e;animation:scaleIn .4s ease}
@keyframes scaleIn{from{transform:scale(0)}to{transform:scale(1)}}
.ref-code{font-family:monospace;font-size:1.4rem;font-weight:700;color:var(--red);letter-spacing:3px;background:rgba(227,29,26,.08);padding:.5rem 1.25rem;border-radius:var(--r-md);display:inline-block;margin:.75rem 0}

/* Admin */
.admin-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.admin-sidebar{background:var(--black-2);border-right:1px solid var(--white-10);padding:1.5rem;position:sticky;top:0;height:100vh;overflow-y:auto}
.admin-sidebar .nav-logo{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--white-10)}
.admin-nav-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:var(--r-md);color:var(--white-60);font-weight:500;transition:all var(--t-fast);margin-bottom:.25rem;cursor:pointer;font-size:.95rem}
.admin-nav-item:hover{background:rgba(227,29,26,.06);color:var(--white)}
.admin-nav-item.active{background:rgba(227,29,26,.1);color:var(--red);border:1px solid rgba(227,29,26,.15)}
.admin-main{padding:2rem;overflow-y:auto}
.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}
.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{padding:1.5rem}
.stat-card .stat-value{font-family:var(--font-head);font-size:2rem;font-weight:800;color:var(--red)}
.stat-card .stat-label{font-size:.85rem;color:var(--white-60);margin-top:.25rem}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{text-align:left;padding:.75rem 1rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--white-60);border-bottom:1px solid var(--white-10)}
.admin-table td{padding:.75rem 1rem;font-size:.9rem;color:var(--white-60);border-bottom:1px solid var(--white-10)}
.admin-table tr:hover td{background:rgba(227,29,26,.02)}
.admin-tab-content{display:none}
.admin-tab-content.active{display:block;animation:fadeInUp .3s ease}
.slot-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.slot-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.slot-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:var(--black-3);border:1px solid var(--white-10);border-radius:var(--r-full);font-size:.85rem;color:var(--white-60)}
.slot-tag.booked-tag{border-color:rgba(227,29,26,.25);background:rgba(227,29,26,.05)}
.slot-tag button{background:none;color:var(--white-60);font-size:1rem;padding:0 2px;line-height:1}
.slot-tag button:hover{color:var(--red)}

/* Auth */
.auth-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}
.auth-card{max-width:400px;width:100%;text-align:center}
.auth-card h2{margin-bottom:.5rem}
.auth-card p{margin-bottom:1.5rem}

.empty-state{text-align:center;padding:3rem;color:var(--white-60)}
.empty-state .icon{font-size:3rem;margin-bottom:1rem;opacity:.5}

/* ── Social Showcase ── */
.social-showcase{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem;
  max-width:900px;margin:0 auto 2rem;
}
.social-card{
  position:relative;display:flex;flex-direction:column;align-items:center;
  gap:1.25rem;padding:2.5rem 1.5rem 2rem;
  background:var(--white-5);border:1px solid var(--white-10);
  border-radius:var(--r-xl);text-decoration:none;
  transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease;
  overflow:hidden;
}
.social-card:hover{
  transform:translateY(-8px);
  border-color:rgba(255,255,255,0.18);
  box-shadow:0 24px 64px rgba(0,0,0,0.55);
}
.social-card-ring{
  position:absolute;top:-30px;left:50%;transform:translateX(-50%);
  width:160px;height:160px;border-radius:50%;opacity:0.13;
  animation:ring-pulse 3s ease-in-out infinite;pointer-events:none;
}
.social-card-ring--tiktok{background:radial-gradient(circle,#69C9D0 0%,#EE1D52 100%)}
.social-card-ring--instagram{background:radial-gradient(circle,#f09433 0%,#dc2743 50%,#bc1888 100%)}
.social-card-ring--facebook{background:radial-gradient(circle,#1877F2 0%,#0a4fa8 100%)}
@keyframes ring-pulse{
  0%,100%{transform:translateX(-50%) scale(1);opacity:.12}
  50%{transform:translateX(-50%) scale(1.15);opacity:.24}
}
.social-card:hover .social-card-ring{opacity:.4}
.social-card-icon{
  position:relative;z-index:1;
  width:100px;height:100px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--white-10);border:2px solid var(--white-15);
  transition:all 0.3s ease;color:var(--white);
}
.social-card:hover .social-card-icon{transform:scale(1.1)}
#social-card-tiktok:hover .social-card-icon{border-color:#69C9D0;box-shadow:0 0 32px rgba(105,201,208,0.35)}
#social-card-instagram:hover .social-card-icon{border-color:#e6683c;box-shadow:0 0 32px rgba(230,104,60,0.35)}
#social-card-facebook:hover .social-card-icon{border-color:#1877F2;box-shadow:0 0 32px rgba(24,119,242,0.35)}
.social-card-info{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:0.3rem;text-align:center;
}
.social-card-name{font-size:1.2rem;font-weight:800;color:var(--white);font-family:var(--font-head)}
.social-card-handle{font-size:0.82rem;color:var(--white-60)}
.social-card-cta{
  margin-top:0.5rem;font-size:0.8rem;font-weight:700;color:var(--red);
  letter-spacing:0.5px;transition:letter-spacing 0.2s ease;
}
.social-card:hover .social-card-cta{letter-spacing:1.5px}
.social-showcase-note{
  text-align:center;color:var(--white-40);font-size:0.85rem;
  margin-top:0.5rem;font-style:italic;
}


/* ── Pricing 2-col ── */
.pricing-grid-2{grid-template-columns:repeat(2,1fr);max-width:780px;margin:0 auto}
.pricing-ideal-badge{
  font-size:0.78rem;color:var(--gray-600);font-style:italic;
  margin-bottom:1rem;line-height:1.4;
}
.pricing-ideal-badge-light{
  color:rgba(255,255,255,0.55);
}

/* ── Responsive ── */
@media(max-width:1024px){
  .why-us-grid{grid-template-columns:1fr;gap:2.5rem}
  .contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .services-cards-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
}
@media(max-width:768px){
  .nav-links{
    position:fixed;top:0;right:-100%;width:280px;height:100vh;
    background:var(--black-2);flex-direction:column;padding:5rem 2rem 2rem;
    gap:1.5rem;transition:right var(--t-base);box-shadow:var(--shadow-lg);z-index:999;
    border-left:1px solid rgba(227,29,26,.2);
  }
  .nav-links.open{right:0}
  .nav-toggle{display:flex;z-index:1001}
  .benefits-grid{grid-template-columns:1fr}
  .results-cards{grid-template-columns:1fr}
  .testimonials-row{grid-template-columns:1fr}
  .pricing-grid,.pricing-grid-2{grid-template-columns:1fr}
  .social-showcase{grid-template-columns:1fr;max-width:360px}
  .pricing-featured{transform:none}
  .pricing-featured:hover{transform:translateY(-4px)}
  .services-cards-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:.75rem;text-align:center}
  .hero-content h1{font-size:2.4rem}
  .booking-steps{flex-direction:column;align-items:center}
  .step-connector{width:2px;height:20px;margin:0}
  .slot-form-grid{grid-template-columns:1fr}
  .admin-layout{grid-template-columns:1fr}
  .admin-sidebar{position:relative;height:auto;border-right:none;border-bottom:1px solid var(--white-10)}
  .stat-cards{grid-template-columns:1fr 1fr}
  .time-slots{grid-template-columns:repeat(3,1fr)}
  .comparison-slider{aspect-ratio:4/3}
}
@media(max-width:480px){
  .hero-badges{gap:.5rem}
  .trust-badge{font-size:.78rem;padding:.4rem .75rem}
  .hero-actions{flex-direction:column}
  .btn-xl{width:100%;justify-content:center}
  .cta-actions{flex-direction:column;align-items:center}
  .calendar-day{font-size:.75rem}
  .time-slots{grid-template-columns:repeat(2,1fr)}
  .stat-cards{grid-template-columns:1fr}
}
