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

:root {
  --yellow: #FFD600;
  --black: #0A0A0A;
  --white: #FFFFFF;
  --gray: #F5F5F5;
  --font: 'Inter', sans-serif;
  --max-w: 1280px;
  --section-pad: 120px;
  --radius: 8px;
  --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font); color: var(--black); background: var(--white); overflow-x: hidden; -webkit-font-smoothing: antialiased; }

.container { max-width: var(--max-w); margin: 0 auto; padding: 0 40px; width: 100%; }

/* ANIMATIONS */
.reveal.active { opacity: 1; transform: translateY(0); }

/* ═══ NAVBAR ═══ */
.navbar { position: fixed; top: 0; left: 0; width: 100%; background: var(--black); z-index: 1000; border-bottom: 1px solid var(--yellow); }
.navbar .container { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.nav-logo { font-size: 1.5rem; color: var(--white); text-decoration: none; font-weight: 700; letter-spacing: -0.5px; }
.nav-logo span { font-weight: 300; }
.nav-links { display: flex; align-items: center; gap: 32px; list-style: none; }
.nav-links a { color: var(--white); text-decoration: none; font-size: 0.875rem; font-weight: 500; transition: var(--transition); letter-spacing: 0.5px; }
.nav-links a:hover { color: var(--yellow); }
.nav-cta { background: var(--yellow) !important; color: var(--black) !important; padding: 10px 24px; border-radius: var(--radius); font-weight: 600 !important; transition: var(--transition); }
.nav-cta:hover { background: #e6c200 !important; transform: translateY(-2px); box-shadow: 0 4px 20px rgba(255, 214, 0, 0.3); }
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; padding: 5px; }
.hamburger span { width: 24px; height: 2px; background: var(--white); transition: var(--transition); }

/* ═══ HERO ═══ */
.hero { background: var(--yellow); padding-top: calc(72px + var(--section-pad)); padding-bottom: var(--section-pad); position: relative; overflow: hidden; min-height: 100vh; display: flex; align-items: center; }
.hero .container { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 60px; align-items: center; }
.hero-badge { display: inline-block; font-size: 0.75rem; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 24px; padding: 8px 16px; background: var(--black); color: var(--yellow); border-radius: 4px; }
.hero h1 { font-size: clamp(2.5rem, 5vw, 4.5rem); font-weight: 800; line-height: 1.05; letter-spacing: -2px; color: var(--black); margin-bottom: 24px; }
.hero-sub { font-size: clamp(1rem, 1.5vw, 1.25rem); font-weight: 400; line-height: 1.6; color: rgba(10, 10, 10, 0.75); margin-bottom: 40px; max-width: 520px; }
.hero-ctas { display: flex; gap: 16px; flex-wrap: wrap; }
.btn-primary { display: inline-flex; align-items: center; gap: 8px; padding: 16px 32px; background: var(--black); color: var(--white); border: 2px solid var(--black); border-radius: var(--radius); font-family: var(--font); font-size: 0.9375rem; font-weight: 600; text-decoration: none; cursor: pointer; transition: var(--transition); }
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 8px 30px rgba(10, 10, 10, 0.3); }
.btn-outline { display: inline-flex; align-items: center; gap: 8px; padding: 16px 32px; background: transparent; color: var(--black); border: 2px solid var(--black); border-radius: var(--radius); font-family: var(--font); font-size: 0.9375rem; font-weight: 600; text-decoration: none; cursor: pointer; transition: var(--transition); }
.btn-outline:hover { background: var(--black); color: var(--white); transform: translateY(-3px); }
.btn-yellow { display: inline-flex; align-items: center; gap: 8px; padding: 16px 32px; background: var(--yellow); color: var(--black); border: 2px solid var(--yellow); border-radius: var(--radius); font-family: var(--font); font-size: 0.9375rem; font-weight: 700; text-decoration: none; cursor: pointer; transition: var(--transition); }
.btn-yellow:hover { background: #e6c200; transform: translateY(-3px); box-shadow: 0 8px 30px rgba(255, 214, 0, 0.4); }

/* Hero Blueprint Visual */
.hero-visual { position: relative; display: flex; align-items: center; justify-content: center; min-height: 400px; }
.blueprint-grid { position: absolute; width: 100%; height: 100%; opacity: 0.12; background-image: linear-gradient(var(--black) 1px, transparent 1px), linear-gradient(90deg, var(--black) 1px, transparent 1px); background-size: 40px 40px; }
.blueprint-diagram { position: relative; z-index: 1; width: 100%; max-width: 450px; }
.blueprint-diagram svg { width: 100%; height: auto; }

/* ═══ SOCIAL PROOF / NUMBERS ═══ */
.social-proof { background: var(--black); padding: var(--section-pad) 0; }
.social-proof .section-title { color: var(--white); text-align: center; font-size: clamp(1.75rem, 3vw, 2.5rem); font-weight: 700; letter-spacing: -1px; margin-bottom: 60px; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 40px; }
.stat-card { text-align: center; padding: 40px 20px; border: 1px solid rgba(255, 214, 0, 0.15); border-radius: var(--radius); transition: var(--transition); }
.stat-card:hover { border-color: var(--yellow); background: rgba(255, 214, 0, 0.05); }
.stat-number { font-size: clamp(2.5rem, 4vw, 4rem); font-weight: 900; color: var(--yellow); line-height: 1; margin-bottom: 12px; }
.stat-label { font-size: 0.9375rem; color: rgba(255, 255, 255, 0.7); font-weight: 400; line-height: 1.4; }
.stat-line { width: 40px; height: 2px; background: var(--yellow); margin: 16px auto 0; }

/* ═══ SERVICES ═══ */
.services { background: var(--white); padding: var(--section-pad) 0; }
.section-header { text-align: center; margin-bottom: 64px; }
.section-badge { display: inline-block; font-size: 0.75rem; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 16px; padding: 8px 16px; border-radius: 4px; }
.section-header h2 { font-size: clamp(1.75rem, 3.5vw, 3rem); font-weight: 700; letter-spacing: -1.5px; margin-bottom: 16px; }
.section-header p { font-size: 1.125rem; color: rgba(10, 10, 10, 0.6); max-width: 600px; margin: 0 auto; line-height: 1.6; }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.service-card { padding: 36px; border: 1px solid rgba(10, 10, 10, 0.1); border-radius: var(--radius); transition: var(--transition); cursor: pointer; position: relative; overflow: hidden; }
.service-card:hover { background: var(--yellow); border-color: var(--yellow); transform: translateY(-4px); box-shadow: 0 12px 40px rgba(255, 214, 0, 0.2); }
.service-icon { width: 48px; height: 48px; margin-bottom: 20px; display: flex; align-items: center; justify-content: center; }
.service-icon svg { width: 32px; height: 32px; stroke: var(--black); stroke-width: 1.5; fill: none; }
.service-card h3 { font-size: 1.125rem; font-weight: 700; margin-bottom: 10px; letter-spacing: -0.3px; }
.service-card p { font-size: 0.875rem; color: rgba(10, 10, 10, 0.6); line-height: 1.6; margin-bottom: 16px; }
.service-card:hover p { color: rgba(10, 10, 10, 0.8); }
.service-arrow { font-size: 1.25rem; color: var(--yellow); font-weight: 700; transition: var(--transition); }
.service-card:hover .service-arrow { color: var(--black); transform: translateX(4px); }

/* ═══ METHOD ═══ */
.method { background: var(--black); padding: var(--section-pad) 0; }
.method .section-header h2, .method .section-header p { color: var(--white); }
.method .section-header p { color: rgba(255, 255, 255, 0.6); }
.method .section-badge { background: var(--yellow); color: var(--black); }
.method-pipeline { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-bottom: 60px; position: relative; }
.method-pipeline::before { content: ''; position: absolute; top: 60px; left: 10%; right: 10%; height: 2px; background: linear-gradient(90deg, var(--yellow) 0%, rgba(255, 214, 0, 0.3) 100%); z-index: 0; }
.method-step { position: relative; z-index: 1; text-align: center; padding: 32px 20px; border: 1px solid rgba(255, 214, 0, 0.2); border-radius: var(--radius); background: var(--black); transition: var(--transition); }
.method-step:hover { border-color: var(--yellow); background: rgba(255, 214, 0, 0.05); }
.step-number { font-size: 3rem; font-weight: 900; color: var(--yellow); line-height: 1; margin-bottom: 8px; }
.step-name { font-size: 0.875rem; font-weight: 700; color: var(--white); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 16px; }
.step-icon { margin-bottom: 16px; }
.step-icon svg { width: 36px; height: 36px; stroke: var(--yellow); stroke-width: 1.5; fill: none; }
.step-list { list-style: none; text-align: left; }
.step-list li { font-size: 0.8125rem; color: rgba(255, 255, 255, 0.6); padding: 4px 0; padding-left: 16px; position: relative; }
.step-list li::before { content: '→'; position: absolute; left: 0; color: var(--yellow); font-size: 0.75rem; }
.method-cta { text-align: center; }

/* ═══ TARGET AUDIENCE ═══ */
.target { background: var(--gray); padding: var(--section-pad) 0; }
.target-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.target-card { background: var(--white); padding: 48px 36px; border-radius: var(--radius); border: 1px solid rgba(10, 10, 10, 0.06); transition: var(--transition); text-align: center; }
.target-card:hover { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(10, 10, 10, 0.08); border-color: var(--yellow); }
.target-icon { width: 64px; height: 64px; margin: 0 auto 24px; background: var(--yellow); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.target-icon svg { width: 28px; height: 28px; stroke: var(--black); stroke-width: 1.5; fill: none; }
.target-card h3 { font-size: 1.125rem; font-weight: 700; margin-bottom: 12px; letter-spacing: -0.3px; }
.target-card p { font-size: 0.875rem; color: rgba(10, 10, 10, 0.6); line-height: 1.6; }

/* ═══ CASES ═══ */
.cases { background: var(--white); padding: var(--section-pad) 0; }
.logos-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 40px; margin-bottom: 60px; padding: 40px 0; border-top: 1px solid rgba(10, 10, 10, 0.08); border-bottom: 1px solid rgba(10, 10, 10, 0.08); }
.logo-placeholder { width: 120px; height: 48px; background: var(--gray); border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 0.75rem; font-weight: 600; color: rgba(10, 10, 10, 0.3); letter-spacing: 1px; text-transform: uppercase; transition: var(--transition); }
.logo-placeholder:hover { background: var(--yellow); color: var(--black); }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.testimonial-card { padding: 36px; border: 1px solid rgba(10, 10, 10, 0.08); border-radius: var(--radius); transition: var(--transition); }
.testimonial-card:hover { border-color: var(--yellow); transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,0.06); }
.testimonial-quote { font-size: 2rem; color: var(--yellow); font-weight: 900; line-height: 1; margin-bottom: 16px; }
.testimonial-text { font-size: 0.9375rem; line-height: 1.7; color: rgba(10,10,10,0.7); margin-bottom: 24px; font-style: italic; }
.testimonial-author { display: flex; align-items: center; gap: 12px; }
.testimonial-avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--yellow); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.875rem; }
.testimonial-info h4 { font-size: 0.875rem; font-weight: 700; }
.testimonial-info span { font-size: 0.75rem; color: rgba(10,10,10,0.5); }

