/* E Mic — marketing site styles */
:root{
  --bg:#FAF9F5;
  --bg-2:#F3EDE2;
  --surface:#FFFFFF;
  --surface-2:#F6F1E9;
  --surface-3:#EFE8DC;
  --border:#E7DFD2;
  --border-strong:#D8CDB9;
  --text:#2B2620;
  --text-muted:#6E6457;
  --text-faint:#9C9285;
  --primary:#D97757;
  --primary-strong:#C2603E;
  --primary-soft:#FAEDE6;
  --primary-border:#EBC3B2;
  --success:#5B8A72;
  --success-soft:#E9F0EA;
  --success-border:#BFD6C7;
  --ink:#2C2722;
  --shadow-sm:0 1px 2px rgba(60,46,30,.05),0 1px 3px rgba(60,46,30,.04);
  --shadow-md:0 4px 16px rgba(60,46,30,.08),0 2px 6px rgba(60,46,30,.05);
  --shadow-lg:0 24px 60px rgba(50,38,24,.14),0 8px 22px rgba(50,38,24,.08);
  --shadow-xl:0 40px 90px rgba(50,38,24,.20),0 12px 30px rgba(50,38,24,.10);
  --sans:'Hanken Grotesk',system-ui,sans-serif;
  --serif:'Newsreader',Georgia,serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --maxw:1160px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--sans);color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(1100px 720px at 50% -22%, #F4EEE1 0%, transparent 64%);
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:var(--primary-soft);}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;border-radius:11px;font-size:14.5px;font-weight:600;padding:12px 20px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);transition:transform .12s,filter .15s,background .15s,box-shadow .15s,border-color .15s;white-space:nowrap;cursor:pointer;font-family:inherit;}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn:active{transform:translateY(0);}
.btn.primary{background:linear-gradient(180deg,var(--primary),var(--primary-strong));border-color:var(--primary-strong);color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.25) inset,var(--shadow-sm);}
.btn.primary:hover{filter:brightness(1.05);box-shadow:0 1px 0 rgba(255,255,255,.25) inset,var(--shadow-md);}
.btn.ghost{background:transparent;border-color:transparent;color:var(--text-muted);}
.btn.ghost:hover{background:rgba(0,0,0,.05);color:var(--text);box-shadow:none;}
.btn.big{padding:15px 26px;font-size:16px;border-radius:13px;}
.btn .win-ico{width:16px;height:16px;}

.kbd{font-family:var(--mono);font-size:.84em;background:var(--surface-3);border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:5px;padding:1px 6px;color:var(--text-muted);white-space:nowrap;}

/* wave mark — E (English) + Mic */
.brandmark{display:inline-flex;align-items:center;gap:2.5px;height:22px;vertical-align:middle;flex:0 0 auto;}
.brandmark span{width:3.5px;border-radius:3px;background:var(--primary);display:block;transform-origin:center;}
.brandmark span:nth-child(1){height:7px;}
.brandmark span:nth-child(2){height:16px;}
.brandmark span:nth-child(3){height:11px;}
.brandmark span:nth-child(4){height:20px;}
.brandmark span:nth-child(5){height:8px;}
.foot-logo .brandmark{height:18px;}
.foot-logo .brandmark span{width:3px;}
@media (prefers-reduced-motion:no-preference){
  .brandmark.animate span{animation:eq 1.5s ease-in-out infinite;}
  .brandmark.animate span:nth-child(1){animation-delay:0s;}
  .brandmark.animate span:nth-child(2){animation-delay:.15s;}
  .brandmark.animate span:nth-child(3){animation-delay:.3s;}
  .brandmark.animate span:nth-child(4){animation-delay:.45s;}
  .brandmark.animate span:nth-child(5){animation-delay:.6s;}
}
@keyframes eq{0%,100%{transform:scaleY(.45);}50%{transform:scaleY(1);}}

/* nav */
.nav{position:sticky;top:0;z-index:50;transition:background .25s,box-shadow .25s,border-color .25s;border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(250,249,245,.82);backdrop-filter:saturate(1.4) blur(14px);-webkit-backdrop-filter:saturate(1.4) blur(14px);border-bottom-color:var(--border);}
.nav-in{display:flex;align-items:center;gap:14px;height:68px;}
.logo{display:flex;align-items:center;gap:11px;font-weight:700;font-size:18px;letter-spacing:-.01em;white-space:nowrap;}
.logo .sub{font-weight:500;font-size:13px;color:var(--text-faint);letter-spacing:0;}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:18px;}
.nav-links a{padding:9px 14px;border-radius:9px;font-size:14.5px;font-weight:500;color:var(--text-muted);transition:background .14s,color .14s;white-space:nowrap;}
.nav-links a:hover{background:rgba(0,0,0,.05);color:var(--text);}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:10px;}

