:root{
  --bg:#0f172a; --panel:#1e293b; --panel2:#334155; --line:#475569;
  --text:#e2e8f0; --muted:#94a3b8; --accent:#3b82f6; --accent2:#2563eb;
  --danger:#dc2626; --ok:#16a34a; --active:#f59e0b;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI","Malgun Gothic",sans-serif;background:var(--bg);color:var(--text)}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 20px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.topbar h1{font-size:18px;margin:0}
.badge{font-size:12px;padding:4px 10px;border-radius:999px;background:var(--panel2);color:var(--muted)}
.badge.ready{background:#064e3b;color:#6ee7b7}
main{max-width:980px;margin:0 auto;padding:20px}

.drop-zone{border:2px dashed var(--line);border-radius:14px;padding:46px 20px;text-align:center;
  cursor:pointer;transition:.15s;background:var(--panel)}
.drop-zone.drag{border-color:var(--accent);background:#1e293b}
.drop-icon{font-size:46px}
.drop-title{font-size:17px;color:var(--text);margin:10px 0 4px}
.drop-sub{font-size:13px;color:var(--muted);margin:0}

.controls{margin-top:18px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px}
.ctrl-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:10px}
.ctrl-row:last-child{margin-bottom:0}
.tts-row label{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.tts-row select,.tts-row input[type=range]{accent-color:var(--accent)}
select{background:var(--panel2);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:6px 8px;max-width:240px}
input[type=range]{width:120px}
.chk{cursor:pointer}

.btn{background:var(--panel2);color:var(--text);border:1px solid var(--line);border-radius:8px;
  padding:8px 14px;font-size:14px;cursor:pointer;transition:.12s}
.btn:hover{background:var(--line)}
.btn.primary{background:var(--accent);border-color:var(--accent2)}
.btn.primary:hover{background:var(--accent2)}
.btn.danger{background:var(--danger);border-color:#b91c1c}
.btn:disabled{opacity:.45;cursor:not-allowed}
.status{font-size:13px;color:var(--muted)}

.slides{margin-top:18px;display:flex;flex-direction:column;gap:14px}
.slide{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:.15s}
.slide.active{border-color:var(--active);box-shadow:0 0 0 2px rgba(245,158,11,.3)}
.slide-head{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--panel2);border-bottom:1px solid var(--line)}
.slide-num{background:var(--accent);color:#fff;font-weight:700;font-size:13px;border-radius:6px;padding:3px 9px}
.slide-title{font-size:15px;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.slide-play{background:var(--ok);border:none;color:#fff;border-radius:8px;padding:6px 12px;cursor:pointer;font-size:13px}
.slide-play:hover{filter:brightness(1.1)}
.slide-body{padding:14px}
.lbl{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin:0 0 4px}
.script-text{font-size:15px;line-height:1.65;color:#f1f5f9;white-space:pre-wrap;margin:0 0 12px}
.body-text{font-size:13px;line-height:1.55;color:var(--muted);white-space:pre-wrap;margin:0;
  border-top:1px dashed var(--line);padding-top:10px}
.empty-note{color:#64748b;font-style:italic}

.foot{text-align:center;color:var(--muted);font-size:12px;padding:24px}
.hidden{display:none}
.word-active{background:rgba(245,158,11,.35);border-radius:3px}