/* ═══ CONTACT FORM ═══ */
.contact { background: var(--yellow); padding: var(--section-pad) 0; }
.contact .section-header h2 { color: var(--black); }
.contact .section-header p { color: rgba(10,10,10,0.7); }
.contact-grid { display: grid; grid-template-columns: 1fr 380px; gap: 60px; align-items: start; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { display: flex; flex-direction: column; }
.form-group.full-width { grid-column: 1 / -1; }
.form-group label { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; color: var(--black); }
.form-group input, .form-group select, .form-group textarea { padding: 14px 16px; background: var(--white); border: 1.5px solid var(--black); border-radius: 6px; font-family: var(--font); font-size: 0.9375rem; color: var(--black); transition: var(--transition); outline: none; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--black); box-shadow: 0 0 0 3px rgba(10,10,10,0.15); }
.form-group textarea { resize: vertical; min-height: 100px; }
.radio-group { display: flex; gap: 20px; padding-top: 4px; }
.radio-option { display: flex; align-items: center; gap: 6px; cursor: pointer; font-size: 0.875rem; font-weight: 500; }
.radio-option input[type="radio"] { accent-color: var(--black); width: 16px; height: 16px; }
.form-submit { grid-column: 1 / -1; margin-top: 12px; }
.form-submit button { width: 100%; padding: 18px; background: var(--black); color: var(--white); border: none; border-radius: var(--radius); font-family: var(--font); font-size: 1rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; cursor: pointer; transition: var(--transition); }
.form-submit button:hover { transform: translateY(-3px); box-shadow: 0 8px 30px rgba(10,10,10,0.3); }
.contact-benefits { padding-top: 40px; }
.contact-benefits h3 { font-size: 1.25rem; font-weight: 700; margin-bottom: 24px; }
.benefit-item { display: flex; align-items: center; gap: 12px; padding: 12px 0; font-size: 0.9375rem; font-weight: 500; }
.benefit-check { width: 28px; height: 28px; background: var(--black); color: var(--yellow); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.875rem; font-weight: 700; flex-shrink: 0; }

