/* ============================================
   BEDEL AI — Landing Page
   Hand-crafted, no frameworks
   ============================================ */

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

:root{
  --bg:#060608;
  --bg2:#0b0b0f;
  --surface:#111118;
  --text:#e2e2e6;
  --muted:#6b6b78;
  --dim:#3a3a46;
  --accent:#8b9cf7;
  --accent2:#6d7ff0;
  --border:rgba(255,255,255,.06);
  --glass:rgba(255,255,255,.03);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-in:cubic-bezier(.55,.055,.675,.19);
}

html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
::selection{background:rgba(139,156,247,.2);color:#fff}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ============================
   INTRO SCREEN
   ============================ */
.intro{position:fixed;inset:0;z-index:2000;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .8s var(--ease),transform .8s var(--ease)}
.intro.hide{opacity:0;transform:scale(1.05);pointer-events:none}
.intro-particles{position:absolute;inset:0;z-index:0}
.intro-content{position:relative;z-index:1;text-align:center}
.intro-logo{opacity:0;transform:translateY(24px);animation:introReveal 1s var(--ease) .3s forwards}
.intro-logo-img{height:72px;width:auto;filter:brightness(0) invert(1);margin:0 auto}
.intro-tagline{margin-top:20px;font-size:1rem;color:var(--muted);height:28px;opacity:0;animation:introReveal .7s var(--ease) 1.4s forwards;letter-spacing:.06em;font-weight:300}
.intro-cursor{animation:cursorBlink 1s step-end infinite;color:var(--accent)}
@keyframes cursorBlink{0%,100%{opacity:1}50%{opacity:0}}
.intro-btn{margin-top:40px;padding:16px 44px;background:transparent;border:1px solid rgba(255,255,255,.12);color:var(--text);font-family:var(--font);font-size:.78rem;font-weight:400;cursor:pointer;display:inline-flex;align-items:center;gap:10px;opacity:0;animation:introReveal .7s var(--ease) 3s forwards;transition:all .4s var(--ease);letter-spacing:.14em;text-transform:uppercase}
.intro-btn:hover{border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.04);gap:14px}
.intro-skip{position:absolute;top:24px;right:28px;background:none;border:none;color:var(--dim);font-family:var(--font);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;padding:10px 14px;opacity:0;animation:introReveal .6s var(--ease) .8s forwards;transition:color .3s,letter-spacing .3s;z-index:2}
.intro-skip:hover{color:var(--text);letter-spacing:.18em}
@keyframes introReveal{to{opacity:1;transform:translateY(0)}}

/* Site wrapper */
.site{opacity:0;transition:opacity .5s var(--ease) .2s}
.site.show{opacity:1}

/* Noise texture */
body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* Custom scrollbar */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--dim);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* ============================
   CUSTOM CURSOR
   ============================ */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:10000;border-radius:50%;will-change:transform}
.cursor-dot{width:6px;height:6px;background:#fff;margin:-3px 0 0 -3px;transition:transform .15s var(--ease),opacity .2s}
.cursor-ring{width:36px;height:36px;border:1px solid rgba(255,255,255,.25);margin:-18px 0 0 -18px;transition:width .3s var(--ease),height .3s var(--ease),margin .3s var(--ease),border-color .3s,background .3s}
.cursor-ring.hover{width:56px;height:56px;margin:-28px 0 0 -28px;border-color:var(--accent);background:rgba(139,156,247,.06)}
.cursor-ring.click{transform:scale(.85)!important}

@media(hover:none),(pointer:coarse){
  .cursor-dot,.cursor-ring{display:none!important}
}

/* ============================
   SCROLL PROGRESS
   ============================ */
.scroll-progress{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--accent2),var(--accent),#fff);z-index:9998;will-change:width;transform-origin:left}

/* ============================
   NAVIGATION
   ============================ */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 0;transition:all .5s var(--ease)}
