*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--bg2:#1a1d27;--bg3:#23273a;--border:#2e3245;--text:#c9cdd9;--text-dim:#6b7280;--text-head:#f0f2ff;--accent:#6c63ff;--accent-h:#8b85ff;--green:#22c55e;--red:#ef4444;--yellow:#facc15;--sans:"Space Grotesk", system-ui, sans-serif;--serif:"Syne", system-ui, sans-serif;font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:16px}body{min-height:100dvh}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:var(--accent-h);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea{font-family:inherit}.loading-screen{flex:1;justify-content:center;align-items:center;min-height:200px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn-primary{background:var(--accent);color:#fff;border-radius:12px;align-items:center;gap:8px;padding:12px 24px;font-size:16px;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.btn-primary:hover{background:var(--accent-h)}.btn-primary:active{transform:scale(.97)}.btn-primary.large{border-radius:14px;padding:16px 32px;font-size:18px}.btn-primary:disabled{opacity:.4;pointer-events:none}.btn-secondary{background:var(--bg3);color:var(--text-head);border:1px solid var(--border);border-radius:12px;align-items:center;gap:8px;padding:12px 20px;font-size:16px;font-weight:500;display:inline-flex}.btn-secondary:hover{background:var(--bg2)}.btn-ghost{color:var(--text-dim);border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:14px;transition:color .15s,background .15s;display:inline-flex}.btn-ghost:hover{color:var(--text-head);background:var(--bg3)}.btn-ghost.danger:hover{color:var(--red)}.auth-page{flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.auth-card{background:var(--bg2);border:1px solid var(--border);border-radius:20px;flex-direction:column;gap:24px;width:100%;max-width:420px;padding:40px 32px;display:flex}.brand{font-family:var(--serif);letter-spacing:-1px;color:var(--text-head);text-align:center;white-space:nowrap;font-size:42px;font-weight:900}.brand-exclaim{color:var(--accent);display:inline-block;transform:skew(-8deg)}.brand-sub{text-align:center;color:var(--text-dim);font-size:15px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-form label{color:var(--text-dim);flex-direction:column;gap:6px;font-size:14px;font-weight:500;display:flex}.auth-form input{border:1px solid var(--border);background:var(--bg3);color:var(--text-head);border-radius:10px;outline:none;padding:12px 16px;font-size:16px;transition:border-color .15s}.auth-form input:focus{border-color:var(--accent)}.auth-form .btn-primary{justify-content:center;width:100%;margin-top:4px}.auth-link{text-align:center;color:var(--text-dim);font-size:14px}.instagram-link{color:var(--text-dim);justify-content:center;align-items:center;gap:7px;margin-top:20px;font-size:13px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.instagram-link:hover{color:#e1306c}.error-msg{color:var(--red);background:#ef44441a;border-radius:8px;padding:8px 12px;font-size:14px}.confirmation-msg{text-align:center;color:var(--text);line-height:1.6}.page{flex-direction:column;flex:1;max-width:100%;display:flex}.dashboard-header{border-bottom:1px solid var(--border);background:var(--bg2);z-index:10;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.dashboard-header .brand{font-size:26px}.header-actions{align-items:center;gap:12px;display:flex}.user-email{color:var(--text-dim);font-size:13px}.dashboard-main{flex:1;padding:24px 20px}.section-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.section-header h2{color:var(--text-head);font-size:22px}.empty-state{color:var(--text-dim);flex-direction:column;align-items:center;gap:16px;padding:60px 20px;display:flex}.empty-state p{font-size:18px}.scripts-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.script-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:16px;padding:20px;transition:border-color .15s;display:flex}.script-card:hover{border-color:var(--accent)}.script-card h3{color:var(--text-head);font-size:18px;font-weight:600}.character-badge{background:var(--bg3);color:var(--accent-h);border-radius:20px;padding:3px 10px;font-size:13px;font-weight:600;display:inline-block}.script-card-actions{align-items:center;gap:10px;display:flex}.setup-header{border-bottom:1px solid var(--border);background:var(--bg2);z-index:10;align-items:center;gap:12px;padding:14px 16px;display:flex;position:sticky;top:0}.setup-header h2{color:var(--text-head);flex:1;font-size:18px}.steps-indicator{align-items:center;gap:6px;display:flex}.step-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:background .2s}.step-dot.active{background:var(--accent)}.step-dot.done{background:var(--green)}.setup-main{flex:1;width:100%;max-width:600px;margin:0 auto;padding:24px 20px}.setup-step{flex-direction:column;gap:20px;display:flex}.field-label{color:var(--text-dim);flex-direction:column;gap:8px;font-size:15px;font-weight:500;display:flex}.text-input{border:1px solid var(--border);background:var(--bg3);color:var(--text-head);border-radius:10px;outline:none;padding:12px 16px;font-size:16px}.text-input:focus{border-color:var(--accent)}.script-textarea{border:1px solid var(--border);background:var(--bg3);color:var(--text-head);resize:vertical;border-radius:12px;outline:none;min-height:300px;padding:14px 16px;font-size:15px;line-height:1.6}.script-textarea:focus{border-color:var(--accent)}.pdf-upload-section{flex-direction:column;gap:8px;display:flex}.pdf-upload-btn{align-self:flex-start;align-items:center;gap:8px;display:inline-flex}.pdf-page-range{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.pdf-page-label{color:var(--text-dim);font-size:13px}.page-input{text-align:center;border:1px solid var(--border);background:var(--bg3);width:56px;color:var(--text-head);border-radius:8px;outline:none;padding:6px 10px;font-size:14px}.page-input:focus{border-color:var(--accent)}.pdf-info-msg{color:var(--green);font-size:13px}.spin{animation:.8s linear infinite spin}.step-description{color:var(--text-dim);font-size:16px}.info-msg{color:var(--yellow);background:#facc151a;border-radius:10px;padding:12px;font-size:15px}.character-list{flex-wrap:wrap;gap:12px;display:flex}.character-option{border:2px solid var(--border);background:var(--bg3);color:var(--text-head);border-radius:12px;padding:14px 24px;font-size:16px;font-weight:600;transition:all .15s}.character-option:hover{border-color:var(--accent)}.character-option.selected{border-color:var(--accent);color:var(--accent-h);background:#6c63ff33}.voice-config-list{flex-direction:column;gap:16px;display:flex}.voice-config-card{background:var(--bg3);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:14px;padding:18px;display:flex}.character-name{color:var(--text-head);font-size:16px;font-weight:700}.voice-options{flex-direction:column;gap:10px;display:flex}.option-group{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.option-label{color:var(--text-dim);min-width:52px;font-size:14px}.option-buttons{gap:8px;display:flex}.option-btn{border:1px solid var(--border);background:var(--bg2);color:var(--text);border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .15s}.option-btn:hover{border-color:var(--accent)}.option-btn.selected{border-color:var(--accent);color:var(--accent-h);background:#6c63ff33}.step-nav{justify-content:space-between;gap:12px;margin-top:8px;display:flex}.practice-page{flex-direction:column;flex:1;height:100dvh;display:flex;overflow:hidden}.practice-header{border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;align-items:center;gap:12px;padding:12px 16px;display:flex}.practice-title{flex-direction:column;flex:1;gap:2px;display:flex}.practice-title h2{color:var(--text-head);font-size:16px;font-weight:600}.my-character-badge{letter-spacing:.5px;color:var(--accent-h);text-transform:uppercase;font-size:11px;font-weight:700}.status-indicator{white-space:nowrap;text-align:center;border-radius:20px;min-width:120px;padding:6px 14px;font-size:13px;font-weight:600}.status-indicator.idle{background:var(--bg3);color:var(--text-dim)}.status-indicator.listening{color:var(--green);background:#22c55e26;animation:1.5s ease-in-out infinite pulse-green}.status-indicator.speaking{color:var(--accent-h);background:#6c63ff26;animation:1.5s ease-in-out infinite pulse-purple}.status-indicator.paused{color:var(--yellow);background:#facc151f}.status-indicator.done{color:var(--green);background:#22c55e1a}@keyframes pulse-green{0%,to{opacity:1}50%{opacity:.6}}@keyframes pulse-purple{0%,to{opacity:1}50%{opacity:.6}}.script-viewer{scroll-behavior:smooth;flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.speech-block{cursor:pointer;border:2px solid #0000;border-radius:14px;padding:14px 18px;transition:all .2s}.speech-block.mine{background:#6c63ff14;border-color:#6c63ff26;margin-left:20px}.speech-block.theirs{background:var(--bg2);border-color:var(--border);margin-right:20px}.speech-block.current.mine{border-color:var(--accent);background:#6c63ff2e}.speech-block.current.theirs{border-color:var(--green);background:#22c55e14}.speech-char{letter-spacing:.8px;text-transform:uppercase;margin-bottom:6px;font-size:11px;font-weight:700;display:block}.speech-block.mine .speech-char{color:var(--accent-h)}.speech-block.theirs .speech-char{color:var(--green)}.speech-text{color:var(--text-head);font-size:18px;line-height:1.55}.error-banner{color:var(--red);background:#ef444426;border-bottom:1px solid #ef44444d;justify-content:space-between;align-items:center;padding:12px 16px;font-size:14px;display:flex}.error-banner button{color:var(--red);font-size:14px;text-decoration:underline}.done-banner{text-align:center;color:var(--text-head);flex-direction:column;align-items:center;gap:16px;padding:24px;font-size:20px;font-weight:600;display:flex}.practice-controls{border-bottom:1px solid var(--border);background:var(--bg2);flex-wrap:wrap;flex-shrink:0;justify-content:center;align-items:center;gap:16px;padding:12px 16px;display:flex}.ctrl-btn{background:var(--bg3);width:52px;height:52px;color:var(--text-head);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.ctrl-btn:hover:not(:disabled){background:var(--border)}.ctrl-btn:active:not(:disabled){transform:scale(.93)}.ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.ctrl-btn.play{background:var(--accent);border-color:var(--accent);width:68px;height:68px}.ctrl-btn.play:hover{background:var(--accent-h);border-color:var(--accent-h)}.speed-control{display:none}.speed-control-inline{border-left:1px solid var(--border);align-items:center;gap:4px;margin-left:8px;padding-left:12px;display:flex}.speed-btn{border:1px solid var(--border);background:var(--bg3);color:var(--text-dim);border-radius:6px;padding:4px 12px;font-size:13px;font-weight:600;transition:all .15s}.speed-btn:hover:not(.active){color:var(--text-head);border-color:var(--text-dim)}.speed-btn.active{border-color:var(--accent);color:var(--accent-h);background:#6c63ff33}.plan-badge{letter-spacing:.3px;cursor:pointer;border:none;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:700;transition:opacity .15s}.plan-badge:hover{opacity:.8}.plan-badge.free{background:var(--bg3);color:var(--text-dim)}.plan-badge.actor{color:var(--accent-h);background:#6c63ff33}.plan-badge.pro{color:var(--yellow);background:#facc1526}.upgrade-banner{color:var(--text-dim);background:#6c63ff14;border:1px solid #6c63ff33;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:10px 20px;font-size:13px;display:flex}.btn-upgrade{background:var(--accent);color:#fff;white-space:nowrap;border-radius:8px;align-items:center;gap:5px;padding:5px 12px;font-size:13px;font-weight:600;transition:background .15s;display:inline-flex}.btn-upgrade:hover{background:var(--accent-h)}.btn-primary.disabled{opacity:.4}.practice-header-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.exam-toggle{border:1px solid var(--border);background:var(--bg3);color:var(--text-dim);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.exam-toggle:hover{border-color:var(--accent);color:var(--accent-h)}.exam-toggle.active{border-color:var(--accent);color:var(--accent-h);background:#6c63ff33}.exam-line{align-items:center;gap:10px;display:flex}.speech-text.exam-masked{height:1.4em;width:var(--mask-len,12ch);background:var(--border);border-radius:4px;flex:1;margin:0}.speech-text.exam-revealed{animation:.25s exam-fade-in}@keyframes exam-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.exam-hint-btn{border:1px solid var(--border);background:var(--bg3);color:var(--text-dim);cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;padding:3px 10px;font-size:12px;font-weight:600;transition:all .15s}.exam-hint-btn:hover{border-color:var(--accent);color:var(--accent-h)}.exam-summary{margin-top:12px;font-size:14px}.exam-summary-perfect{color:var(--green);font-weight:700}.exam-summary-title{color:var(--text-dim);margin-bottom:8px;font-weight:600;display:block}.exam-hint-list{text-align:left;flex-direction:column;gap:6px;max-width:340px;margin:0 auto;list-style:none;display:flex}.exam-hint-list li{align-items:baseline;gap:8px;font-size:13px;display:flex}.exam-hint-count{color:var(--accent-h);min-width:24px;font-weight:700}.exam-hint-preview{color:var(--text-dim)}.metrics-panel{flex-direction:column;align-items:center;gap:16px;width:100%;max-width:480px;font-size:14px;display:flex}.metrics-overall{align-items:baseline;gap:10px;display:flex}.metrics-score{font-size:48px;font-weight:900;line-height:1}.metrics-score--green{color:var(--green)}.metrics-score--yellow{color:var(--yellow)}.metrics-score--red{color:#f87171}.metrics-label{color:var(--text-dim);font-size:14px}.metrics-lines{flex-direction:column;gap:12px;width:100%;list-style:none;display:flex}.metrics-line{grid-template-rows:auto auto;grid-template-columns:1fr auto;align-items:center;gap:4px 12px;display:grid}.metrics-line-bar{background:var(--bg3);border-radius:2px;grid-column:1;height:4px;overflow:hidden}.metrics-line-fill{border-radius:2px;height:100%;transition:width .4s}.metrics-line-fill--green{background:var(--green)}.metrics-line-fill--yellow{background:var(--yellow)}.metrics-line-fill--red{background:#f87171}.metrics-line-texts{flex-direction:column;grid-column:1;gap:2px;display:flex}.metrics-expected{color:var(--text);font-size:13px}.metrics-heard{color:var(--text-dim);font-size:12px;font-style:italic}.metrics-pct{color:var(--text-dim);grid-area:1/2/3;font-size:13px;font-weight:700}.metrics-perfect{color:var(--green);font-size:14px;font-weight:600}.minutes-warning{color:var(--yellow);background:#facc151a;border-bottom:1px solid #facc1533;padding:10px 16px;font-size:13px}.link-btn{color:var(--accent-h);cursor:pointer;font-size:inherit;background:0 0;border:none;text-decoration:underline}.option-btn.locked{opacity:.45;cursor:pointer;align-items:center;gap:4px;display:inline-flex}.option-btn.locked:hover{border-color:var(--yellow);opacity:.7}.pricing-main{flex:1;width:100%;max-width:960px;margin:0 auto;padding:24px 20px}.plan-cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.plan-card{background:var(--bg2);border:2px solid var(--border);border-radius:20px;flex-direction:column;gap:20px;padding:28px 24px;transition:border-color .2s;display:flex;position:relative}.plan-card.current,.plan-card.popular{border-color:var(--accent)}.plan-popular-tag,.plan-current-tag{letter-spacing:.5px;white-space:nowrap;border-radius:20px;padding:2px 12px;font-size:11px;font-weight:700;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.plan-popular-tag{background:var(--accent);color:#fff}.plan-current-tag{background:var(--green);color:#fff}.plan-name{color:var(--text-head);margin-bottom:4px;font-size:22px;font-weight:800}.plan-price{color:var(--text-head);font-size:30px;font-weight:700;line-height:1}.plan-price span{color:var(--text-dim);font-size:15px;font-weight:400}.plan-tagline{color:var(--text-dim);margin-top:4px;font-size:14px}.plan-features{flex-direction:column;flex:1;gap:10px;list-style:none;display:flex}.plan-features li{align-items:flex-start;gap:8px;font-size:14px;line-height:1.4;display:flex}.plan-features li.included{color:var(--text)}.plan-features li.excluded{color:var(--text-dim)}.feat-icon{flex-shrink:0;margin-top:1px}.feat-icon.yes{color:var(--green)}.feat-icon.no{color:var(--border)}.pricing-note{color:var(--text-dim);text-align:center;margin-top:24px;font-size:13px;line-height:1.6}.success-banner{color:var(--green);background:#22c55e1a;border:1px solid #22c55e4d;border-radius:10px;margin-bottom:20px;padding:12px 16px;font-size:14px}@media (width<=480px){.user-email{display:none}.dashboard-header{gap:8px;padding:12px 16px}.dashboard-header .brand{font-size:22px}.header-actions{gap:8px}}@media (width>=640px){.setup-main{padding:32px 24px}.speech-text{font-size:20px}.auth-card{padding:48px 40px}.brand{font-size:52px}}@media (width>=1024px){.scripts-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}
