/* ============================================================
   #05 AI 음성인식·합성 (STT/TTS·통화 분석) — 라이트 보이스 SaaS 테마
   음성/통화 분석 분야 색감 차용: 딥 틸(teal/cyan)
   시그니처: 파형(waveform) + 화자분리 전사 + 분석 패널 / TTS 스튜디오
   ============================================================ */
:root{
  --brand:#0A9CB0; --brand-2:#077E90; --brand-3:#05606E;
  --tint:#E1F4F7; --tint-2:#C6EBF0;
  --spkA:#0A9CB0; --spkA-t:#E1F4F7;   /* 화자 A (상담사) */
  --spkB:#6D5CF0; --spkB-t:#ECE9FD;   /* 화자 B (고객) */
  --pos:#16A34A; --pos-t:#E7F6ED;     /* 긍정 */
  --neg:#E11D48; --neg-t:#FCE7EC;     /* 부정 */
  --neu:#8A95A1; --neu-t:#EEF1F4;     /* 중립 */
  --warn:#E8920C; --warn-t:#FCF1DD;
  --ink:#10212A; --text:#33454F; --muted:#637480; --faint:#94A4AE;
  --bg:#F2F6F8; --panel:#FFFFFF; --panel-2:#F5F9FB; --panel-3:#EAEFF2;
  --line:#E3EAEE; --line-2:#D5DEE3;
  --radius:14px;
  --shadow-xs:0 1px 2px rgba(16,33,42,.05);
  --shadow-sm:0 1px 3px rgba(16,33,42,.07),0 1px 2px rgba(16,33,42,.04);
  --shadow-md:0 10px 30px -8px rgba(16,33,42,.13);
  --shadow-lg:0 36px 76px -28px rgba(16,33,42,.26);
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --sans:'Pretendard',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--panel);-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden}
.wrap{max-width:1300px;margin:0 auto;padding:0 32px}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-2);display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:14px;height:8px;background:linear-gradient(90deg,var(--brand) 50%,transparent 50%) 0/4px 100% repeat-x;border-radius:1px}

