/* =============================================
   LOCAL TITAN — LANDING PAGE STYLES
   Premium dark-mode, conversion-focused design
   ============================================= */

/* ---------- CSS RESET & VARIABLES ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}

:root{
  --bg-deep:#0a0a1a;
  --bg-card:#111127;
  --bg-card-hover:#161640;
  --border:rgba(255,255,255,0.06);
  --border-accent:rgba(139,92,246,0.3);
  --text:#f1f1f7;
  --text-dim:#9ca3af;
  --text-muted:#6b7280;
  --accent:#8b5cf6;
  --accent-light:#a78bfa;
  --accent-glow:rgba(139,92,246,0.25);
  --green:#22c55e;
  --red:#ef4444;
  --orange:#f59e0b;
  --blue:#3b82f6;
  --gold:#fbbf24;
  --radius:12px;
  --radius-lg:20px;
  --radius-xl:28px;
  --font:'Inter',system-ui,-apple-system,sans-serif;
  --max-w:1200px;
}

html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden;}
body{
  font-family:var(--font);
  background:var(--bg-deep);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  max-width:100vw;
}

a{color:var(--accent-light);text-decoration:none;}
a:hover{color:#c4b5fd;}
img{max-width:100%;display:block;}

/* ---------- UTILITY ---------- */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px;}
.section{padding:100px 0;}
.section-alt{background:rgba(17,17,39,0.6);}
.text-center{text-align:center;}
.text-gradient{
  background:linear-gradient(135deg,#a78bfa,#6366f1,#3b82f6);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.badge-pill{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(139,92,246,0.12);color:var(--accent-light);
  padding:6px 16px;border-radius:100px;font-size:0.75rem;font-weight:700;
  text-transform:uppercase;letter-spacing:1.5px;
  border:1px solid rgba(139,92,246,0.2);
}

/* ---------- SCROLL REVEAL ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:all 0.7s cubic-bezier(0.16,1,0.3,1);}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ---------- NAVBAR ---------- */
.landing-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:16px 0;
  background:rgba(10,10,26,0.85);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:all 0.3s;
}
.landing-nav.scrolled{padding:10px 0;background:rgba(10,10,26,0.95);}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--max-w);margin:0 auto;padding:0 24px;
}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.25rem;color:#fff;}
.nav-logo-icon{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,#8b5cf6,#6366f1);
  display:flex;align-items:center;justify-content:center;
  font-size:0.9rem;color:#fff;
}
.nav-logo .titan-badge{
  background:var(--accent);color:#fff;padding:2px 6px;border-radius:4px;
  font-size:0.55rem;font-weight:800;letter-spacing:1px;
  vertical-align:middle;margin-left:2px;
}
.nav-cta{
  background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;
  padding:10px 24px;border-radius:100px;font-weight:700;font-size:0.85rem;
  border:none;cursor:pointer;transition:all 0.3s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-glow);color:#fff;}

/* Nav menu links */
.nav-menu{display:flex;gap:16px;align-items:center;}
.nav-menu a{color:#9ca3af;font-weight:500;font-size:0.9rem;text-decoration:none;transition:color 0.2s;}
.nav-menu a:hover{color:#fff;}

/* Hamburger */
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px;z-index:10;}
.nav-hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all 0.3s;}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.nav-hamburger.open span:nth-child(2){opacity:0;}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

@media(max-width:768px){
  .nav-hamburger{display:flex;}
  .nav-menu{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:rgba(10,10,26,0.98);backdrop-filter:blur(20px);
    flex-direction:column;padding:20px 24px;gap:4px;
    border-bottom:1px solid var(--border);
  }
  .nav-menu.open{display:flex;}
  .nav-menu a{padding:12px 0;font-size:1rem;width:100%;border-bottom:1px solid rgba(255,255,255,0.04);}
  .nav-menu .nav-cta{text-align:center;margin-top:8px;border-radius:12px;padding:14px;display:block;}
}

/* ---------- HERO ---------- */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:120px 0 80px;position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:radial-gradient(circle at 30% 40%,rgba(139,92,246,0.08) 0%,transparent 50%),
             radial-gradient(circle at 70% 60%,rgba(99,102,241,0.06) 0%,transparent 50%);
  animation:heroGlow 12s ease-in-out infinite alternate;
}
@keyframes heroGlow{
  0%{transform:translate(0,0) scale(1);}
  100%{transform:translate(-3%,2%) scale(1.05);}
}
.hero-inner{position:relative;z-index:1;max-width:var(--max-w);margin:0 auto;padding:0 24px;text-align:center;}
.hero-pill{margin-bottom:24px;}
.hero h1{
  font-size:clamp(2.2rem,5.5vw,4rem);font-weight:900;line-height:1.1;
  margin-bottom:20px;letter-spacing:-0.02em;
}
.hero p.hero-sub{
  font-size:clamp(1rem,2vw,1.25rem);color:var(--text-dim);
  max-width:640px;margin:0 auto 40px;line-height:1.7;
}

