/* ===== Tulip landing — shared base (dark, premium) ===== */
:root{
  --v1:#7c66ff; --v2:#c06bff; --violet:#8b7bff; --violet-2:#b98bff;
  --grad:linear-gradient(115deg,var(--v1) 10%,var(--v2) 90%);
  --bg:#07060d; --bg-2:#0d0b18; --panel:#100e1c;
  --txt:#f5f4fa; --muted:#9b98b3; --faint:#6a6782;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.13);
  --glow:rgba(124,102,255,.55);
  --disp:"Space Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;
  --serif:"Instrument Serif",Georgia,serif;
  --ui:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ui);background:var(--bg);color:var(--txt);line-height:1.55;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
.wrap{max-width:1160px;margin:0 auto;padding:0 26px}

.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
#app{position:relative;z-index:3}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--ui);font-size:15px;font-weight:600;
  padding:13px 22px;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .2s cubic-bezier(.2,.7,.2,1),box-shadow .25s,background .2s,border-color .2s;white-space:nowrap}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 0 0 1px rgba(255,255,255,.12) inset,0 12px 34px -10px var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(255,255,255,.2) inset,0 18px 44px -10px var(--glow)}
.btn-ghost{background:rgba(255,255,255,.04);border-color:var(--line-2);color:var(--txt)}
.btn-ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn .was{opacity:.65;text-decoration:line-through;font-weight:500}

/* nav */
header{position:sticky;top:0;z-index:60;backdrop-filter:blur(18px) saturate(150%);
  background:rgba(7,6,13,.6);border-bottom:1px solid transparent;transition:border-color .25s,background .25s}
header.scrolled{border-color:var(--line);background:rgba(7,6,13,.82)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:13px;font-family:var(--disp);font-weight:700;font-size:24px;letter-spacing:-.01em}
.brand .mk{width:46px;height:46px;border-radius:12px;background:var(--grad);display:grid;place-items:center;
  box-shadow:0 6px 18px -4px var(--glow),0 0 0 1px rgba(255,255,255,.12) inset}
.brand .mk svg{width:40px;height:40px}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links .link{font-size:14.5px;color:var(--muted);font-weight:500;transition:color .18s}
.nav-links .link:hover{color:var(--txt)}
@media(max-width:760px){.nav-links .link{display:none}}

/* hero (shared bones; variants restyle bg + accents) */
.hero{padding:96px 0 30px;text-align:center;position:relative}
.badge{display:inline-flex;align-items:center;gap:9px;font-size:12px;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--violet-2);background:rgba(124,102,255,.08);
  border:1px solid rgba(124,102,255,.2);padding:7px 15px;border-radius:999px;margin-bottom:30px}