.navbar.scrolled{padding:12px 0;background:rgba(6,6,8,.9);-webkit-backdrop-filter:blur(24px) saturate(1.4);backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center}
.logo-img{height:44px;width:auto;filter:brightness(0) invert(1);transition:opacity .3s}
.nav-links{display:flex;gap:32px}
.nav-links a{color:var(--muted);font-size:.72rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;transition:color .3s;position:relative}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:1px;background:var(--accent);transition:width .4s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{padding:10px 24px;border:1px solid rgba(255,255,255,.12);color:var(--text);font-size:.72rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;transition:all .3s var(--ease)}
.nav-cta:hover{background:#fff;color:#000;border-color:#fff}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px;z-index:110}
.nav-toggle span{display:block;width:22px;height:1.5px;background:#fff;transition:all .4s var(--ease);transform-origin:center}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.nav-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}

.nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:90;opacity:0;pointer-events:none;transition:opacity .4s}
.nav-backdrop.active{opacity:1;pointer-events:all}

/* ============================
   BUTTONS
   ============================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 36px;font-weight:400;font-size:.78rem;cursor:pointer;transition:all .4s var(--ease);border:none;font-family:var(--font);letter-spacing:.1em;text-transform:uppercase;position:relative;overflow:hidden}
.btn span{position:relative;z-index:1}
.btn svg{position:relative;z-index:1;transition:transform .3s var(--ease)}
.btn:hover svg{transform:translateX(3px)}
.btn-primary{background:#fff;color:#000}
.btn-primary::before{content:'';position:absolute;inset:0;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.btn-primary:hover{color:#fff}
.btn-primary:hover::before{transform:scaleX(1);transform-origin:left}
.btn-ghost{background:transparent;color:var(--text);border:1px solid rgba(255,255,255,.1)}
.btn-ghost:hover{border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.03)}
.btn-lg{padding:18px 44px;font-size:.8rem}
.btn-block{width:100%}

/* ============================
   HERO
   ============================ */
.hero{height:100vh;height:100dvh;display:flex;flex-direction:column;position:relative;overflow:hidden}
.hero-canvas{position:absolute;inset:0;z-index:0;opacity:.5}
.hero-inner{flex:1;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,6vw,80px);align-items:center;padding-top:clamp(80px,12vh,120px);position:relative;z-index:1}
.hero-content{position:relative}

/* Eyebrow */
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:clamp(20px,3vh,32px);font-size:.68rem;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;overflow:hidden}
.eyebrow-line{width:32px;height:1px;background:var(--accent);flex-shrink:0}

/* Title */
.hero-title{font-size:clamp(2rem,4.5vw,3.6rem);font-weight:200;line-height:1.1;margin-bottom:clamp(16px,2.5vh,28px);letter-spacing:-.04em}
.title-line{display:block;overflow:hidden}
.title-word{display:inline-block;transform:translateY(110%);animation:wordReveal .8s var(--ease) forwards;animation-delay:calc(.15s + var(--i) * .1s)}
@keyframes wordReveal{to{transform:translateY(0)}}
.title-accent{font-weight:700;background:linear-gradient(135deg,#fff 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Subtitle */
.hero-sub{font-size:clamp(.88rem,1.1vw,1rem);color:var(--muted);margin-bottom:clamp(24px,3vh,40px);max-width:420px;line-height:1.75;font-weight:300;opacity:0;animation:fadeUp .8s var(--ease) .6s forwards}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.hero-sub{transform:translateY(16px)}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;opacity:0;animation:fadeUp .8s var(--ease) .75s forwards;transform:translateY(16px)}

/* Voice Orb */
.hero-visual{display:flex;align-items:center;justify-content:center;opacity:0;animation:fadeUp 1s var(--ease) .4s forwards;transform:translateY(20px)}
.voice-orb{position:relative;width:clamp(200px,22vw,300px);height:clamp(200px,22vw,300px);display:flex;align-items:center;justify-content:center;cursor:pointer}
.orb-core{
  width:clamp(80px,9vw,110px);height:clamp(80px,9vw,110px);
  border-radius:50%;
  background:radial-gradient(circle at 35% 35%,rgba(139,156,247,.2),rgba(109,127,240,.05));
  border:1px solid rgba(139,156,247,.15);
  position:relative;z-index:2;
  transition:all .6s var(--ease);
  animation:orbBreathe 5s ease-in-out infinite;
}
.orb-core::before{content:'';position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle,rgba(139,156,247,.08),transparent 70%);filter:blur(30px);transform:scale(1.5)}
.voice-orb:hover .orb-core{border-color:rgba(139,156,247,.3);box-shadow:0 0 80px rgba(139,156,247,.15)}
@keyframes orbBreathe{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}

.orb-ring{position:absolute;border-radius:50%;border:1px solid rgba(139,156,247,.06);animation:ringPulse 4s ease-in-out infinite}
.orb-ring:nth-child(2){width:55%;height:55%;animation-delay:0s}
.orb-ring:nth-child(3){width:75%;height:75%;animation-delay:.6s}
.orb-ring:nth-child(4){width:95%;height:95%;animation-delay:1.2s}
@keyframes ringPulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:.08;transform:scale(1.05)}}
.voice-orb:hover .orb-ring{border-color:rgba(139,156,247,.12)}

.orb-particles{position:absolute;inset:0;z-index:1}

.orb-label{position:absolute;font-size:.62rem;color:var(--dim);letter-spacing:.12em;text-transform:uppercase;transition:all .5s var(--ease)}
.orb-label-stt{top:5%;left:50%;transform:translateX(-50%)}
.orb-label-ai{right:0;top:50%;transform:translateY(-50%)}
.orb-label-tts{bottom:5%;left:50%;transform:translateX(-50%)}
.voice-orb:hover .orb-label{color:var(--muted)}