/* ═══ FAQ ═══ */
.faq { background: var(--black); padding: var(--section-pad) 0; }
.faq .section-header h2 { color: var(--white); }
.faq-list { max-width: 800px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid rgba(255,255,255,0.1); }
.faq-question { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 24px 0; background: none; border: none; cursor: pointer; font-family: var(--font); font-size: 1.0625rem; font-weight: 600; color: var(--white); text-align: left; transition: var(--transition); }
.faq-question:hover { color: var(--yellow); }
.faq-icon { font-size: 1.5rem; color: var(--yellow); transition: transform 0.3s ease; font-weight: 300; }
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.4s ease, padding 0.4s ease; }
.faq-answer p { padding: 0 0 24px; font-size: 0.9375rem; color: rgba(255,255,255,0.6); line-height: 1.7; }

/* ═══ CTA FINAL ═══ */
.final-cta { background: var(--yellow); padding: var(--section-pad) 0; text-align: center; }
.final-cta h2 { font-size: clamp(2rem, 4vw, 3.5rem); font-weight: 800; letter-spacing: -1.5px; margin-bottom: 16px; }
.final-cta p { font-size: 1.125rem; color: rgba(10,10,10,0.7); margin-bottom: 40px; max-width: 600px; margin-left: auto; margin-right: auto; line-height: 1.6; }