/* ---------- SCAN FORM ---------- */
.scan-form-card{
  background:var(--bg-card);border:1px solid var(--border-accent);
  border-radius:var(--radius-lg);padding:32px;
  max-width:580px;margin:0 auto;text-align:left;
  box-shadow:0 0 60px rgba(139,92,246,0.08);
}
.scan-form-card h3{font-size:1.1rem;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.scan-form-card h3 i{color:var(--accent-light);}
.form-row{display:flex;gap:12px;margin-bottom:12px;}
.form-row.stack{flex-direction:column;}
.scan-form-card input,.scan-form-card select{
  flex:1;padding:14px 16px;border-radius:10px;border:1px solid var(--border);
  background:rgba(255,255,255,0.04);color:#fff;font-size:0.9rem;
  font-family:var(--font);transition:border 0.2s;
}
.scan-form-card input:focus,.scan-form-card select:focus{border-color:var(--accent);outline:none;}
.scan-form-card input::placeholder{color:var(--text-muted);}
.btn-scan{
  width:100%;padding:16px;border:none;border-radius:12px;
  background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;
  font-size:1rem;font-weight:800;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:10px;
  transition:all 0.3s;margin-top:8px;
}
.btn-scan:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow);}
.btn-scan:disabled{opacity:0.6;cursor:not-allowed;transform:none;}
.trust-row{
  display:flex;align-items:center;justify-content:center;gap:20px;
  margin-top:32px;flex-wrap:wrap;
}
.trust-item{display:flex;align-items:center;gap:6px;font-size:0.8rem;color:var(--text-muted);}
.trust-item i{color:var(--green);font-size:0.7rem;}
.trust-stars{color:var(--gold);}

/* ---------- REPORT SECTION ---------- */
.report-section{display:none;padding:80px 0;}
.report-section.active{display:block;}
.report-header{text-align:center;margin-bottom:48px;}
.report-header h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;margin-bottom:12px;}

/* Grade badge */
.grade-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:120px;height:120px;border-radius:50%;
  font-size:2.5rem;font-weight:900;margin:24px auto;
  border:4px solid;
}
.grade-f{background:rgba(239,68,68,0.1);border-color:var(--red);color:var(--red);}
.grade-d{background:rgba(245,158,11,0.1);border-color:var(--orange);color:var(--orange);}

/* Report grid */
.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:40px;}
.report-card{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;position:relative;overflow:hidden;
}
.report-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.report-card-title{font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);}
.report-card-status{font-size:0.7rem;font-weight:700;padding:4px 10px;border-radius:100px;}
.status-bad{background:rgba(239,68,68,0.12);color:var(--red);}
.status-warning{background:rgba(245,158,11,0.12);color:var(--orange);}
.status-good{background:rgba(34,197,94,0.12);color:var(--green);}
.report-card-value{font-size:2rem;font-weight:900;margin-bottom:4px;}
.report-card-detail{font-size:0.8rem;color:var(--text-muted);}

/* Mini heatmap */
.mini-heatmap{
  display:grid;grid-template-columns:repeat(5,1fr);gap:4px;
  margin-top:12px;
}
.heatmap-cell{
  aspect-ratio:1;border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  font-size:0.6rem;font-weight:800;color:#fff;
}
.cell-red{background:rgba(239,68,68,0.7);}
.cell-orange{background:rgba(245,158,11,0.7);}
.cell-yellow{background:rgba(250,204,21,0.7);}
.cell-green{background:rgba(34,197,94,0.7);}

/* Comparison */
.comparison-bar{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;margin-bottom:32px;
}
.comparison-row{display:flex;align-items:center;gap:16px;margin-bottom:16px;}
.comparison-row:last-child{margin-bottom:0;}
.comp-label{width:180px;font-size:0.8rem;font-weight:600;color:var(--text-dim);}
.comp-bars{flex:1;display:flex;gap:8px;align-items:center;}
.comp-bar{height:8px;border-radius:100px;transition:width 1.5s cubic-bezier(0.16,1,0.3,1);}
.comp-bar.yours{background:var(--red);}
.comp-bar.competitor{background:var(--green);}
.comp-bar-label{font-size:0.7rem;font-weight:700;white-space:nowrap;}