/* Stats */
.stats-strip{flex-shrink:0;padding:clamp(14px,2vh,28px) 0;border-top:1px solid var(--border);position:relative;z-index:1}
.stats-grid{display:flex;align-items:center;justify-content:center;gap:clamp(24px,4vw,52px)}
.stat{text-align:center}
.stat-val{font-size:clamp(1.2rem,2vw,1.7rem);font-weight:200;color:#fff;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.stat-label{font-size:.62rem;color:var(--muted);margin-top:2px;letter-spacing:.1em;text-transform:uppercase}
.stat-sep{width:1px;height:clamp(20px,3vh,36px);background:var(--border)}

/* ============================
   MARQUEE
   ============================ */
.marquee{padding:20px 0;border-bottom:1px solid var(--border);overflow:hidden;background:var(--bg2)}
.marquee-track{display:flex;gap:0;animation:marqueeScroll 30s linear infinite;width:max-content}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-size:.72rem;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--dim);white-space:nowrap;padding:0 12px;transition:color .3s}
.marquee-item:hover{color:var(--accent)}
.marquee-sep{color:rgba(255,255,255,.08);padding:0 8px;font-size:.6rem}
@keyframes marqueeScroll{to{transform:translateX(-50%)}}

/* ============================
   SECTIONS
   ============================ */
.section{padding:clamp(80px,12vh,140px) 0}
.section-alt{background:var(--bg2)}

.sec-head{margin-bottom:clamp(48px,7vh,72px);text-align:center}
.sec-num{display:block;font-size:.65rem;color:var(--accent);letter-spacing:.3em;text-transform:uppercase;margin-bottom:12px;font-weight:500}
.sec-head h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:200;margin-bottom:12px;letter-spacing:-.03em}
.sec-head p{color:var(--muted);font-size:.95rem;max-width:460px;margin:0 auto;font-weight:300;line-height:1.7}

/* Reveal text animation */
.reveal-text{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-text.visible{opacity:1;transform:translateY(0)}
.reveal-text:nth-child(2){transition-delay:.08s}
.reveal-text:nth-child(3){transition-delay:.16s}

/* Scroll reveal for cards */
[data-scroll]{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-scroll].visible{opacity:1;transform:translateY(0)}

/* ============================
   HOW IT WORKS
   ============================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.step-card{padding:clamp(32px,4vh,48px) 28px;background:var(--bg);position:relative;overflow:hidden;transition:background .4s;text-align:center}
.step-card:hover{background:rgba(255,255,255,.015)}
.step-num{font-size:clamp(2.5rem,4vw,3.5rem);font-weight:100;color:rgba(255,255,255,.04);margin-bottom:8px;font-variant-numeric:tabular-nums;transition:color .5s}
.step-card:hover .step-num{color:rgba(139,156,247,.1)}
.step-line{width:24px;height:1px;background:var(--accent);margin:0 auto 20px;opacity:.3;transition:all .4s var(--ease)}
.step-card:hover .step-line{width:40px;opacity:.8}
.step-card h3{font-size:.9rem;font-weight:500;margin-bottom:10px;letter-spacing:.01em}
.step-card p{color:var(--muted);font-size:.84rem;font-weight:300;line-height:1.75;max-width:280px;margin:0 auto}

/* ============================
   FEATURES (Bento)
   ============================ */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:auto;gap:1px;background:var(--border)}
.bento-card{padding:clamp(28px,3vh,40px) 28px;background:var(--bg2);position:relative;overflow:hidden;transition:background .4s;text-align:center}
.bento-card:hover{background:rgba(255,255,255,.015)}
.bento-wide{grid-column:span 2;display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center;text-align:left}
.bento-num{font-size:.6rem;color:var(--accent);letter-spacing:.2em;margin-bottom:14px;font-weight:500}
.bento-wide .bento-num{grid-column:1/-1}
.bento-card h3{font-size:.88rem;font-weight:500;margin-bottom:8px}
.bento-card p{color:var(--muted);font-size:.82rem;font-weight:300;line-height:1.75}

/* Audio wave visual */
.bento-visual{display:flex;align-items:end;gap:3px;height:48px;opacity:.3;transition:opacity .4s}
.bento-wide:hover .bento-visual{opacity:.7}
.wave-bar{width:3px;height:var(--h);background:var(--accent);border-radius:2px;animation:waveAnim 1.2s ease-in-out infinite alternate;animation-delay:calc(var(--h) * .005s)}
@keyframes waveAnim{0%{transform:scaleY(.3)}100%{transform:scaleY(1)}}

/* ============================
   TECHNOLOGY PIPELINE
   ============================ */