/* hero */
.hero{padding:54px 0 48px;position:relative;overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(0,1.08fr);gap:44px;align-items:center;}
.hero-copy{text-align:left;}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);margin-bottom:22px;}
.eyebrow .pin{width:6px;height:6px;border-radius:50%;background:var(--primary);}
h1.hero-title{font-family:var(--serif);font-weight:500;font-size:clamp(40px,4.8vw,64px);line-height:1.04;letter-spacing:-.02em;margin:0 0 22px;max-width:14ch;perspective:900px;}
h1.hero-title em{font-style:italic;color:var(--primary-strong);}
/* 3D scroll-driven headline */
.flip3d{position:relative;display:block;transform-style:preserve-3d;min-height:2.08em;}
.flip3d .face{display:block;backface-visibility:hidden;transform-origin:center top;will-change:transform,opacity;}
.flip3d .face.back{position:absolute;left:0;top:0;right:0;}
.hero-sub{font-size:clamp(16px,1.4vw,19px);line-height:1.55;color:var(--text-muted);max-width:46ch;margin:0 0 28px;}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;}
.hero-trust{margin-top:20px;font-size:13px;color:var(--text-faint);display:flex;gap:16px;flex-wrap:wrap;}
.hero-trust span{display:inline-flex;align-items:center;gap:7px;}
.hero-trust svg{color:var(--success);width:15px;height:15px;}

/* hero 3D visual deck */
.hero-visual{position:relative;perspective:1700px;min-height:600px;}
.hero-deck{position:relative;height:100%;transform-style:preserve-3d;transform:rotateY(-12deg) rotateX(6deg);will-change:transform;}
.hero-visual .appcol{position:absolute;width:322px;max-width:84%;transform-style:preserve-3d;}
.hero-visual .appcol:nth-child(1){top:0;left:0;z-index:2;}
.hero-visual .appcol:nth-child(2){top:158px;left:120px;z-index:3;transform:translateZ(55px);}
.hero-visual .appcap{display:none;}
.hero-visual .appwin{min-height:0;box-shadow:0 30px 60px rgba(50,38,24,.20),0 12px 26px rgba(50,38,24,.12);}
.hero-visual .chat-body{min-height:0;}
@media (prefers-reduced-motion:no-preference){
  .hero-visual .appwin{animation:floaty 6.5s ease-in-out infinite;}
  .hero-visual .appcol:nth-child(2) .appwin{animation-delay:-3.2s;}
}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}

/* reveal motion — visible state is the floor; only the slide animates */
.reveal{opacity:0;}
.reveal.in{opacity:1;}
@media (prefers-reduced-motion:no-preference){
  .reveal.in{animation:revUp .72s cubic-bezier(.2,.7,.3,1) both;}
  .reveal.in.d1{animation-delay:.08s;} .reveal.in.d2{animation-delay:.16s;}
  .reveal.in.d3{animation-delay:.24s;} .reveal.in.d4{animation-delay:.32s;} .reveal.in.d5{animation-delay:.4s;}
}
@keyframes revUp{from{transform:translateY(22px);}to{transform:none;}}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;}}