.report-cta{text-align:center;margin-top:40px;}
.btn-fix{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 40px;border-radius:100px;border:none;
  background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;
  font-size:1.1rem;font-weight:800;cursor:pointer;
  transition:all 0.3s;
  box-shadow:0 4px 20px rgba(34,197,94,0.3);
}
.btn-fix:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(34,197,94,0.4);}

/* Scanning animation */
.scan-overlay{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;
  background:rgba(10,10,26,0.95);
  flex-direction:column;align-items:center;justify-content:center;gap:24px;
}
.scan-overlay.active{display:flex;}
.scan-spinner{
  width:80px;height:80px;border-radius:50%;
  border:4px solid rgba(139,92,246,0.15);border-top-color:var(--accent);
  animation:spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}
.scan-text{font-size:1.1rem;font-weight:700;color:var(--text);}
.scan-subtext{font-size:0.85rem;color:var(--text-dim);max-width:300px;text-align:center;}
.scan-progress-bar{width:300px;height:6px;background:rgba(255,255,255,0.06);border-radius:100px;overflow:hidden;}
.scan-progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--blue));border-radius:100px;transition:width 0.3s;}

/* ---------- SOCIAL PROOF ---------- */
.logo-bar{
  display:flex;align-items:center;justify-content:center;gap:40px;
  flex-wrap:wrap;margin-bottom:60px;opacity:0.4;
}
.logo-bar span{font-size:0.9rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);}

.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px;}
.stat-card{text-align:center;padding:32px 16px;}
.stat-number{font-size:clamp(2rem,4vw,3rem);font-weight:900;margin-bottom:4px;}
.stat-label{font-size:0.85rem;color:var(--text-dim);font-weight:500;}

.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.testimonial-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:24px;
}
.testimonial-stars{margin-bottom:12px;color:var(--gold);font-size:0.85rem;}
.testimonial-text{font-size:0.9rem;color:var(--text-dim);line-height:1.7;margin-bottom:16px;font-style:italic;}
.testimonial-author{display:flex;align-items:center;gap:12px;}
.testimonial-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--blue));
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:0.8rem;color:#fff;
}
.testimonial-name{font-weight:700;font-size:0.85rem;}
.testimonial-role{font-size:0.7rem;color:var(--text-muted);}

/* ---------- COMPETITOR COMPARISON TABLE ---------- */
.compare-table-wrap{
  overflow-x:auto;border-radius:var(--radius-lg);
  border:1px solid var(--border);background:var(--bg-card);
  -webkit-overflow-scrolling:touch;
}
.compare-table{
  width:100%;border-collapse:collapse;min-width:700px;
}
.compare-table thead{background:rgba(139,92,246,0.06);}
.compare-table th{
  padding:20px 16px;font-size:0.8rem;font-weight:700;
  text-align:center;border-bottom:1px solid var(--border);
  color:var(--text-dim);white-space:nowrap;
}
.compare-table th.feature-col{text-align:left;width:220px;}
.compare-table th.titan-col{
  background:rgba(139,92,246,0.1);color:#fff;
  border-left:2px solid var(--accent);border-right:2px solid var(--accent);
  border-top:2px solid var(--accent);
}
.titan-header{font-size:0.9rem;font-weight:900;color:var(--accent-light);display:flex;align-items:center;justify-content:center;gap:6px;}
.titan-price{font-size:0.75rem;color:var(--green);font-weight:800;margin-top:4px;}
.comp-price{font-size:0.65rem;color:var(--text-muted);font-weight:500;margin-top:4px;}
.compare-table td{
  padding:14px 16px;text-align:center;
  border-bottom:1px solid var(--border);font-size:0.85rem;
}
.compare-table td.feature-name{text-align:left;font-weight:600;color:var(--text-dim);}
.compare-table td.titan-col{
  background:rgba(139,92,246,0.05);
  border-left:2px solid var(--accent);border-right:2px solid var(--accent);
}
.ct-yes{color:var(--green);font-size:1.1rem;}
.ct-no{color:rgba(255,255,255,0.1);font-size:1.1rem;}
.ct-partial{color:var(--orange);font-size:1.1rem;}
.total-row td{border-top:2px solid var(--border);background:rgba(255,255,255,0.02);}
.total-row td.titan-col{border-bottom:2px solid var(--accent);}
.total-count{font-size:0.8rem;font-weight:700;color:var(--text-muted);}
.titan-total{color:var(--green) !important;font-size:0.9rem;font-weight:900;}

/* ---------- FEATURE BENTO GRID ---------- */
.bento-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:16px;
}
.bento-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:32px;
  position:relative;overflow:hidden;
  transition:all 0.3s;
}
.bento-card:hover{border-color:var(--border-accent);transform:translateY(-4px);background:var(--bg-card-hover);}
.bento-card.featured{grid-column:span 2;}
.bento-icon{
  width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;margin-bottom:16px;
}
.bento-card h3{font-size:1.1rem;font-weight:800;margin-bottom:8px;}
.bento-card p{font-size:0.85rem;color:var(--text-dim);line-height:1.6;}