.pipeline{position:relative;max-width:980px;margin:0 auto;padding:32px 0 8px}
.pipeline-track{position:absolute;top:54px;left:6%;right:6%;height:1px;background:linear-gradient(90deg,transparent,rgba(139,156,247,.2),rgba(139,156,247,.2),transparent);overflow:hidden;border-radius:1px}
.pipeline-flow{position:absolute;top:0;left:-12%;width:12%;height:100%;background:linear-gradient(90deg,transparent,var(--accent),transparent);animation:plFlow 4.5s linear infinite;will-change:transform}
@keyframes plFlow{0%{transform:translateX(0)}100%{transform:translateX(950%)}}
.pipeline-nodes{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;position:relative;z-index:1}
.pl-node{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;padding:0 4px;position:relative}
.pl-icon{width:56px;height:56px;border-radius:50%;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .5s var(--ease);position:relative}
.pl-icon::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:1px solid transparent;transition:border-color .5s,transform .5s}
.pipeline.active .pl-node[data-step="1"] .pl-icon,
.pipeline.active .pl-node[data-step="2"] .pl-icon,
.pipeline.active .pl-node[data-step="3"] .pl-icon,
.pipeline.active .pl-node[data-step="4"] .pl-icon,
.pipeline.active .pl-node[data-step="5"] .pl-icon,
.pipeline.active .pl-node[data-step="6"] .pl-icon{animation:plPulse 4.5s ease-in-out infinite;color:var(--accent);border-color:rgba(139,156,247,.3)}
.pipeline.active .pl-node[data-step="2"] .pl-icon{animation-delay:.6s}
.pipeline.active .pl-node[data-step="3"] .pl-icon{animation-delay:1.2s}
.pipeline.active .pl-node[data-step="4"] .pl-icon{animation-delay:1.8s}
.pipeline.active .pl-node[data-step="5"] .pl-icon{animation-delay:2.4s}
.pipeline.active .pl-node[data-step="6"] .pl-icon{animation-delay:3s}
@keyframes plPulse{0%,82%,100%{box-shadow:0 0 0 0 rgba(139,156,247,0)}10%{box-shadow:0 0 0 6px rgba(139,156,247,.18);transform:scale(1.06)}25%{box-shadow:0 0 0 0 rgba(139,156,247,0);transform:scale(1)}}
.pl-brain .pl-icon{background:rgba(139,156,247,.05);border-color:rgba(139,156,247,.2);color:var(--accent)}
.pl-name{font-size:.74rem;font-weight:500;color:var(--text);letter-spacing:.02em;margin-top:4px}
.pl-tech{font-size:.62rem;color:var(--muted);font-weight:300;letter-spacing:.04em;line-height:1.4}
.pl-lat{font-size:.58rem;font-weight:500;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;padding:2px 8px;border:1px solid rgba(139,156,247,.18);border-radius:10px;margin-top:2px;font-variant-numeric:tabular-nums}

.pipeline-summary{display:flex;align-items:center;justify-content:center;gap:clamp(18px,3vw,40px);margin-top:48px;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap}
.pl-sum-item{display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}
.pl-sum-num{font-size:1.05rem;font-weight:300;color:#fff;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.pl-sum-lbl{font-size:.62rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.pl-sum-sep{width:1px;height:28px;background:var(--border)}

.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);margin-top:56px;border:1px solid var(--border)}
.trust-card{padding:clamp(24px,3vh,32px) 22px;background:var(--bg2);text-align:left;transition:background .4s;position:relative;overflow:hidden}
.trust-card:hover{background:rgba(255,255,255,.015)}
.trust-icon{width:36px;height:36px;border-radius:50%;background:rgba(139,156,247,.06);border:1px solid rgba(139,156,247,.15);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:18px}
.trust-card h3{font-size:.84rem;font-weight:500;margin-bottom:8px;letter-spacing:.01em}
.trust-card p{color:var(--muted);font-size:.78rem;font-weight:300;line-height:1.7}

.tech-stack{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:48px;padding:0 12px}
.ts-label{font-size:.62rem;color:var(--dim);letter-spacing:.2em;text-transform:uppercase;margin-right:8px}
.ts-chip{font-size:.7rem;font-weight:400;color:var(--muted);padding:6px 14px;border:1px solid var(--border);border-radius:20px;letter-spacing:.02em;transition:all .3s}
.ts-chip:hover{color:var(--text);border-color:rgba(139,156,247,.3);background:rgba(139,156,247,.04)}

@media(max-width:900px){
  .pipeline-nodes{grid-template-columns:repeat(3,1fr);gap:24px 8px}
  .pipeline-track{display:none}
  .pl-node::after{content:'';position:absolute;right:-4px;top:28px;width:8px;height:8px;border-top:1px solid var(--border);border-right:1px solid var(--border);transform:rotate(45deg)}
  .pl-node:nth-child(3n)::after,.pl-node:last-child::after{display:none}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){
  .pipeline-nodes{grid-template-columns:repeat(2,1fr);gap:20px 8px}
  .pl-node:nth-child(3n)::after{display:block}
  .pl-node:nth-child(2n)::after{display:none}
  .trust-grid{grid-template-columns:1fr}
  .pl-sum-sep{display:none}
}

/* ============================
   COMPARISON
   ============================ */