/* ---------- demo stage ---------- */
.demo-stage{margin:50px auto 0;max-width:860px;position:relative;}
.demo-window{
  background:var(--surface);border:1px solid var(--border);border-radius:20px;
  box-shadow:var(--shadow-xl);overflow:hidden;text-align:left;position:relative;
}
.demo-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface-2);border-bottom:1px solid var(--border);}
.demo-bar .dtitle{font-size:12.5px;color:var(--text-muted);font-weight:600;display:flex;align-items:center;gap:8px;}
.win-ctrls{margin-left:auto;display:flex;align-items:center;gap:16px;color:var(--text-faint);}
.win-ctrls svg{width:12px;height:12px;display:block;}
.demo-app{display:flex;min-height:340px;}
.demo-side{width:172px;flex:0 0 172px;background:var(--bg-2);border-right:1px solid var(--border);padding:16px 12px;}
.demo-talk{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:11px;border-radius:11px;border:1px solid var(--primary-strong);background:linear-gradient(180deg,var(--primary),var(--primary-strong));color:#fff;font-weight:600;font-size:13.5px;box-shadow:0 1px 0 rgba(255,255,255,.22) inset,var(--shadow-sm);transition:box-shadow .2s,filter .2s;}
.demo-talk.live{box-shadow:0 0 0 4px var(--primary-soft);filter:brightness(.98);}
.demo-talk .md{width:8px;height:8px;border-radius:50%;background:#fff;}
.demo-nav{margin-top:16px;display:flex;flex-direction:column;gap:3px;}
.demo-nav .ni{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-muted);}
.demo-nav .ni.on{background:var(--surface);color:var(--text);font-weight:600;box-shadow:var(--shadow-sm);border:1px solid var(--border);}
.demo-nav .ni .nd{width:13px;height:13px;border-radius:3px;background:currentColor;opacity:.5;}
.demo-nav .ni.on .nd{background:var(--primary);opacity:1;}
.demo-main{flex:1;padding:22px 24px;min-width:0;position:relative;}
.demo-greet{font-family:var(--serif);font-size:24px;font-weight:500;letter-spacing:-.01em;margin:0 0 3px;}
.demo-greet em{font-style:italic;color:var(--primary-strong);}
.demo-hint{font-size:13px;color:var(--text-faint);margin:0 0 16px;}
.demo-note{background:var(--surface-2);border:1px solid var(--border);border-radius:13px;min-height:150px;padding:16px 18px;position:relative;}
.demo-note .nlabel{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:7px;}
.demo-text{font-size:16.5px;line-height:1.62;color:var(--text);min-height:54px;}
.demo-text .cursor{display:inline-block;width:2px;height:1.05em;background:var(--primary);margin-left:1px;vertical-align:text-bottom;animation:blink 1s steps(1) infinite;border-radius:2px;}
@keyframes blink{50%{opacity:0;}}
.demo-text .pop{display:inline-block;animation:pop .26s cubic-bezier(.2,.8,.3,1.3) both;}
@keyframes pop{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

/* floating pill on demo */
.demo-pill{
  position:absolute;left:50%;bottom:20px;transform:translateX(-50%) translateY(14px);
  display:flex;align-items:center;gap:13px;background:#fff;border:1.5px solid var(--primary);
  border-radius:999px;padding:10px 18px 10px 15px;box-shadow:var(--shadow-lg);
  min-width:250px;opacity:0;pointer-events:none;transition:transform .3s cubic-bezier(.2,.9,.3,1.2);z-index:5;
}
.demo-pill.show{opacity:1;transform:translateX(-50%) translateY(0);}
.demo-pill .pulse{width:10px;height:10px;border-radius:50%;background:var(--primary);flex:0 0 10px;animation:pulse 1.4s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(217,119,87,.45);}70%{box-shadow:0 0 0 8px rgba(217,119,87,0);}100%{box-shadow:0 0 0 0 rgba(217,119,87,0);}}
.demo-pill .wave{display:flex;align-items:center;gap:3px;height:22px;flex:1;}
.demo-pill .wave i{width:3px;border-radius:3px;background:var(--primary);height:5px;display:block;}
.demo-pill.listening .wave i{animation:wv 1s ease-in-out infinite;}
@keyframes wv{0%,100%{height:5px;}50%{height:20px;}}
.demo-pill .plang{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--primary-strong);background:var(--primary-soft);border:1px solid var(--primary-border);border-radius:6px;padding:3px 7px;}
.demo-pill .pstatus{font-size:13px;color:var(--text-muted);font-weight:500;display:flex;align-items:center;gap:8px;flex:1;}
.demo-pill .pcheck{width:20px;height:20px;border-radius:50%;background:var(--success);color:#fff;display:flex;align-items:center;justify-content:center;flex:0 0 20px;}
.dots span{animation:fade 1.2s infinite both;}.dots span:nth-child(2){animation-delay:.2s;}.dots span:nth-child(3){animation-delay:.4s;}
@keyframes fade{0%,80%,100%{opacity:.25;}40%{opacity:1;}}

.demo-cap{text-align:center;margin-top:18px;font-size:13.5px;color:var(--text-faint);}
.demo-cap b{color:var(--text-muted);font-weight:600;}

/* logos strip */
.strip{padding:46px 0 8px;text-align:center;}
.strip p{font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);font-weight:600;margin:0 0 20px;}
.strip-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.strip-chip{display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:11px 17px;font-size:14px;font-weight:600;color:var(--text-muted);box-shadow:var(--shadow-sm);}
.strip-chip svg{width:17px;height:17px;color:var(--text-faint);}