/* ---------- HOW IT WORKS ---------- */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.step-card{text-align:center;padding:24px;}
.step-number{
  width:60px;height:60px;border-radius:50%;margin:0 auto 20px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;font-weight:900;
  background:linear-gradient(135deg,rgba(139,92,246,0.15),rgba(99,102,241,0.1));
  border:2px solid rgba(139,92,246,0.3);color:var(--accent-light);
}
.step-card h3{font-size:1rem;font-weight:800;margin-bottom:8px;}
.step-card p{font-size:0.85rem;color:var(--text-dim);line-height:1.6;}

/* ---------- PRICING ---------- */
.pricing-card{
  max-width:480px;margin:0 auto;
  background:var(--bg-card);border:2px solid var(--border-accent);
  border-radius:var(--radius-xl);padding:48px;text-align:center;
  position:relative;overflow:hidden;
}
.pricing-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,#8b5cf6,#6366f1,#3b82f6);
}
.pricing-popular{
  position:absolute;top:16px;right:-32px;
  background:var(--accent);color:#fff;
  padding:4px 40px;font-size:0.65rem;font-weight:800;
  letter-spacing:1px;text-transform:uppercase;
  transform:rotate(45deg);
}
.pricing-price{margin:24px 0;}
.pricing-price .amount{font-size:3.5rem;font-weight:900;}
.pricing-price .period{font-size:1rem;color:var(--text-muted);font-weight:500;}
.pricing-price .compare{font-size:0.8rem;color:var(--text-muted);margin-top:8px;}
.pricing-price .compare s{color:var(--red);margin-right:4px;}
.pricing-features{list-style:none;text-align:left;margin:32px 0;padding:0;}
.pricing-features li{
  padding:10px 0;font-size:0.9rem;display:flex;align-items:center;gap:12px;
  border-bottom:1px solid var(--border);
}
.pricing-features li:last-child{border:none;}
.pricing-features li i{color:var(--green);font-size:0.8rem;width:20px;text-align:center;}
.pricing-guarantee{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:0.8rem;color:var(--text-dim);margin-top:20px;
}
.pricing-guarantee i{color:var(--green);}
.btn-pricing{
  width:100%;padding:18px;border:none;border-radius:14px;
  background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;
  font-size:1.1rem;font-weight:800;cursor:pointer;
  transition:all 0.3s;
}
.btn-pricing:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow);}

/* ---------- FAQ ---------- */
.faq-list{max-width:720px;margin:0 auto;}
.faq-item{
  border-bottom:1px solid var(--border);
}
.faq-question{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;cursor:pointer;font-weight:700;font-size:1rem;
  transition:color 0.2s;
}
.faq-question:hover{color:var(--accent-light);}
.faq-question i{font-size:0.8rem;color:var(--text-muted);transition:transform 0.3s;}
.faq-item.open .faq-question i{transform:rotate(180deg);}
.faq-answer{
  max-height:0;overflow:hidden;transition:max-height 0.4s ease;
}
.faq-item.open .faq-answer{max-height:300px;}
.faq-answer p{padding:0 0 20px;font-size:0.9rem;color:var(--text-dim);line-height:1.7;}

/* ---------- FINAL CTA ---------- */
.final-cta{
  background:linear-gradient(135deg,rgba(139,92,246,0.1),rgba(99,102,241,0.05));
  border-top:1px solid var(--border-accent);
  border-bottom:1px solid var(--border-accent);
}
.final-cta h2{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;margin-bottom:16px;}
.final-cta p{font-size:1.1rem;color:var(--text-dim);margin-bottom:32px;}
.final-cta-form{
  display:flex;gap:12px;max-width:500px;margin:0 auto;
}
.final-cta-form input{
  flex:1;padding:16px 20px;border:1px solid var(--border-accent);
  border-radius:12px;background:rgba(255,255,255,0.04);color:#fff;
  font-size:0.95rem;font-family:var(--font);
}
.final-cta-form input:focus{outline:none;border-color:var(--accent);}
.final-cta-form button{
  padding:16px 32px;border:none;border-radius:12px;
  background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;
  font-weight:800;font-size:0.95rem;cursor:pointer;white-space:nowrap;
  transition:all 0.3s;
}
.final-cta-form button:hover{box-shadow:0 4px 20px var(--accent-glow);}