.compare-table{max-width:680px;margin:0 auto;border:1px solid var(--border);overflow:hidden}
.compare-row{display:grid;grid-template-columns:1.2fr 1fr 1fr;border-bottom:1px solid var(--border);transition:background .3s}
.compare-row:last-child{border-bottom:none}
.compare-row:not(.compare-header):hover{background:rgba(255,255,255,.01)}
.compare-header{background:rgba(255,255,255,.02)}
.compare-cell{padding:16px 20px;font-size:.82rem;font-weight:300;text-align:center;transition:all .3s}
.compare-cell:first-child{text-align:left;font-weight:400;color:var(--text)}
.compare-header .compare-cell{font-weight:500;font-size:.68rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;padding:14px 20px}
.compare-ai-col{color:var(--accent)!important}
.dim{color:var(--dim)}
.win{color:var(--text);background:rgba(139,156,247,.03)}
.compare-note{max-width:680px;margin:20px auto 0;font-size:.72rem;color:var(--dim);text-align:center;line-height:1.7;font-weight:300;font-style:italic}

/* ============================
   USE CASES
   ============================ */
.cases-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}
.case-card{padding:clamp(28px,4vh,44px) 20px;background:var(--bg2);text-align:center;position:relative;overflow:hidden;transition:background .4s}
.case-card:hover{background:rgba(255,255,255,.015)}
.case-icon{display:block;font-size:1.8rem;margin-bottom:16px;transition:transform .5s var(--ease);filter:grayscale(.7) brightness(1.3)}
.case-card:hover .case-icon{transform:scale(1.15) translateY(-4px);filter:grayscale(.2) brightness(1.1)}
.case-card h3{font-size:.82rem;font-weight:500;margin-bottom:6px}
.case-card p{color:var(--muted);font-size:.76rem;font-weight:300}

/* ============================
   PRICING
   ============================ */