/* ═══ FOOTER ═══ */
.footer { background: var(--black); padding: 80px 0 0; }
.footer-top { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 60px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.footer-brand .nav-logo { font-size: 1.75rem; }
.footer-tagline { font-size: 0.75rem; letter-spacing: 3px; color: rgba(255,255,255,0.4); text-transform: uppercase; margin-top: 12px; }
.footer-links { display: flex; gap: 32px; }
.footer-links a { color: rgba(255,255,255,0.6); text-decoration: none; font-size: 0.875rem; transition: var(--transition); }
.footer-links a:hover { color: var(--yellow); }
.footer-social { display: flex; gap: 16px; }
.footer-social a { width: 40px; height: 40px; border: 1px solid rgba(255,214,0,0.4); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: var(--transition); color: var(--yellow); }
.footer-social a:hover { background: var(--yellow); border-color: var(--yellow); color: var(--black); }
.footer-social a svg { width: 18px; height: 18px; color: inherit; transition: var(--transition); }
.footer-bottom { padding: 32px 0; text-align: center; }
.footer-copy { font-size: 0.8125rem; color: rgba(255,255,255,0.4); margin-bottom: 12px; }
.footer-bar { font-size: 0.6875rem; letter-spacing: 4px; text-transform: uppercase; color: rgba(255,255,255,0.2); font-weight: 600; }

/* ═══ RESPONSIVE ═══ */
@media (max-width: 1024px) {
  :root { --section-pad: 80px; }
  .hero .container { grid-template-columns: 1fr; text-align: center; }
  .hero-sub { margin-left: auto; margin-right: auto; }
  .hero-ctas { justify-content: center; }
  .hero-visual { display: none; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .method-pipeline { grid-template-columns: repeat(2, 1fr); }
  .method-pipeline::before { display: none; }
  .target-grid { grid-template-columns: 1fr; max-width: 500px; margin: 0 auto; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-top { flex-direction: column; gap: 32px; align-items: center; text-align: center; }
  .footer-links { flex-wrap: wrap; justify-content: center; }
}

@media (max-width: 768px) {
  :root { --section-pad: 60px; }
  .container { padding: 0 20px; }
  .nav-links { display: none; position: fixed; top: 72px; left: 0; width: 100%; background: var(--black); flex-direction: column; padding: 32px 20px; gap: 24px; border-bottom: 1px solid var(--yellow); z-index: 999; }
  .nav-links.open { display: flex; }
  .hamburger { display: flex; }
  .hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
  .hamburger.open span:nth-child(2) { opacity: 0; }
  .hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
  .services-grid { grid-template-columns: 1fr; }
  .method-pipeline { grid-template-columns: 1fr; }
  .energy-border--top,.energy-border--bottom { height: 2px; }
  .energy-border--left,.energy-border--right { width: 2px; }
  .wizard-card { padding: 24px 16px; }
  .wiz-cards-grid { grid-template-columns: 1fr 1fr; }
  .wiz-cards-row { flex-wrap: wrap; }
  .wiz-cards-row .wiz-card-opt { min-width: calc(50% - 4px); flex: unset; }
  .wiz-input { font-size: 16px; }
  .graph-container { grid-template-columns: 1fr; }
  .graph-visual { height: 200px; }
  .graph-stats { flex-wrap: wrap; justify-content: center; }
  .btn-primary,.btn-outline,.btn-yellow { width: 100%; justify-content: center; }
  .hero-visual { min-height: 260px; }
}

/* ═══ KEYFRAME ANIMATIONS ═══ */
@keyframes pulse-border { 0%,100%{ box-shadow: 0 0 0 0 rgba(255,214,0,0.5); } 50%{ box-shadow: 0 0 20px 4px rgba(255,214,0,0.3); } }
@keyframes float { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-10px); } }
@keyframes spin-slow { from{ transform: rotate(0deg); } to{ transform: rotate(360deg); } }
@keyframes dash { to{ stroke-dashoffset: -100; } }
@keyframes fade-up { from{ opacity:0; transform: translateY(30px); } to{ opacity:1; transform: translateY(0); } }
@keyframes scale-in { from{ opacity:0; transform: scale(0.8); } to{ opacity:1; transform: scale(1); } }
@keyframes slide-left { from{ opacity:0; transform: translateX(-40px); } to{ opacity:1; transform: translateX(0); } }
@keyframes slide-right { from{ opacity:0; transform: translateX(40px); } to{ opacity:1; transform: translateX(0); } }
@keyframes glow-pulse { 0%,100%{ opacity: 0.3; } 50%{ opacity: 1; } }
@keyframes border-flow { 0%{ background-position: 0% 50%; } 50%{ background-position: 100% 50%; } 100%{ background-position: 0% 50%; } }

/* Pulsing yellow border on sections */
.pulse-section { position: relative; }
.pulse-section::before { content:''; position: absolute; top:0; left:0; right:0; bottom:0; border: 1px solid var(--yellow); pointer-events: none; animation: pulse-border 3s ease-in-out infinite; border-radius: 0; z-index:1; }

/* Glowing line separators */
.glow-line { height: 2px; background: linear-gradient(90deg, transparent, var(--yellow), transparent); background-size: 200% 100%; animation: border-flow 3s linear infinite; margin: 0 auto; max-width: 600px; }

/* Hero SVG — NO ROTATION, breathing + pulsing */
.hero-visual { animation: float 6s ease-in-out infinite; }
.svg-breathe { animation: svgBreathe 3s ease-in-out infinite; }
@keyframes svgBreathe { 0%,100%{ stroke-opacity:0.3; } 50%{ stroke-opacity:0.9; } }
.svg-pulse-dot { animation: svgPulse 2s ease-in-out infinite; transform-origin: center; }
@keyframes svgPulse { 0%,100%{ r:6; } 50%{ r:9; } }
.svg-center-glow { animation: svgGlow 2.5s ease-in-out infinite; }
@keyframes svgGlow { 0%,100%{ filter:drop-shadow(0 0 0 rgba(255,214,0,0)); } 50%{ filter:drop-shadow(0 0 8px rgba(255,214,0,0.6)); } }
.svg-draw { stroke-dasharray: 600; stroke-dashoffset: 600; animation: svgDrawLine 1.2s ease-out forwards; }
@keyframes svgDrawLine { to { stroke-dashoffset: 0; } }

/* ═══ ENERGY BORDERS ═══ */
.energy-border { position:fixed; z-index:9999; pointer-events:none; background:var(--yellow); }
.energy-border--top { top:0;left:0;right:0;height:3px; animation:borderPulse 3s ease-in-out infinite; }
.energy-border--bottom { bottom:0;left:0;right:0;height:3px; animation:borderPulse 3s ease-in-out infinite 1.5s; }
.energy-border--left { top:0;left:0;bottom:0;width:3px; overflow:hidden; animation:borderPulse 3s ease-in-out infinite 0.75s; }
.energy-border--right { top:0;right:0;bottom:0;width:3px; overflow:hidden; animation:borderPulse 3s ease-in-out infinite 2.25s; }
.energy-scan { position:absolute; left:0; width:100%; height:100px; background:linear-gradient(to bottom,transparent,var(--yellow),#fff,var(--yellow),transparent); box-shadow: 0 0 20px var(--yellow); animation:energyScan 2s linear infinite; }
@keyframes borderPulse { 0%,100%{opacity:0.4;box-shadow:0 0 8px #FFD600,0 0 20px #FFD600;} 50%{opacity:1;box-shadow:0 0 15px #FFD600,0 0 40px #FFD600,0 0 60px rgba(255,214,0,0.4);} }
@keyframes energyScan { 0%{top:-100px;} 100%{top:calc(100% + 100px);} }
/* Staggered reveal */
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }

/* ═══ GRAPH SECTION ═══ */
.graph-section { background: var(--black); padding: var(--section-pad) 0; position: relative; overflow: hidden; }
.graph-section::before { content:''; position:absolute; top:0; left:0; right:0; bottom:0; border:1px solid rgba(255,214,0,0.1); pointer-events:none; animation: pulse-border 4s ease-in-out infinite; }
.graph-container { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.graph-text h2 { color: var(--white); font-size: clamp(1.75rem,3vw,2.5rem); font-weight:700; letter-spacing:-1px; margin-bottom:16px; }
.graph-text p { color: rgba(255,255,255,0.6); font-size:1rem; line-height:1.7; margin-bottom: 32px; }
.graph-stats { display: flex; gap: 32px; }
.graph-stat { text-align:center; }
.graph-stat .num { font-size:2rem; font-weight:900; color:var(--yellow); }
.graph-stat .lbl { font-size:0.75rem; color:rgba(255,255,255,0.5); text-transform:uppercase; letter-spacing:1px; margin-top:4px; }
.graph-visual { position:relative; height:300px; display:flex; align-items:flex-end; gap:12px; padding: 20px; border: 1px solid rgba(255,214,0,0.15); border-radius: var(--radius); }
.graph-bar { flex:1; background: linear-gradient(to top, var(--yellow), rgba(255,214,0,0.4)); border-radius: 4px 4px 0 0; transition: height 1.5s cubic-bezier(0.4,0,0.2,1); position: relative; }
.graph-bar .bar-label { position:absolute; top:-24px; left:50%; transform:translateX(-50%); font-size:0.625rem; color:rgba(255,255,255,0.5); white-space:nowrap; text-transform:uppercase; letter-spacing:1px; }
.graph-bar .bar-value { position:absolute; top:-44px; left:50%; transform:translateX(-50%); font-size:0.875rem; font-weight:700; color:var(--yellow); }
.graph-line { position:absolute; bottom:20px; left:20px; right:20px; height:1px; background:rgba(255,255,255,0.1); }

@media(max-width:1024px) { .graph-container { grid-template-columns:1fr; } }

/* ═══ CLIENTS MARQUEE ═══ */
.clients-marquee { overflow:hidden; padding: 20px 0; position:relative; }
.clients-marquee::before,.clients-marquee::after { content:''; position:absolute; top:0; bottom:0; width:80px; z-index:2; pointer-events:none; }
.clients-marquee::before { left:0; background:linear-gradient(to right, var(--white), transparent); }
.clients-marquee::after { right:0; background:linear-gradient(to left, var(--white), transparent); }
.marquee-track { display:flex; gap:48px; animation: marquee 30s linear infinite; width: max-content; }
@keyframes marquee { 0%{transform:translateX(0);} 100%{transform:translateX(-50%);} }
.client-name { font-size:1rem; font-weight:600; color:rgba(10,10,10,0.35); white-space:nowrap; text-transform:uppercase; letter-spacing:2px; transition:var(--transition); padding: 12px 0; }
.client-name:hover { color:var(--yellow); }

/* ═══ WIZARD FORM (GAMIFIED) ═══ */
.wizard-container { max-width:680px; margin:0 auto; }
.wizard-card { background:var(--black); border-radius:16px; padding:40px 36px; position:relative; overflow:hidden; }
.wizard-header { display:flex; justify-content:space-between; margin-bottom:8px; }
.wizard-step-label { font-size:0.75rem; font-weight:600; letter-spacing:2px; color:var(--yellow); text-transform:uppercase; }
.wizard-pct { font-size:0.75rem; font-weight:700; color:var(--yellow); }
.wizard-bar { height:4px; background:#333; border-radius:4px; margin-bottom:24px; overflow:hidden; }
.wizard-bar-fill { height:100%; background:var(--yellow); border-radius:4px; transition:width 0.5s ease; }
.wizard-dots { display:flex; justify-content:center; gap:12px; margin-bottom:32px; }
.wiz-dot { width:32px; height:32px; border-radius:50%; border:2px solid #444; display:flex; align-items:center; justify-content:center; font-size:0.75rem; font-weight:700; color:#666; transition:all 0.3s; }
.wiz-dot.active { border-color:var(--yellow); background:var(--yellow); color:var(--black); }
.wiz-dot.done { border-color:var(--yellow); background:transparent; color:var(--yellow); }
.wizard-body { position:relative; min-height:280px; }
.wiz-step { display:none; animation:wizSlide 0.4s ease forwards; }
.wiz-step.active { display:block; }
@keyframes wizSlide { from{opacity:0;transform:translateX(30px)} to{opacity:1;transform:translateX(0)} }
.wiz-step h3 { color:var(--white); font-size:1.375rem; font-weight:700; margin-bottom:20px; text-align:center; }
.wiz-input { width:100%; padding:14px 16px; background:#1a1a1a; border:1.5px solid #333; border-radius:8px; color:var(--white); font-family:var(--font); font-size:1rem; margin-bottom:12px; transition:border 0.3s; outline:none; }
.wiz-input:focus { border-color:var(--yellow); }
.wiz-textarea { min-height:80px; resize:vertical; }
.wiz-label { display:block; font-size:0.8125rem; font-weight:600; color:rgba(255,255,255,0.6); margin-bottom:6px; margin-top:8px; }
.wiz-nav { display:flex; justify-content:space-between; gap:12px; margin-top:24px; }
.wiz-next { flex:1; padding:14px 24px; background:var(--yellow); color:var(--black); border:none; border-radius:8px; font-family:var(--font); font-size:0.9375rem; font-weight:700; cursor:pointer; transition:all 0.3s; }
.wiz-next:hover { box-shadow:0 0 20px rgba(255,214,0,0.4); transform:translateY(-2px); }
.wiz-back { padding:14px 24px; background:transparent; color:#888; border:1px solid #444; border-radius:8px; font-family:var(--font); font-size:0.875rem; font-weight:500; cursor:pointer; transition:all 0.3s; }
.wiz-back:hover { border-color:var(--yellow); color:var(--yellow); }
.wiz-cards-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.wiz-cards-row { display:flex; flex-wrap:wrap; gap:8px; }
.wiz-card-opt { padding:16px 12px; background:#1a1a1a; border:2px solid #333; border-radius:10px; color:var(--white); font-size:0.875rem; font-weight:600; cursor:pointer; text-align:center; transition:all 0.2s; }
.wiz-card-opt span { display:block; font-size:1.5rem; margin-bottom:4px; }
.wiz-card-opt.selected { border-color:var(--yellow); background:rgba(255,214,0,0.1); transform:scale(1.03); }
.wiz-card-opt:hover { border-color:rgba(255,214,0,0.5); }
.wiz-cards-row .wiz-card-opt { flex:1; min-width:80px; padding:12px 8px; font-size:0.8125rem; }
.wiz-checks { display:flex; flex-direction:column; gap:10px; }
.wiz-check { display:flex; align-items:center; gap:12px; padding:14px 16px; background:#1a1a1a; border:1.5px solid #333; border-radius:8px; color:var(--white); font-size:0.9375rem; cursor:pointer; transition:all 0.2s; }
.wiz-check:hover { border-color:rgba(255,214,0,0.4); }
.wiz-check input { display:none; }
.wiz-checkmark { width:22px; height:22px; border:2px solid #555; border-radius:4px; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all 0.2s; }
.wiz-check input:checked ~ .wiz-checkmark { background:var(--yellow); border-color:var(--yellow); }
.wiz-check input:checked ~ .wiz-checkmark::after { content:'✓'; color:var(--black); font-size:0.875rem; font-weight:700; }
.wiz-final { text-align:center; padding:20px 0; }
.wiz-final h3 { font-size:1.75rem; }
.wiz-final p { color:rgba(255,255,255,0.6); margin-bottom:32px; font-size:1rem; }
.wiz-calendly-btn { display:inline-block; padding:18px 40px; background:var(--yellow); color:var(--black); border-radius:10px; font-size:1.125rem; font-weight:800; text-decoration:none; transition:all 0.3s; }
.wiz-calendly-btn:hover { transform:translateY(-3px); box-shadow:0 8px 30px rgba(255,214,0,0.5); }
.wiz-benefits { margin-top:20px; font-size:0.8125rem; color:rgba(255,255,255,0.4); }
.wiz-shake { animation:wizShake 0.4s ease; }
@keyframes wizShake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-8px)} 75%{transform:translateX(8px)} }

/* Calendly embed */
.calendly-wrapper { border-radius:var(--radius); overflow:hidden; border:2px solid var(--black); min-height:500px; }
.calendly-wrapper iframe { width:100%; height:600px; border:none; }

/* ═══ ENHANCED MOTION ═══ */
.service-card { transition: all 0.4s cubic-bezier(0.4,0,0.2,1); }
.stat-card { transition: all 0.4s cubic-bezier(0.4,0,0.2,1); }
.stat-card:hover { transform: translateY(-8px) scale(1.02); }
.method-step { transition: all 0.4s cubic-bezier(0.4,0,0.2,1); }
.method-step:hover { transform: translateY(-8px); }
.testimonial-card { transition: all 0.4s cubic-bezier(0.4,0,0.2,1); }

/* Navbar pulsing border */
.navbar { border-bottom: 1px solid var(--yellow); animation: pulse-border 4s ease-in-out infinite; }