/* sections */
section{position:relative;}
.sec-pad{padding:84px 0;}
.sec-head{text-align:center;max-width:42ch;margin:0 auto 52px;}
.sec-tag{font-size:12.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--primary-strong);font-weight:700;margin-bottom:14px;}
h2.sec-title{font-family:var(--serif);font-weight:500;font-size:clamp(30px,4vw,46px);line-height:1.08;letter-spacing:-.02em;margin:0 0 14px;}
.sec-title em{font-style:italic;color:var(--primary-strong);}
.sec-lead{font-size:17px;line-height:1.55;color:var(--text-muted);margin:0;}

/* steps */
.steps3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.step{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:28px 26px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s;}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.step .snum{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--primary-strong);background:var(--primary-soft);border:1px solid var(--primary-border);width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.step h3{font-size:19px;font-weight:600;margin:0 0 8px;letter-spacing:-.01em;}
.step p{font-size:14.5px;line-height:1.6;color:var(--text-muted);margin:0;}
.step .skbd{margin-top:16px;display:flex;gap:7px;align-items:center;font-size:13px;color:var(--text-faint);}

/* features */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.feat{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:26px 24px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s,border-color .2s;}
.feat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-strong);}
.feat .ficon{width:46px;height:46px;border-radius:12px;background:var(--primary-soft);color:var(--primary-strong);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.feat.g .ficon{background:var(--success-soft);color:var(--success);}
.feat h3{font-size:17.5px;font-weight:600;margin:0 0 7px;letter-spacing:-.01em;}
.feat p{font-size:14px;line-height:1.6;color:var(--text-muted);margin:0;}

/* stats band */
.band{background:linear-gradient(135deg,var(--ink),#3A332C);color:#F4EFE7;border-radius:26px;padding:54px 40px;text-align:center;position:relative;overflow:hidden;}
.band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 10% 0%,rgba(217,119,87,.18),transparent 60%),radial-gradient(500px 300px at 100% 100%,rgba(91,138,114,.16),transparent 55%);}
.band-in{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.bstat .bval{font-family:var(--serif);font-size:clamp(40px,5.5vw,62px);font-weight:500;line-height:1;letter-spacing:-.02em;}
.bstat .bval small{font-size:.5em;color:#E0A888;font-family:var(--sans);font-weight:600;margin-left:4px;}
.bstat .blab{font-size:14px;color:#C9BFB0;margin-top:12px;}
.band-divider{position:absolute;top:14%;bottom:14%;width:1px;background:rgba(255,255,255,.12);}

/* pricing */
.price-wrap{display:flex;justify-content:center;}
.price-card{max-width:480px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden;position:relative;}
.price-top{padding:32px 34px 28px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#fff,var(--surface-2));position:relative;}
.price-badge{position:absolute;top:22px;right:26px;font-size:11.5px;font-weight:700;letter-spacing:.05em;color:var(--success);background:var(--success-soft);border:1px solid var(--success-border);border-radius:30px;padding:5px 12px;}
.price-name{font-size:15px;font-weight:600;color:var(--text-muted);}
.price-amt{font-family:var(--serif);font-size:62px;font-weight:500;line-height:1;letter-spacing:-.02em;margin-top:10px;}
.price-amt .cur{font-size:24px;color:var(--text-muted);font-weight:600;font-family:var(--sans);margin-left:6px;}
.price-once{font-size:14px;color:var(--text-faint);margin-top:10px;display:flex;align-items:center;gap:8px;}
.price-feat{padding:26px 34px;list-style:none;margin:0;display:flex;flex-direction:column;gap:14px;}
.price-feat li{display:flex;align-items:center;gap:12px;font-size:15px;color:var(--text);}
.price-feat .tick{width:22px;height:22px;border-radius:50%;background:var(--success-soft);color:var(--success);display:flex;align-items:center;justify-content:center;flex:0 0 22px;}
.price-foot{padding:0 34px 32px;}
.price-foot .btn{width:100%;justify-content:center;}
.price-fib{margin-top:16px;display:flex;align-items:center;gap:13px;background:var(--surface-2);border:1px solid var(--border);border-radius:13px;padding:14px 16px;}
.price-fib .flogo{width:42px;height:42px;border-radius:10px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:6px;flex:0 0 42px;}
.price-fib .ft b{font-size:14px;font-weight:600;display:block;}
.price-fib .ft span{font-size:12.5px;color:var(--text-faint);}

/* CTA final */
.cta-final{text-align:center;}
.cta-final h2{font-family:var(--serif);font-weight:500;font-size:clamp(32px,4.5vw,52px);line-height:1.14;letter-spacing:-.02em;margin:0 auto 18px;max-width:18ch;}
.cta-final h2 em{font-style:italic;color:var(--primary-strong);}
.cta-final p{font-size:17px;color:var(--text-muted);margin:0 auto 28px;max-width:46ch;}

/* footer */
footer{border-top:1px solid var(--border);margin-top:30px;padding:40px 0 50px;}
.foot-in{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.foot-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:16px;}
.foot-links{display:flex;gap:8px;flex-wrap:wrap;}
.foot-links a{font-size:13.5px;color:var(--text-muted);padding:6px 10px;border-radius:8px;}
.foot-links a:hover{background:rgba(0,0,0,.05);color:var(--text);}
.foot-copy{margin-left:auto;font-size:13px;color:var(--text-faint);}

/* ---------- in-app showcase ---------- */
.apps{display:grid;grid-template-columns:1fr 1fr;gap:26px;}
.appcol{display:flex;flex-direction:column;}
.appcap{display:flex;align-items:center;gap:10px;margin:0 2px 14px;}
.appcap .alogo{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex:0 0 30px;color:#fff;}
.appcap .alogo.wa{background:#1FA855;}
.appcap .alogo.ol{background:#0F6CBD;}
.appcap b{font-size:15px;font-weight:600;display:block;line-height:1.2;}
.appcap span{font-size:12.5px;color:var(--text-faint);}

.appwin{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;position:relative;display:flex;flex-direction:column;min-height:392px;}
.appbar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface-2);border-bottom:1px solid var(--border);}
.appbar .appname{font-size:12px;color:var(--text-muted);font-weight:600;white-space:nowrap;flex:0 0 auto;}
.appbar .win-ctrls{margin-left:auto;display:flex;gap:14px;color:var(--text-faint);}
.appbar .win-ctrls svg{width:11px;height:11px;display:block;}

/* chat */
.chat-head{display:flex;align-items:center;gap:11px;padding:12px 16px;background:#075E54;color:#fff;}
.chat-head .cav{width:36px;height:36px;border-radius:50%;background:#ffffff2e;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex:0 0 36px;}
.chat-head b{font-size:14px;font-weight:600;display:block;line-height:1.2;}
.chat-head span{font-size:11.5px;opacity:.8;}
.chat-body{flex:1;padding:16px;display:flex;flex-direction:column;gap:9px;background:#EDE4D8;background-image:radial-gradient(circle at 12px 12px,rgba(0,0,0,.018) 1.5px,transparent 0);background-size:24px 24px;}
.bub{max-width:78%;padding:8px 12px;border-radius:12px;font-size:13.5px;line-height:1.45;box-shadow:0 1px 1px rgba(0,0,0,.05);}
.bub.in{background:#fff;align-self:flex-start;border-top-left-radius:3px;color:#2B2620;}
.bub.out{background:#DCF8C6;align-self:flex-end;border-top-right-radius:3px;color:#243027;}
.bub .bt{font-size:10px;color:#8a9; display:block;text-align:right;margin-top:2px;}
.chat-input{display:flex;align-items:center;gap:9px;padding:10px 12px;background:#F4EFE9;border-top:1px solid var(--border);}
.chat-input .cfield{flex:1;background:#fff;border:1px solid var(--border-strong);border-radius:20px;padding:9px 14px;font-size:13.5px;color:var(--text);min-height:38px;display:flex;align-items:center;}
.chat-input .cmic{width:38px;height:38px;border-radius:50%;background:#1FA855;color:#fff;display:flex;align-items:center;justify-content:center;flex:0 0 38px;box-shadow:0 0 0 4px rgba(31,168,85,.16);}
.chat-input .cmic svg{width:17px;height:17px;}

/* email */
.mail-head{padding:14px 18px 10px;border-bottom:1px solid var(--border);}
.mail-head .mrow{display:flex;gap:12px;font-size:13.5px;padding:6px 0;border-bottom:1px solid #F0EBE2;color:var(--text);}
.mail-head .mrow:last-child{border-bottom:none;}
.mail-head .ml{color:var(--text-faint);width:54px;flex:0 0 54px;font-size:12.5px;padding-top:1px;}
.mail-body{flex:1;padding:16px 18px;font-size:14px;line-height:1.62;color:var(--text);}
.mail-foot{display:flex;align-items:center;gap:12px;padding:11px 16px;border-top:1px solid var(--border);background:var(--surface-2);}
.mail-foot .send{background:#0F6CBD;color:#fff;border:none;border-radius:7px;padding:8px 20px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:7px;font-family:inherit;}
.mail-foot .mtool{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--text-faint);}
.mail-foot .mtool svg{width:16px;height:16px;}

.caret{display:inline-block;width:2px;height:1.05em;background:var(--primary);margin-left:1px;vertical-align:text-bottom;border-radius:2px;animation:blink 1s steps(1) infinite;}
.dictated{color:var(--text);}

/* overlay pill (over the app) */
.ovl{position:absolute;left:50%;bottom:62px;transform:translateX(-50%);display:flex;align-items:center;gap:12px;background:#fff;border:1.5px solid var(--primary);border-radius:999px;padding:9px 16px 9px 13px;box-shadow:0 16px 36px rgba(50,30,20,.26);z-index:6;white-space:nowrap;}
.ovl .opulse{width:9px;height:9px;border-radius:50%;background:var(--primary);flex:0 0 9px;animation:pulse 1.4s infinite;}
.ovl .owave{display:flex;align-items:center;gap:2.5px;height:20px;}
.ovl .owave i{width:2.5px;border-radius:3px;background:var(--primary);height:5px;display:block;}
@media (prefers-reduced-motion:no-preference){.ovl .owave i{animation:wv 1s ease-in-out infinite;}}
.ovl .olang{font-family:var(--mono);font-size:9.5px;font-weight:600;color:var(--primary-strong);background:var(--primary-soft);border:1px solid var(--primary-border);border-radius:5px;padding:2px 6px;}
.ovl .otext{font-size:12.5px;color:var(--text-muted);font-weight:500;}

@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:30px;}
  .hero-copy{text-align:center;}
  .hero-copy .hero-title{margin-left:auto;margin-right:auto;}
  .hero-copy .hero-sub{margin-left:auto;margin-right:auto;}
  .hero-cta,.hero-trust{justify-content:center;}
  .hero-visual{perspective:none;min-height:0;display:flex;flex-direction:column;gap:22px;align-items:center;}
  .hero-deck{transform:none;display:flex;flex-direction:column;gap:22px;width:100%;max-width:380px;margin:0 auto;}
  .hero-visual .appcol{position:static;width:100%;max-width:100%;transform:none !important;}
}
@media (max-width:860px){
  .apps{grid-template-columns:1fr;}
}

/* ---------- scroll-driven app switcher ---------- */
.appswap{position:relative;background:linear-gradient(180deg,transparent,var(--surface-2) 30%,var(--surface-2) 70%,transparent);}
.appswap-track{position:relative;height:380vh;}
.appswap-stage{position:sticky;top:0;height:100vh;min-height:600px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;}
.appswap-head{text-align:center;max-width:40ch;}
.appswap-head .sec-tag{margin-bottom:10px;}
.appswap-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(26px,3.4vw,40px);line-height:1.08;letter-spacing:-.02em;margin:0;}
.appswap-head h2 em{font-style:italic;color:var(--primary-strong);}
.appswap-frame{position:relative;width:430px;max-width:90vw;height:432px;perspective:1400px;}
.appswap-card{position:absolute;inset:0;opacity:0;transform:translateX(60px) scale(.96);transition:opacity .55s cubic-bezier(.2,.7,.3,1),transform .55s cubic-bezier(.2,.7,.3,1);pointer-events:none;}
.appswap-card.on{opacity:1;transform:none;}
.appswap-card.prev{transform:translateX(-60px) scale(.96);}
.appswap-card .appwin{height:100%;min-height:0;display:flex;flex-direction:column;box-shadow:0 30px 64px rgba(50,38,24,.18),0 12px 26px rgba(50,38,24,.10);}
.appswap-dots{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.appswap-dot{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:30px;font-size:13px;font-weight:600;color:var(--text-faint);background:var(--surface);border:1px solid var(--border);transition:color .3s,background .3s,border-color .3s;}
.appswap-dot svg{width:15px;height:15px;}
.appswap-dot.on{color:#fff;background:var(--primary);border-color:var(--primary-strong);box-shadow:var(--shadow-sm);}

/* word mock */
.doc-ribbon{display:flex;align-items:center;gap:7px;padding:9px 14px;background:#F3F1EC;border-bottom:1px solid var(--border);}
.doc-ribbon i{width:22px;height:6px;border-radius:3px;background:var(--border-strong);display:block;}
.doc-ribbon i:nth-child(2){width:14px;} .doc-ribbon i:nth-child(3){width:30px;}
.doc-page{flex:1;background:#fff;margin:14px;border:1px solid var(--border);border-radius:6px;padding:20px 22px;box-shadow:var(--shadow-sm);}
.doc-page h4{font-family:var(--serif);font-size:18px;font-weight:600;margin:0 0 10px;}
.doc-page p{font-size:13.5px;line-height:1.7;color:var(--text);margin:0;}

/* browser mock */
.br-bar{display:flex;align-items:center;gap:9px;padding:10px 14px;background:#EDEAE3;border-bottom:1px solid var(--border);}
.br-bar .brdot{width:11px;height:11px;border-radius:50%;background:var(--border-strong);}
.br-url{flex:1;background:#fff;border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:7px;}
.br-body{flex:1;padding:22px;display:flex;flex-direction:column;}
.br-search{border:1px solid var(--border-strong);border-radius:24px;padding:13px 18px;font-size:14px;color:var(--text);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:10px;min-height:50px;}
.br-search svg{color:var(--text-faint);flex:0 0 18px;}
.br-note{margin-top:14px;font-size:12px;color:var(--text-faint);}

/* ---------- AI cleanup flow (left → right) ---------- */
.ai-flow{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:stretch;position:relative;}
.ai-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;}
.ai-card .ai-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--text-faint);display:flex;align-items:center;gap:8px;}
.ai-card.raw{border-style:dashed;}
.ai-card.raw .ai-label{color:var(--text-faint);}
.ai-card.raw p{font-size:16px;line-height:1.6;color:var(--text-faint);margin:0;font-style:italic;}
.ai-card.raw .fill{color:var(--danger);opacity:.7;text-decoration:line-through;text-decoration-color:rgba(188,82,71,.5);}
.ai-card.clean{border-color:var(--primary-border);background:linear-gradient(160deg,#fff,var(--primary-soft));}
.ai-card.clean .ai-label{color:var(--primary-strong);}
.ai-card.clean p{font-size:16px;line-height:1.6;color:var(--text);margin:0;font-weight:500;}
.ai-card.clean .punct{color:var(--primary-strong);font-weight:700;}
.ai-core{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-width:96px;}
.ai-chip{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-strong));border-radius:30px;padding:8px 14px;box-shadow:var(--shadow-sm);white-space:nowrap;}
.ai-chip svg{width:15px;height:15px;}
.ai-track{position:relative;width:90px;height:3px;border-radius:3px;background:var(--border-strong);overflow:hidden;}
.ai-track::after{content:"";position:absolute;top:0;left:0;height:100%;width:40%;border-radius:3px;background:linear-gradient(90deg,transparent,var(--primary),transparent);}
@media (prefers-reduced-motion:no-preference){.ai-track::after{animation:flowLR 1.5s linear infinite;}}
@keyframes flowLR{0%{transform:translateX(-100%);}100%{transform:translateX(260%);}}
.ai-comet{position:absolute;top:50%;left:0;width:9px;height:9px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px var(--primary-soft);transform:transl(-50%,-50%);}

@media (max-width:760px){
  .ai-flow{grid-template-columns:1fr;}
  .ai-core{flex-direction:row;min-width:0;padding:4px 0;}
  .ai-track{width:3px;height:46px;}
  @media (prefers-reduced-motion:no-preference){.ai-track::after{animation:flowTB 1.5s linear infinite;width:100%;height:40%;background:linear-gradient(180deg,transparent,var(--primary),transparent);}}
}
@keyframes flowTB{0%{transform:translateY(-100%);}100%{transform:translateY(260%);}}
@media (max-width:560px){
  .wrap{padding:0 18px;}
  .hero{padding:40px 0 20px;}
  .sec-pad{padding:60px 0;}
  .hero-cta .btn{flex:1;justify-content:center;}
}