/* ---------- SCREEN INDEX ---------- */
.index{position:sticky;top:0;z-index:80;background:rgba(242,246,248,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.index-inner{display:flex;align-items:center;gap:4px;height:54px;overflow-x:auto;scrollbar-width:none}
.index-inner::-webkit-scrollbar{display:none}
.index a{font-size:13px;color:var(--muted);padding:7px 13px;border-radius:8px;white-space:nowrap;font-weight:500;display:flex;align-items:center;gap:8px;transition:.15s}
.index a .n{font-family:var(--mono);font-size:11px;color:var(--faint)}
.index a:hover{background:#fff;color:var(--ink)}
.index a.on{background:var(--brand);color:#fff}
.index a.on .n{color:#bfe9f0}

/* ---------- INTRO ---------- */
.intro{position:relative;overflow:hidden;padding:60px 0 64px;border-bottom:1px solid var(--line);
  background:radial-gradient(1000px 460px at 84% -12%,var(--tint),transparent 60%),linear-gradient(180deg,#FBFDFE,#F2F6F8)}
.intro::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(rgba(10,156,176,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(10,156,176,.06) 1px,transparent 1px);
  background-size:50px 50px;mask-image:radial-gradient(820px 420px at 82% 0,#000,transparent 76%)}
.intro .wrap{position:relative;z-index:2}
.intro-grid{display:grid;grid-template-columns:1fr auto;gap:42px;align-items:flex-end}
.intro h1{font-size:clamp(34px,4.4vw,54px);line-height:1.02;letter-spacing:-.035em;font-weight:800;color:var(--ink);margin:16px 0 8px}
.intro .en{font-family:var(--mono);font-size:14px;letter-spacing:.04em;color:var(--muted)}
.intro p.lede{font-size:18px;line-height:1.6;color:var(--text);max-width:640px;margin-top:20px}
.intro .pills{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px}
.intro .pill{font-size:13px;color:var(--brand-2);background:#fff;border:1px solid var(--tint-2);border-radius:8px;padding:7px 13px;font-weight:500;box-shadow:var(--shadow-xs)}
.intro-meta{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:6px 22px;box-shadow:var(--shadow-sm)}
.intro-meta .row{display:flex;align-items:baseline;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.intro-meta .row:last-child{border-bottom:0}
.intro-meta .k{font-family:var(--mono);font-size:28px;font-weight:700;color:var(--ink);letter-spacing:-.02em;min-width:78px}
.intro-meta .k em{font-style:normal;color:var(--brand);font-size:17px}
.intro-meta .v{font-size:12.5px;color:var(--muted)}

/* ---------- TOUR ---------- */
.tour{padding:64px 0;border-bottom:1px solid var(--line)}
.tour.alt{background:var(--bg)}
.tour-head{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:start;margin-bottom:28px}
.tour-head .num{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--brand-2);background:var(--tint);border:1px solid var(--tint-2);border-radius:9px;padding:8px 12px;height:fit-content;letter-spacing:.04em}
.tour-head h2{font-size:clamp(23px,2.6vw,32px);letter-spacing:-.03em;line-height:1.12;font-weight:800;color:var(--ink)}
.tour-head p{font-size:15.5px;color:var(--muted);line-height:1.56;margin-top:8px;max-width:600px}
.tour-head .pills{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end;max-width:340px}
.tour-head .pills .p{font-size:11.5px;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:7px;padding:5px 11px;font-weight:500}

/* ---------- WINDOW + SHELL ---------- */
.win{border-radius:16px;background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow-lg);overflow:hidden}
.win-bar{display:flex;align-items:center;gap:9px;padding:11px 15px;background:var(--panel-2);border-bottom:1px solid var(--line)}
.dots{display:flex;gap:6px}.dot{width:11px;height:11px;border-radius:50%}
.win-bar .url{margin-left:8px;font-family:var(--mono);font-size:11.5px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:7px;padding:5px 13px;display:flex;align-items:center;gap:8px}
.win-bar .url .lock{color:var(--pos)}
.app{display:grid;grid-template-columns:204px 1fr;min-height:564px}
.side{background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:16px 12px}
.side-brand{display:flex;align-items:center;gap:10px;padding:4px 8px 16px;border-bottom:1px solid var(--line);margin-bottom:12px}
.side-brand .lg{width:30px;height:30px;border-radius:8px;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:15px;box-shadow:0 3px 10px -3px var(--brand)}
.side-brand .bt{font-weight:800;font-size:14px;color:var(--ink);letter-spacing:-.01em}
.side-brand .bs{font-family:var(--mono);font-size:9px;color:var(--faint);letter-spacing:.04em}
.side-sec{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);padding:10px 10px 6px}
.snav{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;color:var(--muted);font-size:13px;font-weight:500;cursor:default;transition:.14s}
.snav svg{width:18px;height:18px;stroke-width:1.9;flex-shrink:0}
.snav .cnt{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:700;color:var(--muted);background:var(--panel-3);padding:1px 7px;border-radius:20px}
.snav:hover{background:var(--panel-2);color:var(--text)}
.snav.on{background:var(--tint);color:var(--brand-2);font-weight:600}
.snav.on .cnt{background:var(--brand);color:#fff}
.side-foot{margin-top:auto;display:flex;align-items:center;gap:9px;padding:10px;border-top:1px solid var(--line)}
.side-foot .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-3));color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700}
.side-foot .nm{font-size:12px;font-weight:600;color:var(--ink)}
.side-foot .rl{font-size:10px;color:var(--muted)}
.main{background:var(--bg);display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:16px;padding:14px 22px;background:var(--panel);border-bottom:1px solid var(--line)}
.tb-title{font-size:17px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.tb-sub{font-size:12px;color:var(--muted);margin-top:1px}
.tb-sp{flex:1}
.tb-search{display:flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:8px 13px;min-width:210px;color:var(--faint);font-size:12.5px}
.tb-search svg{width:15px;height:15px;stroke:var(--faint)}
.tb-live{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--neg);background:var(--neg-t);padding:6px 11px;border-radius:8px;letter-spacing:.05em}
.tb-live .pulse{width:7px;height:7px;border-radius:50%;background:var(--neg);animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.tb-btn{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:#fff;background:var(--brand);border-radius:10px;padding:9px 15px;box-shadow:0 4px 12px -4px var(--brand)}
.tb-btn svg{width:15px;height:15px;stroke:#fff;stroke-width:2.2}
.canvas{padding:18px 22px 22px;flex:1}

/* segmented + chips */
.seg{display:inline-flex;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:3px}
.seg b{font-size:12px;color:var(--muted);padding:6px 12px;border-radius:6px;font-weight:600;cursor:default}
.seg b.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-xs)}
.chip{font-size:11.5px;color:var(--muted);border:1px solid var(--line);border-radius:20px;padding:5px 12px;background:#fff;font-weight:500}
.chip.on{background:var(--tint);border-color:var(--tint-2);color:var(--brand-2)}
.pillbtn{font-size:12px;font-weight:600;color:var(--brand-2);background:var(--tint);border:1px solid var(--tint-2);border-radius:9px;padding:7px 13px;display:inline-flex;align-items:center;gap:6px}
.tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}

/* ---------- WAVEFORM PLAYER ---------- */
.player{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:15px 17px;box-shadow:var(--shadow-xs)}
.player.live{background:linear-gradient(180deg,#fff,var(--panel-2))}
.player-top{display:flex;align-items:center;gap:13px;margin-bottom:13px}
.play-btn{width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;flex-shrink:0;box-shadow:0 5px 14px -4px var(--brand)}
.play-btn svg{width:18px;height:18px;fill:#fff}
.player-info{flex:1;min-width:0}
.player-info .h{font-size:14px;font-weight:700;color:var(--ink)}
.player-info .s{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:2px}
.player-time{font-family:var(--mono);font-size:12px;color:var(--text);font-weight:600}
.wave{display:flex;align-items:center;gap:2px;height:56px;position:relative}
.wave .bar{flex:1;border-radius:2px;background:var(--tint-2);min-width:2px}
.wave .bar.a{background:var(--spkA)}
.wave .bar.b{background:var(--spkB)}
.wave .bar.played{opacity:1}
.wave .bar.future{opacity:.4}
.wave .ph{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--ink);border-radius:2px;z-index:2}
.wave .ph::after{content:"";position:absolute;top:-4px;left:-3px;width:8px;height:8px;border-radius:50%;background:var(--ink)}
.wave-live{display:flex;align-items:center;gap:2px;height:56px}
.wave-live .bar{flex:1;border-radius:2px;background:var(--brand);min-width:2px;animation:vu 1.1s ease-in-out infinite}
@keyframes vu{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}
.wave-axis{display:flex;justify-content:space-between;font-family:var(--mono);font-size:9px;color:var(--faint);margin-top:6px}
.spk-legend{display:flex;gap:14px;margin-top:10px}
.spk-legend div{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--text)}
.spk-legend .sw{width:11px;height:11px;border-radius:3px}

/* ---------- TRANSCRIPT ---------- */
.call-wrap{display:grid;grid-template-columns:1fr 312px;gap:16px;margin-top:14px}
.transcript{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:8px;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:4px;max-height:520px;overflow:hidden}
.turn{display:flex;gap:11px;padding:10px 11px;border-radius:11px}
.turn:hover{background:var(--panel-2)}
.turn .av{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.turn.a .av{background:var(--spkA)}.turn.b .av{background:var(--spkB)}
.turn .body{flex:1;min-width:0}
.turn .meta{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.turn .who{font-size:12px;font-weight:700;color:var(--ink)}
.turn.a .who{color:var(--brand-2)}.turn.b .who{color:var(--spkB)}
.turn .tm{font-family:var(--mono);font-size:10px;color:var(--faint)}
.turn .senti{font-size:9px;font-weight:700;padding:1px 6px;border-radius:5px}
.senti.pos{background:var(--pos-t);color:var(--pos)}.senti.neg{background:var(--neg-t);color:var(--neg)}.senti.neu{background:var(--neu-t);color:var(--neu)}
.turn .txt{font-size:13.5px;color:var(--text);line-height:1.55}
.turn .txt .kw{background:var(--tint);color:var(--brand-2);font-weight:600;padding:0 3px;border-radius:3px}
.turn .txt .kw.neg{background:var(--neg-t);color:var(--neg)}
.turn.live .txt::after{content:"▋";color:var(--brand);animation:blink 1s infinite}

/* analysis side */
.ana-side{display:flex;flex-direction:column;gap:12px}
.ana-card{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:15px;box-shadow:var(--shadow-xs)}
.ana-card h4{font-size:12.5px;font-weight:700;color:var(--ink);margin-bottom:11px;display:flex;align-items:center;gap:7px}
.ana-card h4 .ico{width:18px;height:18px;color:var(--brand)}
.summary-txt{font-size:13px;color:var(--text);line-height:1.6}
.senti-meter{display:flex;flex-direction:column;gap:9px}
.senti-bar{display:flex;align-items:center;gap:10px;font-size:12px}
.senti-bar .lb{width:38px;color:var(--muted)}
.senti-bar .track{flex:1;height:8px;border-radius:5px;background:var(--panel-3);overflow:hidden}
.senti-bar .track i{display:block;height:100%;border-radius:5px}
.senti-bar .pc{font-family:var(--mono);font-size:11px;color:var(--text);font-weight:600;width:34px;text-align:right}
.kw-chips{display:flex;flex-wrap:wrap;gap:6px}
.kw-chip{font-size:11.5px;color:var(--brand-2);background:var(--tint);border:1px solid var(--tint-2);border-radius:20px;padding:4px 11px;font-weight:500}
.kw-chip .c{font-family:var(--mono);color:var(--muted);margin-left:5px;font-size:10px}
.actions-list{display:flex;flex-direction:column;gap:9px}
.action-item{display:flex;gap:9px;font-size:12.5px;color:var(--text);align-items:flex-start}
.action-item .ck{width:17px;height:17px;border-radius:5px;border:1.6px solid var(--tint-2);flex-shrink:0;margin-top:1px;display:grid;place-items:center}
.action-item.done .ck{background:var(--brand);border-color:var(--brand)}
.action-item.done .ck svg{width:10px;height:10px;stroke:#fff;stroke-width:3}

/* ---------- LIVE metrics ---------- */
.live-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:14px}
.lmetric{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:13px 15px;box-shadow:var(--shadow-xs)}
.lmetric .l{font-size:11.5px;color:var(--muted)}
.lmetric .v{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--ink);margin-top:4px;display:flex;align-items:baseline;gap:4px}
.lmetric .v small{font-size:11px;color:var(--faint);font-weight:500}
.lmetric .v.pos{color:var(--pos)}.lmetric .v.neg{color:var(--neg)}

/* ---------- TABLE ---------- */
.tbl{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;font-size:13px;box-shadow:var(--shadow-xs)}
.tbl th{text-align:left;font-size:10.5px;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;font-weight:600;padding:12px 15px;background:var(--panel-2);border-bottom:1px solid var(--line)}
.tbl td{padding:11px 15px;border-bottom:1px solid var(--line);color:var(--text);vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}.tbl tbody tr:hover{background:var(--panel-2)}
.cname{display:flex;align-items:center;gap:11px}
.av-sm{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
.cname .h{font-weight:600;color:var(--ink)}.cname .s{font-family:var(--mono);font-size:10.5px;color:var(--muted);margin-top:2px}
.miniwave{display:flex;align-items:center;gap:1.5px;height:22px;width:90px}
.miniwave i{flex:1;background:var(--tint-2);border-radius:1px;min-width:1.5px}
.tag{font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;display:inline-block;white-space:nowrap}
.tag.pos{background:var(--pos-t);color:var(--pos)}.tag.neg{background:var(--neg-t);color:var(--neg)}.tag.neu{background:var(--neu-t);color:var(--neu)}.tag.b{background:var(--tint);color:var(--brand-2)}.tag.n{background:var(--panel-3);color:var(--muted)}
.pg{display:flex;align-items:center;justify-content:space-between;margin-top:13px;font-size:12.5px;color:var(--muted)}
.pgb{display:flex;gap:5px}
.pgb b{width:30px;height:30px;display:grid;place-items:center;border:1px solid var(--line);border-radius:8px;font-size:12px;color:var(--text);font-weight:600;background:#fff}
.pgb b.on{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ---------- 04 TTS STUDIO ---------- */
.tts-wrap{display:grid;grid-template-columns:1fr 320px;gap:16px}
.tts-editor{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:14px}
.tts-ta{background:var(--panel-2);border:1px solid var(--line);border-radius:11px;padding:14px 15px;font-size:14.5px;line-height:1.7;color:var(--ink);min-height:150px}
.tts-ta .ssml{background:var(--tint);color:var(--brand-2);border-radius:4px;padding:0 4px;font-family:var(--mono);font-size:12px}
.tts-controls{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ctrl .cl{font-size:12px;color:var(--muted);margin-bottom:7px;display:flex;justify-content:space-between}
.ctrl .cl b{color:var(--ink);font-family:var(--mono)}
.slider{height:6px;border-radius:5px;background:var(--panel-3);position:relative}
.slider i{position:absolute;left:0;top:0;bottom:0;border-radius:5px;background:var(--brand)}
.slider .knob{position:absolute;top:50%;width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid var(--brand);transform:translate(-50%,-50%);box-shadow:var(--shadow-sm)}
.tts-out{display:flex;align-items:center;gap:13px;background:var(--tint);border:1px solid var(--tint-2);border-radius:11px;padding:13px 15px}
.tts-gen{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:700;color:#fff;background:var(--brand);border-radius:11px;padding:13px;box-shadow:0 5px 14px -4px var(--brand)}
.tts-gen svg{width:17px;height:17px;stroke:#fff;stroke-width:2.2}
/* voice cards */
.voice-list{display:flex;flex-direction:column;gap:10px}
.voice-h{font-size:12.5px;font-weight:700;color:var(--ink);margin-bottom:2px}
.voice{display:flex;align-items:center;gap:11px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:11px 13px;box-shadow:var(--shadow-xs)}
.voice.on{border-color:var(--brand);background:var(--tint)}
.voice .av{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.voice .vi{flex:1;min-width:0}
.voice .vn{font-size:13px;font-weight:700;color:var(--ink)}
.voice .vtag{font-size:10.5px;color:var(--muted);margin-top:2px}
.voice .vplay{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--brand);flex-shrink:0}
.voice .vplay svg{width:13px;height:13px;fill:var(--brand)}
.voice.on .vplay{background:var(--brand);border-color:var(--brand);color:#fff}
.voice.on .vplay svg{fill:#fff}

/* ---------- ANALYTICS ---------- */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:15px;box-shadow:var(--shadow-xs)}
.kpi .l{font-size:12px;color:var(--muted)}
.kpi .v{font-size:26px;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin-top:8px;font-family:var(--mono)}
.kpi .d{font-size:11.5px;margin-top:5px;font-family:var(--mono);font-weight:600;display:inline-flex;align-items:center;gap:4px}
.kpi .d.up{color:var(--pos)}.kpi .d.dn{color:var(--neg)}
.rep-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:14px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:16px;box-shadow:var(--shadow-xs)}
.panel .ph{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.panel .ph .t{font-size:13.5px;font-weight:700;color:var(--ink)}
.panel .ph .leg{display:flex;gap:13px;font-size:11px;color:var(--muted)}
.leg i{width:9px;height:9px;border-radius:2px;display:inline-block;margin-right:5px;vertical-align:middle}
.bars{display:flex;align-items:flex-end;gap:9px;height:160px}
.bars .col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:3px;height:100%}
.bars .bar{border-radius:3px 3px 0 0;background:var(--brand)}
.bars .bar.b2{background:var(--tint-2)}
.bars .x{font-family:var(--mono);font-size:9px;color:var(--faint);text-align:center}
.donut-wrap{display:flex;align-items:center;gap:22px}
.donut{width:140px;height:140px;border-radius:50%;flex-shrink:0;position:relative}
.donut::after{content:"";position:absolute;inset:26px;border-radius:50%;background:var(--panel)}
.donut .ctr{position:absolute;inset:0;display:grid;place-items:center;text-align:center;z-index:2}
.donut .ctr b{font-family:var(--mono);font-size:22px;color:var(--ink);display:block;line-height:1}
.donut .ctr span{font-size:9px;color:var(--muted);font-family:var(--mono)}
.dleg{display:flex;flex-direction:column;gap:11px;font-size:12.5px;color:var(--text)}
.dleg div{display:flex;align-items:center;gap:9px}
.dleg .v{margin-left:auto;font-family:var(--mono);color:var(--muted);font-weight:600}
.sw{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.rank{display:flex;flex-direction:column;gap:11px}
.rank .r{display:flex;align-items:center;gap:11px;font-size:12.5px}
.rank .nm{color:var(--ink);font-weight:500;width:92px;flex-shrink:0}
.rank .track2{flex:1;height:8px;border-radius:5px;background:var(--panel-3);overflow:hidden}
.rank .track2 i{display:block;height:100%;background:var(--brand);border-radius:5px}
.rank .vv{font-family:var(--mono);font-size:11px;color:var(--muted);width:42px;text-align:right}

/* ---------- RULES ---------- */
.rule{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-xs);margin-bottom:10px}
.rule .top{display:flex;align-items:center;gap:11px}
.rule .rn{font-size:13.5px;font-weight:700;color:var(--ink)}
.rule .cond{font-family:var(--mono);font-size:11.5px;color:var(--text);background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:9px 12px;margin-top:10px;line-height:1.6}
.rule .cond .kw{color:var(--brand-2);font-weight:700}
.rule .cond .ph2{color:var(--spkB);font-weight:600}
.rule .foot{display:flex;gap:7px;margin-top:10px;align-items:center}
.rule .mtag{font-size:10.5px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:6px;padding:3px 9px;font-family:var(--mono)}
.toggle{width:36px;height:20px;border-radius:20px;background:var(--brand);position:relative;flex-shrink:0;margin-left:auto}
.toggle::after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2px;right:2px;box-shadow:0 1px 2px rgba(0,0,0,.2)}
.toggle.off{background:var(--line-2)}.toggle.off::after{left:2px;right:auto}

/* ---------- INTEGRATIONS / SETTINGS ---------- */
.intg-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.intg{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:15px;box-shadow:var(--shadow-xs)}
.intg .top{display:flex;align-items:center;gap:11px;margin-bottom:13px}
.intg .ic{width:36px;height:36px;border-radius:9px;background:var(--tint);display:grid;place-items:center}
.intg .ic svg{width:18px;height:18px;stroke:var(--brand)}
.intg .nm{font-size:14.5px;font-weight:700;color:var(--ink)}
.intg .stt{font-size:11.5px;color:var(--muted);margin-top:2px}
.field{font-family:var(--mono);font-size:11px;color:var(--text);background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:9px 11px;word-break:break-all}
.kv{display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted);padding:8px 0;border-bottom:1px solid var(--line)}
.kv:last-child{border:0}.kv b{color:var(--ink);font-weight:500;font-family:var(--mono)}
.set-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.setcard{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:16px;box-shadow:var(--shadow-xs)}
.setcard h4{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:13px}
.opt{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--line)}
.opt:last-child{border:0}
.opt .oi{flex:1}.opt .on{font-size:13px;font-weight:600;color:var(--ink)}.opt .od{font-size:11.5px;color:var(--muted);margin-top:2px}
.langtag{font-size:10.5px;color:var(--text);border:1px solid var(--line);border-radius:6px;padding:3px 9px;font-family:var(--mono);background:#fff}
.seg-v{display:inline-flex;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:2px;margin-left:auto}
.seg-v b{font-size:11px;padding:5px 11px;border-radius:6px;color:var(--muted);font-weight:600}
.seg-v b.on{background:var(--brand);color:#fff}
.vocab{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.vocab span{font-size:11px;font-family:var(--mono);color:var(--brand-2);background:var(--tint);border:1px solid var(--tint-2);border-radius:6px;padding:3px 9px}

/* ---------- FEATURE MATRIX ---------- */
.matrix{padding:70px 0;background:var(--bg);border-bottom:1px solid var(--line)}
.mat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.mcard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;transition:.18s;box-shadow:var(--shadow-xs)}
.mcard:hover{border-color:var(--tint-2);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.mcard .ic{width:44px;height:44px;border-radius:11px;background:var(--tint);display:grid;place-items:center;margin-bottom:15px}
.mcard .ic svg{width:22px;height:22px;stroke:var(--brand)}
.mcard h4{font-size:16.5px;font-weight:700;margin-bottom:7px;letter-spacing:-.01em;color:var(--ink)}
.mcard p{font-size:14px;color:var(--muted);line-height:1.55}

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

@media(max-width:1040px){
  .call-wrap,.tts-wrap,.rep-grid,.intg-grid,.set-grid{grid-template-columns:1fr}
  .live-metrics,.kpi-row{grid-template-columns:1fr 1fr}.mat-grid{grid-template-columns:1fr 1fr}
  .intro-grid{grid-template-columns:1fr}.tour-head{grid-template-columns:auto 1fr}.tour-head .pills{display:none}
  .app{grid-template-columns:1fr}.side{display:none}
}
@media(max-width:640px){
  .wrap{padding:0 16px}.live-metrics,.kpi-row,.mat-grid,.tts-controls{grid-template-columns:1fr}
  .tour{padding:46px 0}.tbl th:nth-child(n+4),.tbl td:nth-child(n+4){display:none}
}