.badge .d{width:7px;height:7px;border-radius:50%;background:#34c759;box-shadow:0 0 10px #34c759}
h1{font-family:var(--disp);font-weight:700;font-size:clamp(46px,8.4vw,92px);line-height:.98;letter-spacing:-.04em}
h1 .word{display:inline-block}
h1 em{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:-.01em;
  background:linear-gradient(115deg,#a58bff,#e0a0ff);-webkit-background-clip:text;background-clip:text;color:transparent;position:relative}
h1 em::after{content:"";position:absolute;inset:-8% -6%;background:radial-gradient(60% 60% at 50% 50%,rgba(180,120,255,.5),transparent 70%);filter:blur(22px);z-index:-1}
.sub{font-size:clamp(17px,2.2vw,20px);color:var(--muted);max-width:600px;margin:26px auto 0;font-weight:400}
.ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:36px}
.dl-note{margin-top:16px;font-size:13px;color:var(--faint);letter-spacing:.01em}
.metas{margin-top:22px;display:flex;gap:20px;justify-content:center;flex-wrap:wrap;font-size:13px;color:var(--faint)}
.metas span{display:inline-flex;align-items:center;gap:7px}
.metas svg{width:15px;height:15px;color:var(--violet)}
.anim h1 .word,.anim h1 em{opacity:0;transform:translateY(24px);filter:blur(6px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.anim h1 .l0{animation-delay:.05s}.anim h1 .l1{animation-delay:.16s}.anim h1 .l2{animation-delay:.27s}
@keyframes rise{to{opacity:1;transform:none;filter:blur(0)}}

/* demo window */
.stage{position:relative;max-width:940px;margin:60px auto 0}
.stage::before{content:"";position:absolute;inset:-6% -4% -12%;z-index:0;
  background:radial-gradient(60% 55% at 50% 40%,rgba(124,102,255,.55),transparent 72%);filter:blur(46px)}
.window{position:relative;z-index:1;background:#fdfdff;border-radius:16px;overflow:hidden;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.08)}
.titlebar{height:44px;display:flex;align-items:center;gap:8px;padding:0 16px;background:#f4f3f9;border-bottom:1px solid #ececf3}
.tl{width:12px;height:12px;border-radius:50%}.tl.r{background:#ff5f57}.tl.y{background:#febc2e}.tl.g{background:#28c840}
.titlebar .tt{margin:0 auto;font-size:12.5px;color:#a3a0b3;font-weight:500;transform:translateX(-24px)}
.scene{position:relative;aspect-ratio:16/9.4;background:radial-gradient(120% 120% at 78% 0%,#fff 0%,#f3f1fb 100%);overflow:hidden;text-align:left}
.doc{position:absolute;inset:0;padding:7% 8%;font-size:clamp(15px,2.5vw,27px);line-height:1.7;color:#26233b;font-weight:500;font-family:var(--ui)}
.doc .to{font-size:.6em;text-transform:uppercase;letter-spacing:.16em;color:#b7b3c9;font-weight:700;margin-bottom:.55em}
.doc .typed{min-height:1.7em}
.caret{display:inline-block;width:2px;height:1.05em;background:var(--v1);vertical-align:-.16em;margin-left:1px;animation:blink 1.05s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.pointer{position:absolute;width:26px;height:26px;left:9%;top:66%;z-index:6;
  transition:left .9s cubic-bezier(.6,.05,.2,1),top .9s cubic-bezier(.6,.05,.2,1);filter:drop-shadow(0 3px 6px rgba(0,0,0,.3))}
.pill{position:absolute;z-index:7;left:9%;top:56%;display:flex;align-items:center;
  height:clamp(28px,4.8vw,44px);padding:0 clamp(10px,1.5vw,15px);border-radius:999px;background:rgba(16,14,30,.94);
  box-shadow:0 12px 34px -6px rgba(20,14,60,.6),0 0 0 1px rgba(255,255,255,.08) inset,0 0 40px -4px var(--glow);
  transform:scale(.2);opacity:0;transform-origin:left center;transition:transform .44s cubic-bezier(.34,1.56,.64,1),opacity .3s}
.pill.show{transform:scale(1);opacity:1}
.pill .wave{display:flex;align-items:center;gap:clamp(2.5px,.5vw,4px);height:58%}
.pill .wave i{width:clamp(2.5px,.5vw,4px);height:34%;border-radius:99px;background:linear-gradient(#fff,#dcd3ff);transform-origin:center}
.pill.listening .wave i{animation:wv .85s ease-in-out infinite}
.pill .wave i:nth-child(1){animation-delay:0s}.pill .wave i:nth-child(2){animation-delay:.1s}
.pill .wave i:nth-child(3){animation-delay:.22s}.pill .wave i:nth-child(4){animation-delay:.34s}.pill .wave i:nth-child(5){animation-delay:.46s}
@keyframes wv{0%,100%{transform:scaleY(.5)}50%{transform:scaleY(2.6)}}
.pill .proc{display:none;width:clamp(10px,1.7vw,14px);height:clamp(10px,1.7vw,14px);border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
.pill.processing .wave{display:none}.pill.processing .proc{display:block}
@keyframes spin{to{transform:rotate(360deg)}}
.fnkey{position:absolute;bottom:6%;left:50%;transform:translateX(-50%) translateY(8px);z-index:6;
  display:flex;align-items:center;gap:9px;font-size:clamp(11px,1.7vw,14px);color:#8a86a0;font-weight:600;
  background:rgba(255,255,255,.9);border:1px solid #ececf3;padding:8px 15px;border-radius:12px;
  box-shadow:0 8px 20px -8px rgba(60,40,140,.3);opacity:0;transition:opacity .3s,transform .3s}
.fnkey.show{opacity:1;transform:translateX(-50%) translateY(0)}
.fnkey kbd{font-family:var(--ui);font-weight:700;color:#26233b;background:#f0edfb;border:1px solid #e3ddf3;border-bottom-width:2px;border-radius:7px;padding:3px 9px;transition:all .12s}
.fnkey.pressed kbd{background:var(--grad);color:#fff;border-color:transparent;transform:translateY(1px);box-shadow:0 0 16px var(--glow)}

/* marquee */
.marquee-sec{padding:70px 0 20px;text-align:center}
.marquee-sec .cap{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);font-weight:600;margin-bottom:30px}
.marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.track{display:flex;gap:14px;width:max-content;animation:scroll 32s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.chip-app{display:inline-flex;align-items:center;gap:10px;padding:12px 22px;border:1px solid var(--line);border-radius:14px;background:var(--bg-2);font-size:16px;font-weight:600;color:#cfcdde;white-space:nowrap}
.chip-app .g{width:8px;height:8px;border-radius:50%;background:var(--violet);opacity:.7}
@keyframes scroll{to{transform:translateX(calc(-50% - 7px))}}

/* section heads */
.sec{padding:104px 0}
.head{text-align:center;max-width:640px;margin:0 auto 60px}
.head .kick{font-size:12.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--violet)}
.head h2{font-family:var(--disp);font-weight:700;font-size:clamp(32px,5vw,52px);letter-spacing:-.035em;line-height:1.04;margin-top:14px}
.head h2 em{font-family:var(--serif);font-style:italic;font-weight:400;background:linear-gradient(115deg,#a58bff,#e0a0ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.head p{color:var(--muted);font-size:17px;margin-top:16px}

/* steps + cards */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.card{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:32px 28px;transition:transform .25s,border-color .25s,box-shadow .25s}
.card:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 30px 60px -30px rgba(124,102,255,.4)}
.step .n{font-family:var(--disp);font-size:14px;font-weight:700;color:#fff;width:38px;height:38px;border-radius:11px;background:var(--grad);display:grid;place-items:center;margin-bottom:20px;box-shadow:0 8px 20px -8px var(--glow)}
.step h3{font-family:var(--disp);font-weight:600;font-size:20px;letter-spacing:-.02em;margin-bottom:9px}
.step p{color:var(--muted);font-size:14.5px}
.kbd{display:inline-block;font-weight:700;background:rgba(124,102,255,.14);border:1px solid rgba(124,102,255,.25);border-radius:6px;padding:1px 8px;color:var(--violet-2);font-size:.9em}

/* features */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid{grid-template-columns:1fr}}
.feat .ic{width:48px;height:48px;border-radius:13px;background:rgba(124,102,255,.12);border:1px solid rgba(124,102,255,.2);display:grid;place-items:center;margin-bottom:18px}
.feat .ic svg{width:24px;height:24px;color:var(--violet-2)}
.feat h3{font-family:var(--disp);font-weight:600;font-size:18px;letter-spacing:-.02em;margin-bottom:8px}
.feat p{color:var(--muted);font-size:14px}

/* privacy band */
.band{position:relative;border-radius:30px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(160deg,#120f22,#1a1330);padding:76px 48px;text-align:center}
.band .bl{position:absolute;width:500px;height:500px;border-radius:50%;filter:blur(90px);opacity:.5}
.band .bl.x{background:#6b4fff;top:-220px;left:-100px}.band .bl.y{background:#b04fff;bottom:-260px;right:-80px}
.band .rel{position:relative;z-index:1}
.band h2{font-family:var(--disp);font-weight:700;font-size:clamp(30px,4.6vw,50px);letter-spacing:-.035em;line-height:1.06}
.band p{color:var(--muted);font-size:17px;max-width:560px;margin:18px auto 0}
.chips{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.chip{background:rgba(255,255,255,.05);border:1px solid var(--line-2);padding:9px 17px;border-radius:999px;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:8px;color:#d9d7e6}
.chip svg{width:15px;height:15px;color:var(--violet-2)}

/* pricing */
.price-wrap{max-width:470px;margin:0 auto;position:relative}
.price-card{position:relative;border-radius:26px;padding:1.5px;background:linear-gradient(140deg,rgba(124,102,255,.7),rgba(192,107,255,.25),rgba(124,102,255,.6));box-shadow:0 40px 90px -40px var(--glow)}
.price-inner{background:#0d0b18;border-radius:24.5px;padding:42px 38px;text-align:center}
.p-badge{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--violet-2);background:rgba(124,102,255,.1);border:1px solid rgba(124,102,255,.22);padding:6px 15px;border-radius:999px;margin-bottom:22px}
.p-num{display:flex;align-items:baseline;justify-content:center;gap:14px;margin:4px 0 6px}
.p-num .was{font-family:var(--disp);font-size:30px;color:var(--faint);text-decoration:line-through;font-weight:600}
.p-num .now{font-family:var(--disp);font-size:66px;font-weight:700;letter-spacing:-.04em;background:linear-gradient(115deg,#b7a3ff,#e0a0ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.p-sub{color:var(--muted);font-size:14.5px}
.p-list{text-align:left;margin:28px auto 30px;display:grid;gap:14px;max-width:310px}
.p-list li{list-style:none;display:flex;align-items:flex-start;gap:12px;font-size:15px;color:#d9d7e6}
.p-list svg{width:20px;height:20px;color:var(--violet-2);flex-shrink:0;margin-top:1px}
.price-card .btn{width:100%;justify-content:center;font-size:16px;padding:15px}
.p-note{font-size:12.5px;color:var(--faint);margin-top:14px}

/* faq */
.faq{max-width:780px;margin:0 auto;display:grid;gap:12px}
details{border:1px solid var(--line);border-radius:15px;background:var(--panel);padding:2px 24px;transition:border-color .2s}
details[open]{border-color:var(--line-2)}
summary{cursor:pointer;list-style:none;padding:20px 0;font-weight:600;font-size:16.5px;display:flex;justify-content:space-between;align-items:center;gap:16px}
summary::-webkit-details-marker{display:none}
summary .plus{width:22px;height:22px;flex-shrink:0;position:relative;transition:transform .25s}
summary .plus::before,summary .plus::after{content:"";position:absolute;background:var(--violet-2);border-radius:2px}
summary .plus::before{left:0;right:0;top:10px;height:2px}summary .plus::after{top:0;bottom:0;left:10px;width:2px}
details[open] summary .plus{transform:rotate(135deg)}
details p{color:var(--muted);font-size:15px;padding:0 0 22px}

/* final + footer */
.final{text-align:center;padding:40px 0 10px}
.final h2{font-family:var(--disp);font-weight:700;font-size:clamp(34px,6vw,68px);letter-spacing:-.04em;line-height:1}
.final h2 em{font-family:var(--serif);font-style:italic;font-weight:400;background:linear-gradient(115deg,#a58bff,#e0a0ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.final p{color:var(--muted);margin:18px auto 30px;max-width:460px;font-size:17px}
footer{border-top:1px solid var(--line);padding:40px 0;margin-top:90px}
.foot{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.foot .brand{font-size:18px}.foot .brand .mk{width:30px;height:30px}.foot .brand .mk svg{width:19px;height:19px}
.foot .fl{display:flex;gap:26px;font-size:14px;color:var(--muted)}.foot .fl a:hover{color:var(--txt)}
.foot .cr{width:100%;text-align:center;font-size:13px;color:var(--faint);margin-top:6px}

.reveal{opacity:0;transform:translateY(30px);filter:blur(4px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1),filter .8s}
.reveal.in{opacity:1;transform:none;filter:blur(0)}

/* variant switcher pill (shown on every variant for easy comparison) */
.switch{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:200;display:flex;gap:4px;
  background:rgba(16,14,30,.8);backdrop-filter:blur(14px);border:1px solid var(--line-2);padding:5px;border-radius:999px;
  box-shadow:0 12px 40px -12px #000}
.switch a{font-size:12.5px;font-weight:600;color:var(--muted);padding:7px 14px;border-radius:999px;transition:all .18s}
.switch a:hover{color:var(--txt)}
.switch a.on{background:var(--grad);color:#fff}

/* ============ VARIANT BACKGROUNDS ============ */
/* base auras used by launch */
.aura{position:fixed;border-radius:50%;filter:blur(120px);z-index:0;pointer-events:none}

/* --- LAUNCH: violet gradient wash + auras --- */
.v-launch .aura.a1{width:640px;height:640px;background:#5b3fff;top:-260px;left:-160px;opacity:.5;animation:drift 20s ease-in-out infinite}
.v-launch .aura.a2{width:520px;height:520px;background:#9d3fff;top:-120px;right:-180px;opacity:.4;animation:drift 26s ease-in-out infinite reverse}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(50px,40px)}}

/* --- SPOTLIGHT: pure black + light rays fanning onto the demo --- */
.v-spotlight{background:#040308}
.v-spotlight .hero{padding-top:82px}
.v-spotlight .rays{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:1200px;height:900px;z-index:0;pointer-events:none;
  background:repeating-conic-gradient(from 90deg at 50% -6%,rgba(170,140,255,.11) 0deg 5deg,transparent 5deg 15deg);
  -webkit-mask:radial-gradient(72% 62% at 50% 0%,#000,transparent 72%);mask:radial-gradient(72% 62% at 50% 0%,#000,transparent 72%);
  animation:rayspin 60s linear infinite;opacity:.75}
@keyframes rayspin{to{transform:translateX(-50%) rotate(360deg)}}
.v-spotlight .hero h1{font-size:clamp(40px,6.6vw,74px)}
.v-spotlight .stage{margin-top:44px}
.v-spotlight .stage::before{background:radial-gradient(58% 55% at 50% 38%,rgba(150,120,255,.7),transparent 70%);filter:blur(56px);inset:-10% -6% -16%}

/* --- AURORA: morphing violet ribbon behind big type --- */
.v-aurora{background:#050409}
.v-aurora .ribbon{position:absolute;top:-8%;left:50%;width:1200px;height:640px;z-index:0;pointer-events:none;filter:blur(64px);opacity:.55;
  background:conic-gradient(from 0deg,#7c66ff,#c06bff,#5b3fff,#a24fff,#7c66ff);
  border-radius:46% 54% 62% 38%/52% 46% 54% 48%;transform:translateX(-50%);mix-blend-mode:screen;animation:ribbon 16s ease-in-out infinite}
.v-aurora .ribbon.r2{width:820px;height:420px;top:6%;opacity:.4;background:conic-gradient(from 180deg,#9d3fff,#6b4fff,#c06bff,#7c66ff);animation-duration:22s;animation-direction:reverse}
@keyframes ribbon{0%,100%{transform:translateX(-50%) rotate(0) scale(1)}50%{transform:translateX(-52%) rotate(18deg) scale(1.12)}}
.v-aurora .hero h1{font-size:clamp(48px,9vw,104px)}
.v-aurora .badge{background:rgba(124,102,255,.14);border-color:rgba(160,120,255,.35)}

/* --- SILK: flowing silk light-waves, minimal --- */
.v-silk{background:#030308}
.v-silk .silk{position:absolute;top:0;left:0;width:100%;height:760px;z-index:0;pointer-events:none;opacity:.5}
.v-silk .silk svg{width:100%;height:100%}
.v-silk .silk path{fill:none;stroke-width:1.5;opacity:.6}
.v-silk .silk .w1{animation:silkdrift 14s ease-in-out infinite}
.v-silk .silk .w2{animation:silkdrift 19s ease-in-out infinite reverse}
.v-silk .silk .w3{animation:silkdrift 24s ease-in-out infinite}
@keyframes silkdrift{0%,100%{transform:translateY(0)}50%{transform:translateY(26px)}}
.v-silk .hero{padding-top:120px;padding-bottom:20px}
.v-silk .hero h1{font-weight:600;letter-spacing:-.045em}
.v-silk .badge{background:transparent;border-color:var(--line-2);color:var(--muted)}
.v-silk .stage::before{opacity:.7}

/* --- CENTERPIECE: front-and-center mock app windows. The mouse cursor stays put,
   the pill materializes at it, and your speech types into the field. --- */
.v-centerpiece{background:#050409}
.v-centerpiece .aura{position:fixed}
.v-centerpiece .aura.a1{width:760px;height:760px;background:#5b3fff;top:-300px;left:50%;transform:translateX(-74%);opacity:.28;filter:blur(140px)}
.v-centerpiece .aura.a2{width:600px;height:600px;background:#a24fff;top:-180px;left:50%;transform:translateX(-6%);opacity:.24;filter:blur(140px)}
.v-centerpiece .hero{padding:56px 0 30px}
.v-centerpiece .sub{margin-top:6px}
.cp-stage{position:relative;width:100%;display:flex;flex-direction:column;align-items:center;gap:20px}

.cp-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.cp-tab{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--muted);
  padding:8px 15px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.02);transition:all .35s}
.cp-tab .dot{width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.65}
.cp-tab.on{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 8px 22px -8px var(--glow)}

.cp-win{position:relative;width:min(730px,93vw);border-radius:15px;overflow:hidden;
  box-shadow:0 44px 100px -34px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.07);transition:background .45s}
.cp-bar{height:44px;display:flex;align-items:center;gap:8px;padding:0 15px;transition:background .45s,color .45s}
.cp-bar .tl{width:12px;height:12px;border-radius:50%}
.cp-bar .r{background:#ff5f57}.cp-bar .y{background:#febc2e}.cp-bar .g{background:#28c840}
.cp-bar .ttl{margin:0 auto;transform:translateX(-24px);font-size:12.5px;font-weight:600}
.cp-body{position:relative;min-height:322px;padding:30px 34px;font-size:clamp(16px,2.05vw,20px);line-height:1.62;transition:color .45s;text-align:left}
.cp-lbl{font-size:.72em;font-weight:700;opacity:.5;margin-bottom:.6em;letter-spacing:.02em}
.cp-row{display:flex;gap:.6em;padding:.4em 0;border-bottom:1px solid rgba(128,128,128,.14)}
.cp-row .k{opacity:.42;min-width:3.6em}
.cp-msg{opacity:.5;font-size:.9em;margin:.2em 0 1.1em;display:flex;gap:.5em;align-items:center}
.cp-msg .av{width:1.3em;height:1.3em;border-radius:6px;background:linear-gradient(135deg,#f0a,#a0f);flex:0 0 auto}
.cp-field{position:relative;margin-top:1.05em;min-height:2.6em}
.cp-input{margin-top:1.1em;border:1px solid rgba(255,255,255,.14);border-radius:11px;padding:.7em .85em}
.cp-input .cp-field{margin:0;min-height:1.6em}
.cp-typed{white-space:pre-wrap}
.cp-tcaret{display:inline-block;width:2px;height:1.05em;background:currentColor;opacity:.8;vertical-align:-.16em;margin-left:1px;animation:blink 1s steps(1) infinite}

/* window themes */
.cp-win.mail{background:#ffffff;color:#211f36}
.cp-win.mail .cp-bar{background:#f4f3f9;color:#9a97ad}
.cp-win.notes{background:#fffdf4;color:#2d2815}
.cp-win.notes .cp-bar{background:#faf4e2;color:#b3a880}
.cp-win.notes .cp-title{font-weight:700;font-size:1.1em;margin-bottom:.35em}
.cp-win.slack{background:#12101d;color:#e9e8f1}
.cp-win.slack .cp-bar{background:#1b1830;color:#9b98b3}
.cp-win.terminal{background:#0b0a12;color:#c7f7d8;font-family:ui-monospace,"SFMono-Regular",Menlo,monospace}
.cp-win.terminal .cp-bar{background:#17161f;color:#8a86a0}
.cp-win.terminal .cp-body{font-size:clamp(14px,1.9vw,18px)}
.cp-win.terminal .prompt{color:#7c9cff}
.cp-win.terminal .cp-field{margin-top:.5em}

/* the (stationary) mouse pointer + pill, hovering where you're dictating */
.cp-mp{position:absolute;left:-4px;top:-30px;display:inline-flex;align-items:center;gap:9px;z-index:6;opacity:0;transition:opacity .35s ease}
.cp-mp.in{opacity:1}
.cp-mp .ptr{width:23px;height:23px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.45));transition:transform .12s}
.cp-mp.press .ptr{animation:ptrpress .34s ease}
@keyframes ptrpress{40%{transform:scale(.82)}100%{transform:scale(1)}}
.cp-mp .ring{position:absolute;left:9px;top:11px;width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle,var(--glow),transparent 66%);opacity:0;transform:translate(-50%,-50%);pointer-events:none}
.cp-mp.press .ring{animation:ripple .6s ease}
@keyframes ripple{0%{opacity:.85;transform:translate(-50%,-50%) scale(.3)}100%{opacity:0;transform:translate(-50%,-50%) scale(3)}}
.cp-pill{display:inline-flex;align-items:center;gap:3px;height:24px;padding:0 9px;border-radius:999px;
  background:rgba(16,14,30,.96);box-shadow:0 8px 22px -4px rgba(20,14,60,.55),0 0 30px -4px var(--glow),0 0 0 1px rgba(255,255,255,.1) inset;
  transform:scale(.1);opacity:0;transform-origin:left center;transition:transform .42s cubic-bezier(.34,1.56,.64,1),opacity .28s}
.cp-pill.show{transform:scale(1);opacity:1}
.cp-pill i{display:inline-block;width:3px;height:8px;border-radius:99px;background:linear-gradient(#fff,#dcd3ff);transform-origin:center}
.cp-pill.listening i{animation:wv .8s ease-in-out infinite}
.cp-pill i:nth-child(1){animation-delay:0s}.cp-pill i:nth-child(2){animation-delay:.12s}.cp-pill i:nth-child(3){animation-delay:.24s}.cp-pill i:nth-child(4){animation-delay:.36s}
.cp-hint{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--faint);font-weight:600;transition:opacity .3s}
.cp-hint kbd{font-family:var(--ui);font-weight:700;color:#d9d7e6;background:rgba(124,102,255,.14);border:1px solid rgba(124,102,255,.3);border-radius:7px;padding:3px 9px;transition:all .12s}
.cp-hint.pressed kbd{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 0 16px var(--glow)}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none;filter:none}.track{animation:none}
}