/* ---------- FOOTER ---------- */
.landing-footer{
  padding:40px 0;border-top:1px solid var(--border);
  text-align:center;
}
.landing-footer p{font-size:0.8rem;color:var(--text-muted);}

/* ---------- ROI CALCULATOR POPUP ---------- */
.roi-overlay{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9998;
  background:rgba(10,10,26,0.75);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  align-items:center;justify-content:center;padding:20px;
  animation:roiFadeIn 0.3s ease;
}
.roi-overlay.active{display:flex;}
@keyframes roiFadeIn{from{opacity:0;}to{opacity:1;}}
.roi-card{
  display:flex;max-width:820px;width:100%;border-radius:20px;overflow:hidden;
  background:var(--bg-card);border:1px solid var(--border-accent);
  box-shadow:0 30px 80px rgba(0,0,0,0.6);
  animation:roiSlideUp 0.4s cubic-bezier(0.16,1,0.3,1);
  position:relative;
}
@keyframes roiSlideUp{from{opacity:0;transform:translateY(40px);}to{opacity:1;transform:translateY(0);}}
.roi-close{
  position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.1);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  color:#94a3b8;font-size:1rem;z-index:2;transition:all 0.2s;
}
.roi-close:hover{background:rgba(255,255,255,0.15);color:#fff;}

/* Left panel - case study carousel */
.roi-left{
  width:320px;min-height:340px;flex-shrink:0;
  background:linear-gradient(160deg,#4f46e5,#7c3aed 40%,#2563eb 100%);
  padding:32px 28px;display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
}
.roi-left::after{
  content:'';position:absolute;bottom:-40px;right:-40px;width:200px;height:200px;
  border-radius:50%;background:rgba(255,255,255,0.06);
}
.roi-case{display:none;animation:roiCaseFade 0.5s ease;}
.roi-case.active{display:block;}
@keyframes roiCaseFade{from{opacity:0;transform:translateX(-10px);}to{opacity:1;transform:translateX(0);}}
.roi-case-industry{font-size:0.7rem;color:rgba(255,255,255,0.7);font-weight:600;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;}
.roi-case-title{font-size:1rem;font-weight:800;color:#fff;line-height:1.4;margin-bottom:auto;}
.roi-case-stats{display:flex;gap:24px;margin-top:24px;}
.roi-case-stat-val{font-size:1.8rem;font-weight:900;color:#fff;}
.roi-case-stat-label{font-size:0.65rem;color:rgba(255,255,255,0.7);line-height:1.3;max-width:100px;}
.roi-dots{display:flex;gap:8px;margin-top:20px;}
.roi-dot{width:24px;height:3px;border-radius:3px;background:rgba(255,255,255,0.25);transition:all 0.3s;}
.roi-dot.active{background:#fff;width:32px;}

/* Right panel - form */
.roi-right{flex:1;padding:36px 32px;display:flex;flex-direction:column;justify-content:center;}
.roi-right h2{font-size:1.6rem;font-weight:900;line-height:1.2;margin-bottom:8px;color:#fff;}
.roi-right .roi-sub{font-size:0.85rem;color:var(--text-dim);margin-bottom:24px;}
.roi-form{display:flex;flex-direction:column;gap:10px;}
.roi-form input{
  padding:13px 16px;border-radius:10px;border:1px solid var(--border);
  background:rgba(255,255,255,0.04);color:#fff;font-size:0.9rem;font-family:var(--font);
  transition:border 0.2s;
}
.roi-form input:focus{border-color:var(--accent);outline:none;}
.roi-form input::placeholder{color:var(--text-muted);}
.roi-btn{
  padding:14px;border:none;border-radius:10px;
  background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;
  font-size:0.95rem;font-weight:800;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all 0.3s;margin-top:4px;
}
.roi-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(124,58,237,0.4);}

/* ROI results (shown after calculation) */
.roi-results{display:none;animation:roiFadeIn 0.4s ease;}
.roi-results.active{display:block;}
.roi-result-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin:16px 0;}
.roi-result-box{text-align:center;padding:14px 8px;border-radius:10px;}
.roi-result-box.loss{background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.15);}
.roi-result-box.gain{background:rgba(34,197,94,0.08);border:1px solid rgba(34,197,94,0.15);}
.roi-result-label{font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:4px;}
.roi-result-val{font-size:1.3rem;font-weight:900;}

/* ---------- URGENCY STICKY BANNER ---------- */
.urgency-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:900;
  background:linear-gradient(135deg,rgba(239,68,68,0.95),rgba(220,38,38,0.95));
  backdrop-filter:blur(10px);padding:12px 24px;
  display:none;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;
  box-shadow:0 -4px 30px rgba(239,68,68,0.3);
  animation:urgencySlide 0.5s cubic-bezier(0.16,1,0.3,1);
}
.urgency-banner.active{display:flex;}
@keyframes urgencySlide{from{transform:translateY(100%);}to{transform:translateY(0);}}
.urgency-banner p{font-size:0.82rem;font-weight:600;color:#fff;margin:0;}
.urgency-banner button{
  padding:8px 20px;border-radius:8px;border:none;
  background:#fff;color:#dc2626;font-weight:800;font-size:0.8rem;
  cursor:pointer;white-space:nowrap;transition:all 0.2s;
}
.urgency-banner button:hover{transform:scale(1.03);box-shadow:0 2px 12px rgba(0,0,0,0.2);}
.urgency-close{background:none;border:none;color:rgba(255,255,255,0.7);cursor:pointer;font-size:1.1rem;padding:4px;}

/* ---------- HERO PLATFORM ROTATION ---------- */
.platform-rotate{position:relative;display:inline-block;min-width:180px;text-align:left;}
.platform-word{
  display:inline-block;opacity:0;position:absolute;left:0;
  transition:all 0.5s cubic-bezier(0.16,1,0.3,1);
  background:linear-gradient(135deg,#a78bfa,#6366f1,#3b82f6);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.platform-word.active{opacity:1;position:relative;}

/* ---------- RESPONSIVE ---------- */
@media(max-width:768px){
  .section{padding:60px 0;}
  .container{padding:0 16px;}
  .form-row{flex-direction:column;}
  .report-grid{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr;gap:12px;}
  .testimonials-grid{grid-template-columns:1fr;}
  .bento-grid{grid-template-columns:1fr;}
  .bento-card.featured{grid-column:span 1;}
  .bento-card{padding:24px 18px;}
  .steps-grid{grid-template-columns:1fr;gap:20px;}
  .step-number{width:48px;height:48px;font-size:1.1rem;}
  .comparison-row{flex-direction:column;align-items:flex-start;gap:8px;}
  .comp-label{width:100%;}
  .final-cta-form{flex-direction:column;}
  .trust-row{flex-direction:column;gap:8px;}
  .compare-table-wrap{margin:0 -16px;border-radius:0;border-left:none;border-right:none;}
  .roi-card{flex-direction:column;}
  .roi-left{width:100%;min-height:auto;padding:24px 20px;}
  .roi-right{padding:24px 20px;}
  .roi-result-grid{grid-template-columns:1fr;}
  .urgency-banner{padding:10px 16px;gap:10px;}
  .urgency-banner p{font-size:0.72rem;text-align:center;}
  .platform-rotate{min-width:120px;}
  .hero h1{font-size:clamp(1.4rem,4.5vw,2.4rem);word-break:break-word;}
  .hero{min-height:auto;padding:100px 0 60px;}
  .hero-inner{padding:0 16px;overflow:hidden;}
  .hero p.hero-sub{font-size:0.9rem;}
  .desktop-br{display:none;}
  /* Quiz mobile fixes */
  .quiz-card{padding:20px 14px 18px;border-radius:16px;max-height:95vh;}
  .quiz-progress{margin-bottom:20px;margin-top:20px;}
  .quiz-progress-track{margin:0 20px;}
  .quiz-step-dot{width:22px;height:22px;font-size:0.55rem;}
  .quiz-progress-steps{padding:0 8px;}
  .quiz-step-header h2{font-size:1.1rem;}
  .quiz-step-header p{font-size:0.78rem;}
  .quiz-options{grid-template-columns:1fr;gap:6px;max-height:55vh;}
  .quiz-option{padding:10px 12px;gap:8px;}
  .quiz-option-icon{width:30px;height:30px;font-size:0.75rem;}
  .quiz-option-text{font-size:0.78rem;}
  .quiz-option-sub{font-size:0.6rem;}
  .quiz-option.selected::after{right:8px;font-size:0.75rem;}
  .quiz-gauge-wrap{width:120px;height:120px;}
  .quiz-gauge-number{font-size:2rem;}
  .quiz-rec-features{grid-template-columns:1fr;}
  .btn-quiz-hero{padding:14px 24px;font-size:0.9rem;}
  .quiz-score-row{font-size:0.75rem;}
  .quiz-lead-intro{font-size:0.78rem;}
  .quiz-form-fields input{padding:11px 14px;font-size:0.85rem;}
  .quiz-submit-btn{padding:13px;font-size:0.9rem;}
  /* Pricing stack on mobile */
  .pricing-grid-wrapper{grid-template-columns:1fr !important;}
  /* Prevent freezing - use GPU compositing */
  .reveal{will-change:transform,opacity;}
  .scan-spinner{will-change:transform;}
}

/* ---------- QUIZ HERO BUTTON ---------- */
.btn-quiz-hero{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;border:none;border-radius:12px;
  background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;
  font-size:1rem;font-weight:800;cursor:pointer;
  transition:all 0.3s;font-family:var(--font);
  box-shadow:0 4px 20px rgba(34,197,94,0.35);
}
.btn-quiz-hero:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(34,197,94,0.5);}

/* ---------- QUIZ MODAL ---------- */
.quiz-overlay{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;
  background:rgba(10,10,26,0.8);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  align-items:center;justify-content:center;padding:20px;
}
.quiz-overlay.active{display:flex;}
.quiz-card{
  width:100%;max-width:580px;max-height:90vh;overflow-y:auto;
  background:linear-gradient(160deg,#111127 0%,#0d0d24 100%);
  border:1px solid var(--border-accent);border-radius:24px;
  padding:36px 32px 28px;position:relative;
  box-shadow:0 40px 100px rgba(0,0,0,0.7),0 0 60px rgba(139,92,246,0.1);
  animation:quizSlideUp 0.5s cubic-bezier(0.16,1,0.3,1);
}
@keyframes quizSlideUp{from{opacity:0;transform:translateY(50px) scale(0.97);}to{opacity:1;transform:translateY(0) scale(1);}}
.quiz-close{
  position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.1);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  color:#94a3b8;font-size:1.1rem;transition:all 0.2s;z-index:10;
}
.quiz-close:hover{background:rgba(255,255,255,0.15);color:#fff;}

/* Progress */
.quiz-progress{margin-bottom:32px;margin-top:28px;position:relative;}
.quiz-progress-track{
  height:4px;background:rgba(255,255,255,0.06);border-radius:100px;
  margin:0 28px;position:relative;
}
.quiz-progress-fill{
  height:100%;border-radius:100px;
  background:linear-gradient(90deg,#8b5cf6,#6366f1);
  width:0%;transition:width 0.5s cubic-bezier(0.16,1,0.3,1);
}
.quiz-progress-steps{
  display:flex;justify-content:space-between;
  position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);
  padding:0 14px;padding-right:0;
}
.quiz-step-dot{
  width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,0.06);border:2px solid rgba(255,255,255,0.1);
  display:flex;align-items:center;justify-content:center;
  font-size:0.65rem;font-weight:800;color:#64748b;
  transition:all 0.3s;z-index:1;
}
.quiz-step-dot.active{
  background:linear-gradient(135deg,#7c3aed,#6366f1);
  border-color:#8b5cf6;color:#fff;
  box-shadow:0 0 16px rgba(139,92,246,0.4);
}
.quiz-step-dot.done{
  background:#22c55e;border-color:#22c55e;color:#fff;
}

/* Steps */
.quiz-step{display:none;animation:quizStepFade 0.4s ease;}
.quiz-step.active{display:block;}
@keyframes quizStepFade{from{opacity:0;transform:translateX(20px);}to{opacity:1;transform:translateX(0);}}
.quiz-step-header{text-align:center;margin-bottom:24px;}
.quiz-step-header h2{font-size:1.4rem;font-weight:900;color:#fff;margin-bottom:6px;line-height:1.3;}
.quiz-step-header p{font-size:0.85rem;color:var(--text-muted);margin:0;}

/* Option Cards */
.quiz-options{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-height:60vh;overflow-y:auto;padding-right:4px;}
.quiz-options::-webkit-scrollbar{width:4px;}
.quiz-options::-webkit-scrollbar-thumb{background:rgba(139,92,246,0.3);border-radius:4px;}
.quiz-option{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-radius:12px;
  background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);
  cursor:pointer;transition:all 0.25s;position:relative;
}
.quiz-option:hover{
  background:rgba(139,92,246,0.06);border-color:rgba(139,92,246,0.25);
  transform:translateY(-2px);
}
.quiz-option.selected{
  background:rgba(139,92,246,0.1);border-color:rgba(139,92,246,0.5);
  box-shadow:0 0 20px rgba(139,92,246,0.15);
}
.quiz-option.selected::after{
  content:'\f058';font-family:'Font Awesome 6 Free';font-weight:900;
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  color:#8b5cf6;font-size:0.9rem;
}
.quiz-option-icon{
  width:34px;height:34px;border-radius:8px;flex-shrink:0;
  background:rgba(139,92,246,0.12);color:#a78bfa;
  display:flex;align-items:center;justify-content:center;font-size:0.85rem;
}
.quiz-option-text{font-weight:700;font-size:0.82rem;color:#e2e8f0;}
.quiz-option-sub{font-size:0.65rem;color:#64748b;margin-top:1px;}

/* Back Button */
.quiz-back{
  display:flex;align-items:center;gap:6px;margin-top:20px;
  padding:10px 18px;border:none;border-radius:8px;
  background:rgba(255,255,255,0.04);color:#94a3b8;
  font-size:0.8rem;font-weight:600;cursor:pointer;
  font-family:var(--font);transition:all 0.2s;
}
.quiz-back:hover{background:rgba(255,255,255,0.08);color:#fff;}

/* ---------- QUIZ GAUGE ---------- */
.quiz-gauge-wrap{
  position:relative;width:160px;height:160px;margin:0 auto 20px;
}
.quiz-gauge{width:100%;height:100%;}
.quiz-gauge-fill{transition:stroke-dashoffset 2s cubic-bezier(0.16,1,0.3,1);}
.quiz-gauge-center{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;
}
.quiz-gauge-number{font-size:2.8rem;font-weight:900;color:#fff;line-height:1;}
.quiz-gauge-label{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-top:2px;}

/* Score Breakdown */
.quiz-score-breakdown{
  display:flex;flex-direction:column;gap:8px;
  margin-bottom:24px;
  background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);
  border-radius:12px;padding:16px;
}
.quiz-score-row{
  display:flex;align-items:center;gap:10px;
  padding:6px 0;font-size:0.82rem;
}
.quiz-score-indicator{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
}
.quiz-score-indicator.red{background:#ef4444;box-shadow:0 0 6px rgba(239,68,68,0.5);}
.quiz-score-indicator.yellow{background:#fbbf24;box-shadow:0 0 6px rgba(251,191,36,0.5);}
.quiz-score-indicator.green{background:#22c55e;box-shadow:0 0 6px rgba(34,197,94,0.5);}
.quiz-score-name{flex:1;color:#94a3b8;font-weight:500;}
.quiz-score-value{font-weight:800;font-size:0.72rem;letter-spacing:0.5px;color:#ef4444;}

/* Lead Capture Form */
.quiz-lead-form{margin-bottom:16px;}
.quiz-lead-intro{
  font-size:0.82rem;font-weight:600;color:#e2e8f0;
  margin-bottom:12px;text-align:center;
}
.quiz-form-fields{display:flex;flex-direction:column;gap:8px;}
.quiz-form-fields input{
  padding:13px 16px;border-radius:10px;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.04);color:#fff;
  font-size:0.9rem;font-family:var(--font);transition:border 0.2s;
}
.quiz-form-fields input:focus{border-color:var(--accent);outline:none;}
.quiz-form-fields input::placeholder{color:#475569;}
.quiz-sms-opt{
  display:flex;align-items:center;gap:8px;margin:12px 0 16px;
  font-size:0.78rem;color:#94a3b8;cursor:pointer;
}
.quiz-sms-opt input[type="checkbox"]{
  width:16px;height:16px;border-radius:4px;cursor:pointer;accent-color:#8b5cf6;
}
.quiz-submit-btn{
  width:100%;padding:15px;border:none;border-radius:12px;
  background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;
  font-size:1rem;font-weight:800;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:10px;
  transition:all 0.3s;font-family:var(--font);
  box-shadow:0 4px 20px rgba(34,197,94,0.3);
}
.quiz-submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(34,197,94,0.5);}

/* Recommendation */
.quiz-recommendation{animation:quizStepFade 0.5s ease;text-align:center;}
.quiz-rec-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(34,197,94,0.1);color:#22c55e;
  padding:6px 16px;border-radius:100px;font-size:0.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;
}
.quiz-recommendation h3{font-size:1.3rem;font-weight:900;color:#fff;margin-bottom:8px;}
.quiz-recommendation p{font-size:0.85rem;color:var(--text-dim);line-height:1.6;margin-bottom:20px;}
.quiz-rec-features{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px;text-align:left;
}
.quiz-rec-feat{
  display:flex;align-items:center;gap:8px;font-size:0.8rem;color:#e2e8f0;font-weight:500;
}
.quiz-rec-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:16px;border-radius:12px;
  background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;
  font-size:1rem;font-weight:800;text-decoration:none;
  transition:all 0.3s;box-shadow:0 4px 20px rgba(124,58,237,0.4);
}
.quiz-rec-cta:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(124,58,237,0.5);color:#fff;}

/* ---------- EXTRA SMALL SCREENS ---------- */
@media(max-width:380px){
  .quiz-card{padding:16px 10px 14px;}
  .quiz-step-header h2{font-size:0.95rem;}
  .quiz-option{padding:8px 10px;}
  .quiz-option-text{font-size:0.7rem;}
  .hero h1{font-size:1.4rem;}
  .container{padding:0 12px;}
}