.pricing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);max-width:700px;margin:0 auto}
.price-card{padding:clamp(36px,5vh,52px) 32px;background:var(--bg);text-align:center;position:relative;transition:background .4s;overflow:hidden}
.price-card:hover{background:rgba(255,255,255,.01)}
.price-featured{background:rgba(139,156,247,.02)}
.price-featured:hover{background:rgba(139,156,247,.04)}
.price-badge{position:absolute;top:16px;left:50%;transform:translateX(-50%);padding:5px 18px;background:var(--accent);color:#000;font-size:.6rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.price-name{font-size:.72rem;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;margin-bottom:20px;margin-top:16px}
.price-amount{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:200;margin-bottom:28px;letter-spacing:-.02em}
.price-currency{font-size:.7em;color:var(--muted);font-weight:300;margin-right:2px}
.price-period{font-size:.7rem;font-weight:300;color:var(--muted)}
.price-custom{font-size:1.4rem;color:var(--muted);font-weight:300}
.price-features{list-style:none;text-align:left;margin-bottom:32px}
.price-features li{padding:9px 0;border-bottom:1px solid var(--border);font-size:.82rem;color:var(--muted);font-weight:300;padding-left:20px;position:relative}
.price-features li::before{content:'';position:absolute;left:0;top:50%;width:6px;height:6px;border:1px solid var(--dim);border-radius:50%;transform:translateY(-50%)}
.price-featured .price-features li::before{border-color:var(--accent);background:rgba(139,156,247,.15)}

/* ============================
   DEMO — Tabs + Phone simulator
   ============================ */
.demo-tabs{display:inline-flex;margin:0 auto 32px;border:1px solid var(--border);border-radius:999px;padding:4px;gap:2px;background:var(--bg2);justify-self:center}
.demo-wrap{display:flex;justify-content:center;flex-direction:column;align-items:center}
.demo-tab{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border:none;background:transparent;color:var(--muted);font-family:var(--font);font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;cursor:pointer;transition:all .35s var(--ease)}
.demo-tab svg{transition:transform .3s var(--ease)}
.demo-tab.active{background:var(--accent);color:#000}
.demo-tab:not(.active):hover{color:var(--text)}

.demo-phone{width:100%;max-width:380px;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:36px;overflow:hidden;box-shadow:0 40px 80px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.04);position:relative}

.phone-status{display:flex;align-items:center;justify-content:space-between;padding:8px 24px 0;font-size:.66rem;font-weight:500;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:.02em}
.phs-icons{display:inline-flex;align-items:center;gap:5px;color:var(--text);opacity:.7}

.demo-notch{width:100px;height:5px;background:var(--bg);border-radius:10px;margin:6px auto 0}
.demo-header{padding:14px 24px;display:flex;align-items:center;gap:10px;font-size:.72rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid var(--border)}

.phone-view{display:none;flex-direction:column}
.phone-view.active{display:flex;animation:phoneFade .35s var(--ease)}
@keyframes phoneFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* Call view */
.phone-call{padding:24px 22px 22px;min-height:540px;text-align:center}
.call-header{margin-top:8px;margin-bottom:18px}
.call-stage{display:block;font-size:.62rem;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;margin-bottom:10px;animation:stagePulse 1.4s ease-in-out infinite;font-weight:400}
.phone-call.connected .call-stage{animation:none;color:#34d399}
.phone-call.ended .call-stage{animation:none;color:#ef4444}
@keyframes stagePulse{0%,100%{opacity:.5}50%{opacity:1}}
.call-name{display:block;font-size:1.2rem;font-weight:300;color:#fff;letter-spacing:-.01em;margin-bottom:4px}
.call-num{display:block;font-size:.72rem;color:var(--muted);font-weight:300;letter-spacing:.04em;font-variant-numeric:tabular-nums}
.call-timer{display:block;font-size:.74rem;color:var(--accent);font-weight:400;letter-spacing:.06em;font-variant-numeric:tabular-nums;margin-top:6px}

.call-orb{position:relative;width:140px;height:140px;margin:6px auto 4px;display:flex;align-items:center;justify-content:center}
.co-glow{position:absolute;inset:-20px;border-radius:50%;background:radial-gradient(circle,rgba(139,156,247,.18),transparent 70%);filter:blur(20px);opacity:0;transition:opacity .5s var(--ease)}
.phone-call.connected .co-glow{opacity:1}
.co-core{width:64px;height:64px;border-radius:50%;background:radial-gradient(circle at 35% 35%,rgba(139,156,247,.4),rgba(109,127,240,.1));border:1px solid rgba(139,156,247,.3);position:relative;z-index:2;transition:transform .3s var(--ease)}
.phone-call.ringing .co-core{animation:coRing 1.4s ease-in-out infinite}
.phone-call.ai-speaking .co-core{animation:coSpeak .6s ease-in-out infinite}
.phone-call.user-speaking .co-core{animation:coListen 1s ease-in-out infinite;background:radial-gradient(circle at 35% 35%,rgba(52,211,153,.4),rgba(52,211,153,.1));border-color:rgba(52,211,153,.3)}
@keyframes coRing{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
@keyframes coSpeak{0%,100%{transform:scale(1)}50%{transform:scale(1.18)}}
@keyframes coListen{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.co-ring{position:absolute;border-radius:50%;border:1px solid rgba(139,156,247,.15);width:100%;height:100%;animation:coRingPulse 3s ease-in-out infinite}
.co-ring:nth-child(2){width:75%;height:75%;animation-delay:0s}
.co-ring:nth-child(3){width:90%;height:90%;animation-delay:.4s}
.co-ring:nth-child(4){width:108%;height:108%;animation-delay:.8s;border-color:rgba(139,156,247,.06)}
@keyframes coRingPulse{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:.05;transform:scale(1.04)}}
.phone-call.user-speaking .co-ring{border-color:rgba(52,211,153,.18)}
.co-state{position:absolute;font-size:.6rem;font-weight:600;color:var(--accent);letter-spacing:.16em;text-transform:uppercase;z-index:3;pointer-events:none}
.phone-call.user-speaking .co-state{color:#34d399}

.call-wave{display:flex;align-items:center;justify-content:center;gap:3px;height:34px;margin:16px auto 12px;opacity:.18;transition:opacity .3s}
.phone-call.connected .call-wave{opacity:.6}
.call-wave span{width:2px;height:8px;background:var(--accent);border-radius:2px;transition:height .12s ease-out}
.phone-call.user-speaking .call-wave span{background:#34d399}

.call-transcript{flex:1;min-height:90px;max-height:130px;overflow-y:auto;padding:10px 4px;display:flex;flex-direction:column;gap:8px;text-align:left;scroll-behavior:smooth}
.call-transcript::-webkit-scrollbar{width:2px}
.call-transcript::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08)}
.ct-line{font-size:.78rem;line-height:1.55;font-weight:300;padding:8px 12px;border-radius:12px;max-width:88%;animation:ctIn .3s var(--ease-out)}
@keyframes ctIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.ct-ai{background:rgba(139,156,247,.06);border:1px solid rgba(139,156,247,.12);color:var(--text);align-self:flex-start;border-bottom-left-radius:4px}
.ct-user{background:rgba(52,211,153,.06);border:1px solid rgba(52,211,153,.12);color:var(--text);align-self:flex-end;border-bottom-right-radius:4px}
.ct-prefix{display:block;font-size:.56rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin-bottom:3px;opacity:.7}
.ct-ai .ct-prefix{color:var(--accent)}
.ct-user .ct-prefix{color:#34d399}

.call-controls{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:14px}
.call-btn{width:54px;height:54px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .25s var(--ease),box-shadow .3s}
.call-btn:hover{transform:scale(1.06)}
.call-btn:active{transform:scale(.95)}
.call-end{background:#ef4444;box-shadow:0 8px 24px rgba(239,68,68,.3)}
.call-end svg{transform:rotate(135deg)}
.call-end:hover{box-shadow:0 12px 32px rgba(239,68,68,.45)}
.call-replay{background:var(--accent);color:#000;box-shadow:0 8px 24px rgba(139,156,247,.3)}
.call-foot{font-size:.6rem;color:var(--dim);letter-spacing:.1em;text-transform:uppercase;margin-top:14px;font-weight:300}

/* Chat view (existing) */
.phone-chat .demo-header{padding:14px 24px;display:flex;align-items:center;gap:10px;font-size:.72rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid var(--border)}
.demo-status{width:6px;height:6px;border-radius:50%;background:#34d399;box-shadow:0 0 8px rgba(52,211,153,.4);animation:statusPulse 2s infinite}
@keyframes statusPulse{0%,100%{box-shadow:0 0 0 0 rgba(52,211,153,.3)}50%{box-shadow:0 0 0 6px rgba(52,211,153,0)}}
.demo-msgs{padding:20px;min-height:280px;max-height:340px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;scroll-behavior:smooth}
.demo-msgs::-webkit-scrollbar{width:2px}
.demo-msgs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:2px}
.demo-msg{padding:11px 15px;border-radius:16px;font-size:.84rem;line-height:1.6;max-width:82%;animation:msgIn .35s var(--ease-out) forwards;font-weight:300}
@keyframes msgIn{from{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.demo-ai{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);align-self:flex-start;border-bottom-left-radius:4px}
.demo-user{background:var(--accent);color:#000;font-weight:400;align-self:flex-end;border-bottom-right-radius:4px}
.demo-loading{background:rgba(255,255,255,.02);border:1px solid var(--border);align-self:flex-start;border-bottom-left-radius:4px;padding:14px 18px}
.typing-dots{display:flex;gap:4px;align-items:center}
.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--dim);animation:dotBounce 1.4s infinite}
.typing-dots span:nth-child(2){animation-delay:.15s}
.typing-dots span:nth-child(3){animation-delay:.3s}
@keyframes dotBounce{0%,60%,100%{transform:translateY(0);opacity:.3}30%{transform:translateY(-5px);opacity:1}}

.demo-input{display:flex;border-top:1px solid var(--border);padding:4px}
.demo-input input{flex:1;padding:14px 18px;background:transparent;border:none;color:var(--text);font-family:var(--font);font-size:.86rem;outline:none;font-weight:300}
.demo-input input::placeholder{color:var(--dim)}
.demo-send{width:40px;height:40px;border-radius:50%;background:var(--accent);border:none;color:#000;cursor:pointer;display:flex;align-items:center;justify-content:center;margin:auto 6px;transition:all .3s var(--ease)}
.demo-send:hover{transform:scale(1.08);box-shadow:0 0 20px rgba(139,156,247,.3)}
.demo-send:disabled{opacity:.2;cursor:not-allowed;transform:none;box-shadow:none}

/* ============================
   FAQ
   ============================ */
.faq-list{max-width:640px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-q{width:100%;padding:22px 0;display:flex;align-items:center;justify-content:space-between;background:none;border:none;color:var(--text);font-family:var(--font);font-size:.88rem;font-weight:400;cursor:pointer;text-align:left;gap:16px;transition:color .3s}
.faq-q:hover{color:#fff}
.faq-icon{flex-shrink:0;color:var(--dim);transition:all .4s var(--ease)}
.faq-item.open .faq-icon{transform:rotate(45deg);color:var(--accent)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease),padding .4s var(--ease)}
.faq-item.open .faq-a{max-height:220px;padding:0 0 20px}
.faq-a p{color:var(--muted);font-size:.84rem;line-height:1.8;font-weight:300}

/* ============================
   CTA
   ============================ */
.cta-section{padding:clamp(80px,14vh,160px) 0;position:relative;overflow:hidden;background:var(--bg2)}
.cta-section::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(139,156,247,.06),transparent 60%);pointer-events:none}
.cta-inner{text-align:center;position:relative}
.cta-inner h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:200;margin-bottom:14px;letter-spacing:-.02em;line-height:1.3}
.cta-inner p{color:var(--muted);font-size:.95rem;margin-bottom:36px;font-weight:300}

/* ============================
   CONTACT
   ============================ */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(40px,6vw,80px);align-items:start}
.contact-info{display:flex;flex-direction:column;gap:4px}
.contact-item{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--border);transition:all .3s var(--ease);color:inherit;text-decoration:none}
.contact-item:first-child{border-top:1px solid var(--border)}
.contact-item:hover{padding-left:8px}
.contact-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:50%;flex-shrink:0;color:var(--muted);transition:all .3s}
.contact-item:hover .contact-icon{border-color:var(--accent);color:var(--accent);background:rgba(139,156,247,.05)}
.contact-item strong{display:block;font-size:.88rem;font-weight:500;margin-bottom:1px}
.contact-item span{color:var(--muted);font-size:.72rem;letter-spacing:.04em}

/* Form with floating labels */
.contact-form{display:flex;flex-direction:column;gap:0}
.form-group{position:relative;margin-bottom:0}
.form-group input,.form-group textarea{width:100%;padding:22px 0 10px;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:.88rem;outline:none;transition:border-color .3s;font-weight:300}
.form-group label{position:absolute;left:0;top:18px;font-size:.84rem;color:var(--dim);pointer-events:none;transition:all .3s var(--ease);font-weight:300}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group input:focus ~ label,.form-group input:not(:placeholder-shown) ~ label,
.form-group textarea:focus ~ label,.form-group textarea:not(:placeholder-shown) ~ label{top:2px;font-size:.62rem;color:var(--accent);letter-spacing:.08em;text-transform:uppercase}
.form-group input::placeholder,.form-group textarea::placeholder{color:transparent}
.form-group textarea{resize:vertical;min-height:60px}
.contact-form .btn{margin-top:24px}

.selected-plan{display:flex;align-items:center;gap:10px;padding:14px 16px;background:rgba(139,156,247,.04);border:1px solid rgba(139,156,247,.12);margin-bottom:16px;animation:msgIn .3s forwards}
.plan-badge-text{flex:1;font-size:.8rem;color:var(--text);letter-spacing:.04em}
.plan-badge-close{background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s}
.plan-badge-close:hover{color:#fff}

.contact-form .btn.success{background:#10b981;color:#fff}
.contact-form .btn.success::before{display:none}
.contact-form .btn.error{background:#ef4444;color:#fff}
.contact-form .btn.error::before{display:none}

/* ============================
   FOOTER
   ============================ */
.footer{padding:32px 0;border-top:1px solid var(--border)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer-links{display:flex;gap:24px}
.footer-links a{font-size:.7rem;color:var(--dim);letter-spacing:.08em;text-transform:uppercase;transition:color .3s}
.footer-links a:hover{color:var(--text)}
.footer-social{display:flex;gap:6px}
.social-link{width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:var(--muted);border:1px solid var(--border);border-radius:50%;transition:all .3s var(--ease)}
.social-link:hover{background:#fff;color:#000;border-color:#fff;transform:translateY(-2px)}
.footer-copy{color:var(--dim);font-size:.7rem;letter-spacing:.04em}

/* ============================
   3D TILT EFFECT
   ============================ */
.tilt-card{transform-style:preserve-3d;perspective:800px;transition:transform .4s var(--ease)}
.tilt-card .tilt-glare{position:absolute;inset:0;opacity:0;transition:opacity .4s;pointer-events:none;background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),rgba(139,156,247,.06),transparent 40%)}
.tilt-card:hover .tilt-glare{opacity:1}

/* ============================
   RESPONSIVE
   ============================ */

@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-sub{margin:0 auto clamp(20px,3vh,32px)}
  .hero-actions{justify-content:center}
  .hero-visual{margin-top:clamp(8px,2vh,24px)}
  .voice-orb{width:clamp(160px,20vw,220px);height:clamp(160px,20vw,220px)}
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento-wide{grid-column:span 2}
  .cases-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav-links.active{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(6,6,8,.97);padding:100px 32px 32px;gap:20px;z-index:105;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);animation:menuIn .4s var(--ease-out)}
  .nav-links.active a{font-size:1.1rem;letter-spacing:.06em}
  @keyframes menuIn{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}

  .hero-inner{padding-top:clamp(64px,9vh,90px)}
  .hero h1,.hero-title{font-size:clamp(1.6rem,7vw,2.2rem)}
  .hero-sub{font-size:.86rem}
  .hero-actions{gap:10px}
  .hero-actions .btn-lg{padding:14px 28px;font-size:.75rem}
  .voice-orb{width:clamp(130px,35vw,180px);height:clamp(130px,35vw,180px)}

  .steps,.bento,.pricing-grid,.cases-grid,.testi-grid{grid-template-columns:1fr}
  .bento-wide{grid-column:span 1}
  .bento-wide{grid-template-columns:1fr}
  .stats-grid{flex-wrap:wrap;gap:14px}
  .stat-sep{display:none}
  .contact-grid{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;text-align:center}
  .footer-links{flex-wrap:wrap;justify-content:center}
  .compare-cell{padding:12px 10px;font-size:.76rem}
  .compare-row{grid-template-columns:1.2fr 1fr 1fr}
  .section{padding:clamp(60px,10vh,100px) 0}
  .demo-phone{max-width:100%;border-radius:28px}
  .phone-call{padding:20px 16px 18px;min-height:500px}
  .call-orb{width:120px;height:120px}
  .co-core{width:54px;height:54px}
  .call-transcript{max-height:110px}
  .demo-tabs{font-size:.66rem}
  .cursor-dot,.cursor-ring{display:none!important}
}

@media(max-width:380px){
  .hero-title{font-size:1.5rem}
  .hero-sub{font-size:.82rem}
  .btn-lg{padding:12px 20px;font-size:.72rem}
  .stat-val{font-size:1.1rem}
}

@media(max-height:700px){
  .hero-inner{padding-top:60px}
  .hero-sub{margin-bottom:12px}
  .hero-visual{margin-top:4px}
  .voice-orb{width:140px;height:140px}
  .stats-strip{padding:10px 0}
}

/* ============================
   REDUCED MOTION
   ============================ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
  .intro{display:none!important}
  .site{opacity:1!important}
  .hero-canvas,.intro-particles,.orb-particles,.cursor-dot,.cursor-ring,
  .marquee-track,.scroll-progress,body::after{display:none!important}
  .reveal-text,[data-scroll]{opacity:1!important;transform:none!important}
  .title-word{transform:none!important}
  .hero-sub,.hero-actions,.hero-visual{opacity:1!important;transform:none!important}
}
