*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh}@supports (padding-bottom: env(safe-area-inset-bottom)){.gtab--mobile,.drawer{padding-bottom:env(safe-area-inset-bottom)}.modal-overlay{padding:0 env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}}:root{--brand: #D97757;--brand-light: #FEF3EE;--brand-lighter: #D97757;--brand-bg: #FFF7F4;--accent: #D97757;--accent-dark: #C46648;--accent-light: #FEF3EE;--accent-bg: #FFF7F4;--success: #22C55E;--success-bg: #F0FDF4;--warning: #F59E0B;--warning-bg: #FFFBEB;--error: #EF4444;--error-bg: #FEF2F2;--info: #3B82F6;--info-bg: #EFF6FF;--strength-lime: #84CC16;--wechat-green: #07C160;--prog-untrained: #9CA3AF;--prog-struggling: #F59E0B;--prog-remembered: #D97706;--prog-fluent: #22C55E;--bg: #FAFAFA;--surface: #FFFFFF;--fg: #1F2937;--fg-secondary: #6B7280;--fg-tertiary: #9CA3AF;--border: #E5E7EB;--border-light: #F3F4F6;--divider: #F3F4F6;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--bp-mobile: 768px;--bp-tablet: 1024px;--bp-desktop: 1025px;--font-display: -apple-system, "SF Pro Display", BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-body: -apple-system, "SF Pro Text", BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-mono: "JetBrains Mono", "IBM Plex Mono", "SF Mono", Menlo, monospace;--radius-card: 12px;--radius-btn: 10px;--radius-pill: 20px;--radius-input: 10px;--radius-modal: 16px;--shadow-card: 0 1px 3px rgba(0,0,0,.06);--shadow-modal: 0 8px 30px rgba(0,0,0,.12)}.text-h1{font:700 28px/1.2 var(--font-display);color:var(--fg);margin:0;letter-spacing:-.02em}.text-h2{font:700 20px/1.4 var(--font-display);color:var(--fg);margin:0;letter-spacing:-.01em}.text-h3{font:600 18px/1.4 var(--font-display);color:var(--fg);margin:0;letter-spacing:-.01em}.text-body{font:400 15px/1.65 var(--font-body);color:var(--fg)}.text-caption{font:400 13px/1.5 var(--font-body);color:var(--fg-secondary)}.text-overline{font:600 12px/1.5 var(--font-body);color:var(--fg-tertiary);text-transform:uppercase;letter-spacing:.06em}.tabular-nums{font-variant-numeric:tabular-nums;font-family:var(--font-mono)}@media (max-width: 767px){.text-h1{font-size:24px}.text-h2{font-size:18px}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-card)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;height:48px;padding:0 24px;color:#fff;font:600 16px/1 var(--font-body);background:var(--accent);border:none;border-radius:var(--radius-btn);cursor:pointer;transition:filter .15s,transform .15s}.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;height:48px;padding:0 24px;color:var(--fg);font:500 16px/1 var(--font-body);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-btn);cursor:pointer;transition:background .15s}.btn-secondary:hover{background:var(--bg)}.pill{display:inline-flex;align-items:center;height:32px;padding:0 14px;font:500 13px/1 var(--font-body);background:transparent;border:1px solid var(--border);border-radius:var(--radius-pill);cursor:pointer;transition:all .15s;white-space:nowrap;color:var(--fg-secondary)}.pill.active{color:#fff;background:var(--fg);border-color:var(--fg)}.pill--brand{background:var(--brand-light);color:var(--brand);border-color:transparent}.pill--brand.active{background:var(--accent);border-color:var(--accent)}.progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-bar__fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.progress-label{font-size:13px;color:var(--fg-secondary);font-variant-numeric:tabular-nums}.progress-label strong{color:var(--accent);font-weight:600}.status-dot{display:inline-block;width:6px;height:6px;border-radius:50%}.status-dot--untrained{background:var(--prog-untrained)}.status-dot--struggling{background:var(--prog-struggling)}.status-dot--remembered{background:var(--prog-remembered)}.status-dot--fluent{background:var(--prog-fluent)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 24px;text-align:center}.empty-state__icon{width:48px;height:48px;color:var(--fg-tertiary)}.empty-state__title{font-size:18px;font-weight:600;color:var(--fg-secondary)}.empty-state__text{font-size:15px;color:var(--fg-tertiary);line-height:1.5;max-width:280px}.error-page{display:flex;flex-direction:column;align-items:center;gap:12px;padding:64px 24px;text-align:center;min-height:400px;justify-content:center}.error-page__illustration{color:var(--fg-tertiary);margin-bottom:8px}.error-page__title{font:700 22px/1.3 var(--font-display);color:var(--fg);margin:0}.error-page__desc{font:400 15px/1.6 var(--font-body);color:var(--fg-secondary);margin:0;max-width:320px}.error-page__actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;justify-content:center}.hide-scrollbar{scrollbar-width:none}.hide-scrollbar::-webkit-scrollbar{display:none}@media (max-width: 767px){.hide-on-mobile{display:none!important}.show-on-mobile{display:block!important}}@media (min-width: 768px){.hide-on-desktop{display:none!important}.show-on-desktop{display:block!important}}.spinner{display:inline-block;width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}.spinner--sm{width:18px;height:18px;border-width:2px}.spinner--lg{width:48px;height:48px;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);padding:4px 10px;background:var(--fg);color:#fff;font-size:12px;line-height:1.5;white-space:nowrap;border-radius:6px;pointer-events:none;opacity:0;transition:opacity .15s;z-index:300}[data-tooltip]:hover:after{opacity:1}.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:var(--radius-card);font-size:14px;line-height:1.5;border:1px solid}.alert--info{background:#f0fdfa;border-color:#99f6e4;color:#155e75}.alert--success{background:var(--success-bg);border-color:#bbf7d0;color:#166534}.alert--warning{background:var(--warning-bg);border-color:#fde68a;color:#92400e}.alert--error{background:var(--error-bg);border-color:#fecaca;color:#991b1b}.alert__icon{flex-shrink:0;font-size:16px;margin-top:1px}.alert__body{flex:1}.alert__title{font-weight:600;margin-bottom:2px}.alert__desc{font-size:13px;opacity:.85}.badge{position:relative;display:inline-flex}.badge-dot{position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--error);border:2px solid var(--surface)}.badge-count{position:absolute;top:-6px;right:-8px;min-width:16px;height:16px;border-radius:8px;background:var(--error);color:#fff;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1;border:2px solid var(--surface)}.drawer-overlay{position:fixed;inset:0;background:#0006;z-index:1000;animation:fadeIn .2s ease}.drawer{position:fixed;top:0;right:0;bottom:0;width:400px;max-width:min(400px,92vw);background:var(--surface);box-shadow:var(--shadow-modal);z-index:1001;display:flex;flex-direction:column;animation:slideInRight .25s ease}.drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);flex-shrink:0}.drawer__title{font:600 18px/1.4 var(--font-display);color:var(--fg)}.drawer__close{width:32px;height:32px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--fg-secondary);border-radius:8px;transition:background .15s}.drawer__close:hover{background:var(--border-light)}.drawer__body{flex:1;overflow-y:auto;padding:var(--space-lg)}.drawer__footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);flex-shrink:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@media (max-width: 767px){.drawer{width:100%;max-width:100%}}@media (max-width: 767px){.hide-mobile{display:none!important}}.accordion{border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.accordion-item{border-bottom:1px solid var(--border-light)}.accordion-item:last-child{border-bottom:none}.accordion-header{width:100%;padding:14px 16px;background:none;border:none;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font:500 15px/1.4 var(--font-body);color:var(--fg);transition:background .15s}.accordion-header:hover{background:var(--border-light)}.accordion-arrow{transition:transform .2s;color:var(--fg-tertiary)}.accordion-item.is-open .accordion-arrow{transform:rotate(180deg)}.accordion-body{padding:0 16px 14px}.slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:var(--border);border-radius:2px;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 1px 4px #00000026;transition:transform .15s}.slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;border:none;background:var(--accent);cursor:pointer}.select-wrap{position:relative;display:inline-block;min-width:120px}.select-trigger{display:flex;align-items:center;justify-content:space-between;height:40px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius-input);background:var(--surface);cursor:pointer;font:400 14px/1 var(--font-body);color:var(--fg);transition:border-color .15s;width:100%}.select-trigger:hover{border-color:var(--fg-tertiary)}.select-trigger.is-open{border-color:var(--accent)}.select-trigger__arrow{color:var(--fg-tertiary);transition:transform .15s;font-size:12px}.select-trigger.is-open .select-trigger__arrow{transform:rotate(180deg)}.select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-modal);z-index:200;max-height:240px;overflow-y:auto;padding:4px}.select-option{padding:8px 12px;border-radius:6px;cursor:pointer;font:400 14px/1.4 var(--font-body);color:var(--fg);transition:background .1s}.select-option:hover{background:var(--border-light)}.select-option.is-selected{background:var(--accent-bg);color:var(--accent);font-weight:500}.dropdown-menu{position:absolute;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-modal);z-index:200;padding:4px;min-width:160px}.dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;cursor:pointer;font:400 14px/1.4 var(--font-body);color:var(--fg);border:none;background:none;width:100%;text-align:start;transition:background .1s}.dropdown-item:hover{background:var(--border-light)}.dropdown-item--danger{color:var(--error)}.dropdown-item--danger:hover{background:var(--error-bg)}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;padding:10px 12px;font-weight:600;color:var(--fg-secondary);border-bottom:2px solid var(--border);font-size:13px;white-space:nowrap}.table td{padding:10px 12px;border-bottom:1px solid var(--border-light);color:var(--fg)}.table tr:hover td{background:var(--border-light)}.stepper{display:flex;align-items:center}.stepper-step{display:flex;align-items:center;gap:8px;font:400 14px/1 var(--font-body);color:var(--fg-tertiary)}.stepper-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:2px solid var(--border);color:var(--fg-tertiary);background:var(--surface);transition:all .2s}.stepper-step.is-active .stepper-dot,.stepper-step.is-done .stepper-dot{border-color:var(--accent);background:var(--accent);color:#fff}.stepper-step.is-done{color:var(--fg)}.stepper-line{flex:1;height:2px;background:var(--border);margin:0 8px;min-width:24px}.stepper-line.is-done{background:var(--accent)}.popover{position:absolute;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-modal);padding:var(--space-md)}html{height:100%;overflow:hidden}#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden;text-align:initial}body{height:100%;margin:0;padding:0;overflow:hidden;font-family:var(--font-body);-webkit-font-smoothing:antialiased}.app-shell{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;background:var(--bg)}.app-shell__body{display:flex;flex:1;overflow:hidden}.app-shell__main{flex:1;display:flex;flex-direction:column;overflow-y:auto}.app-shell__page{flex:1;padding:var(--space-lg);display:flex;flex-direction:column;padding-bottom:calc(var(--space-lg) + 50px + env(safe-area-inset-bottom,0px))}.app-shell__page--no-pad{padding:0!important;max-width:none!important;margin:0!important;overflow:hidden!important}.app-shell--no-nav .app-shell__main{margin-left:0!important}.app-shell--no-nav .app-shell__page{padding-bottom:var(--space-xl);max-width:none}.gtab--mobile{display:none}.gtab--desktop{display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;width:220px;background:var(--surface);border-right:1px solid var(--border);z-index:100}.gtab__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border)}.gtab__logo{font:700 20px/1 var(--font-display);color:var(--brand);letter-spacing:-.02em;cursor:pointer}.gtab__logo span{color:var(--fg)}.gtab__nav{flex:1;padding:12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.gtab__footer{border-top:1px solid var(--border);padding:12px}.gtab__item{display:flex;align-items:center;gap:12px;width:100%;padding:12px;background:none;border:none;border-radius:10px;font:500 14px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;transition:all .15s;text-align:start}.gtab__item:hover{background:var(--border-light)}.gtab__item.is-active{background:var(--accent-bg);color:var(--accent);font-weight:600}.gtab__icon{font-size:18px;display:grid;place-items:center;flex-shrink:0;width:22px;height:22px}.gtab__label{white-space:nowrap}@media (max-width: 767px){.gtab--desktop{display:none}.gtab--mobile{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(50px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--surface);border-top:1px solid var(--border);z-index:100}.gtab--mobile .gtab__item{flex:1;flex-direction:column;gap:2px;padding:6px 0;font-size:10px;font-weight:600}.gtab--mobile .gtab__icon{font-size:20px}.script-card__desc{-webkit-line-clamp:1}.script-card__img{height:72px}.script-card__char{font-size:28px}}@media (min-width: 768px) and (max-width: 1199px){.app-shell__main{margin-left:72px}.gtab--desktop{width:72px}.gtab__header{flex-direction:column;gap:8px;padding:var(--space-lg) 8px}.gtab__logo{width:32px;height:32px;background:var(--brand);color:var(--surface);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.gtab__logo span{display:none}.gtab__nav{padding:12px 8px}.gtab__item{flex-direction:column;justify-content:center;gap:4px;padding:10px 4px;text-align:center}.gtab__label{display:block;font-size:10px}.gtab__footer{padding:8px}.app-shell__page{padding:var(--space-xl);padding-bottom:var(--space-xl)}}@media (min-width: 1200px){.app-shell__main{margin-left:220px}.app-shell__page{padding:var(--space-2xl);max-width:960px;margin:0 auto}}.dashboard,.product-page{max-width:640px}.dashboard__greeting{margin-bottom:28px}.dashboard__greeting-row{display:flex;justify-content:space-between;align-items:flex-start}.dashboard__greeting-title{font:700 26px/1.2 var(--font-display);color:var(--fg);letter-spacing:-.02em}.dashboard__greeting-sub{font-size:14px;color:var(--fg-secondary);margin-top:4px}.dashboard__greeting-date{font-size:13px;color:var(--fg-tertiary);white-space:nowrap;padding-top:6px;font-variant-numeric:tabular-nums}.dashboard__hero-row{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}.dashboard__hero{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;box-shadow:var(--shadow-card);cursor:pointer;transition:box-shadow .2s,transform .2s}.dashboard__hero:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-1px)}.dashboard__hero-accent{width:4px;flex-shrink:0}.dashboard__hero-body{flex:1;padding:20px 24px}.dashboard__hero--empty{cursor:default;text-align:center;padding:48px 24px;flex-direction:column;align-items:center;gap:12px}.dashboard__hero--empty:hover{box-shadow:var(--shadow-card);transform:none}.dashboard__hero-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dashboard__hero-label{display:flex;align-items:center;gap:6px;font:600 12px/1.5 var(--font-body);color:var(--fg-tertiary);text-transform:uppercase;letter-spacing:.06em}.dashboard__hero-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.dashboard__hero-tag{font-size:11px;font-weight:600;padding:2px 10px;border-radius:20px;background:var(--accent-bg);color:var(--accent)}.dashboard__hero-title{font:700 22px/1.3 var(--font-display);color:var(--fg);margin-bottom:4px;letter-spacing:-.02em}.dashboard__hero-meta{font-size:13px;color:var(--fg-secondary);margin-bottom:14px;line-height:1.4}.dashboard__hero-chars{display:flex;align-items:center;gap:0;margin-bottom:16px}.dashboard__hero-char{width:28px;height:28px;border-radius:50%;border:2px solid var(--surface);background:var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--fg-secondary);margin-right:-6px;position:relative}.dashboard__hero-char:first-child{background:var(--accent);color:var(--surface)}.dashboard__hero-char-count{margin-left:12px;font-size:12px;color:var(--fg-tertiary)}.dashboard__hero-progress{margin-bottom:18px}.dashboard__hero-progress .progress-bar{margin-bottom:6px}.dashboard__hero-progress-label{font-size:13px;color:var(--fg-secondary)}.dashboard__hero-progress-label strong{color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}.dashboard__btn-row{display:flex;gap:10px}.dashboard__btn-row .btn-primary{flex:2}.dashboard__btn-row .btn-secondary{flex:1}.dashboard__hero-empty-icon{width:56px;height:56px;border-radius:16px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:4px}.dashboard__hero-empty-title{font:600 18px/1.3 var(--font-display);color:var(--fg)}.dashboard__hero-empty-desc{font-size:14px;color:var(--fg-secondary);margin-bottom:8px}.dashboard__stats-col{display:none;flex-direction:column;gap:10px;width:200px;flex-shrink:0}.dashboard__stats-row{display:flex;gap:12px}.dashboard__stat-card{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:14px 16px;text-align:center}.dashboard__stat-value{font:700 26px/1 var(--font-display);font-variant-numeric:tabular-nums}.dashboard__stat-unit{font-size:16px}.dashboard__stat-label{font-size:11px;color:var(--fg-secondary);margin-top:2px}.dashboard__section{margin-bottom:32px}.dashboard__section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}.dashboard__section-title{font:600 18px/1.3 var(--font-display);color:var(--fg);letter-spacing:-.01em}.dashboard__section-link{display:flex;align-items:center;gap:4px;border:none;background:transparent;font:500 13px/1.4 var(--font-body);color:var(--accent);cursor:pointer;transition:opacity .15s;padding:0}.dashboard__section-link:hover{opacity:.75}.dashboard__recent-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.dashboard__recent-scroll::-webkit-scrollbar{display:none}.dashboard__recent-card{flex-shrink:0;width:180px;display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;box-shadow:var(--shadow-card);cursor:pointer;transition:box-shadow .15s,transform .15s}.dashboard__recent-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.dashboard__recent-card-stripe{width:3px;flex-shrink:0}.dashboard__recent-card-body{flex:1;padding:14px 16px}.dashboard__recent-card-tag{font-size:10px;font-weight:600;color:var(--accent);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.dashboard__recent-card-title{font:600 14px/1.3 var(--font-display);color:var(--fg);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard__recent-card-meta{font-size:12px;color:var(--fg-tertiary);margin-bottom:10px}.dashboard__recent-card-progress{display:flex;align-items:center;gap:8px}.dashboard__recent-card-progress .progress-bar{flex:1;margin:0}.dashboard__recent-card-progress span{font-size:11px;font-weight:600;color:var(--fg-tertiary);font-variant-numeric:tabular-nums;min-width:30px;text-align:right}.dashboard__quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dashboard__quick-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);cursor:pointer;transition:box-shadow .2s}.dashboard__quick-card:hover{box-shadow:0 2px 8px #0000000f}.dashboard__quick-card-icon{width:44px;height:44px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.dashboard__quick-card-icon--accent{background:var(--accent-bg);color:var(--accent)}.dashboard__quick-card-icon--success{background:var(--success-bg);color:var(--success)}.dashboard__quick-card-icon--info{background:var(--info-bg);color:var(--info)}.dashboard__quick-card-title{font:600 14px/1.3 var(--font-display)}.dashboard__quick-card-desc{font-size:12px;color:var(--fg-tertiary);margin-top:2px}.dashboard__collab-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);cursor:pointer;transition:box-shadow .2s}.dashboard__collab-card+.dashboard__collab-card{margin-top:10px}.dashboard__collab-card:hover{box-shadow:0 2px 8px #0000000f}.dashboard__collab-icon{width:40px;height:40px;border-radius:10px;background:var(--success-bg);color:var(--success);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard__collab-info{flex:1;min-width:0}.dashboard__collab-title{font:600 15px/1.3 var(--font-display)}.dashboard__collab-meta{font-size:12px;color:var(--fg-secondary);margin-top:2px}.dashboard__collab-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:var(--accent);color:var(--surface);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}@media (min-width: 768px){.dashboard__greeting-title{font-size:30px}.dashboard__hero-title{font-size:24px}.dashboard__hero-row{flex-direction:row;gap:20px}.dashboard__hero-row>.dashboard__hero{margin-bottom:0;flex:1}.dashboard__stats-col{display:flex}.dashboard__stat-card{padding:14px 16px}.dashboard__recent-scroll{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;overflow-x:visible;padding-bottom:0}.dashboard__recent-card{width:auto;flex-shrink:initial}.dashboard__recent-card-body{padding:14px 16px}.dashboard__quick-grid{grid-template-columns:1fr 1fr}}@media (min-width: 1200px){.dashboard__hero-body{padding:24px 28px}.dashboard__stat-value{font-size:28px}}.script-list-page,.stage-list-page{max-width:640px}.script-search{position:relative;margin-bottom:12px}.script-search__input{width:100%;height:44px;border:1px solid var(--border);border-radius:var(--radius-input);padding:0 16px 0 40px;font:400 15px/1 var(--font-body);color:var(--fg);background:var(--surface);outline:none;transition:border-color .15s}.script-search__input:focus{border-color:var(--accent)}.script-search__input::placeholder{color:var(--fg-tertiary)}.script-search__icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--fg-tertiary)}.script-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.script-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;cursor:pointer;transition:box-shadow .2s,transform .15s}.script-card:hover{box-shadow:0 4px 16px #00000012;transform:translateY(-1px)}.script-card:active{transform:translateY(0)}.script-card__img{height:88px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.script-card__cover{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:1}.script-card__char{font:900 36px/1 var(--font-display);opacity:.7;position:relative;z-index:1}.script-card__img:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40px;background:linear-gradient(transparent,var(--surface));z-index:2}.script-card__progress-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--border-light);z-index:3}.script-card__progress-fill{height:100%;border-radius:0 2px 2px 0;transition:width .3s}.script-card__body{padding:12px 14px 14px}.script-card__title{font:700 16px/1.3 var(--font-display);margin-bottom:4px;display:flex;align-items:center;gap:6px}.script-card__desc{font-size:12px;line-height:1.4;color:var(--fg-tertiary);margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.script-card__tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}.script-card__tag{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;background:var(--border-light);color:var(--fg-tertiary);white-space:nowrap}.script-card__tag--beginner{color:var(--success);background:var(--success-bg, rgba(34,197,94,.1))}.script-card__tag--intermediate{color:var(--warning);background:var(--warning-bg, rgba(245,158,11,.1))}.script-card__tag--advanced{color:var(--error);background:var(--error-bg, rgba(239,68,68,.1))}.script-card__struct{font-size:9px;font-weight:600;padding:2px 5px;border-radius:3px;background:var(--border-light);color:var(--fg-tertiary)}.script-card__meta{font-size:12px;color:var(--fg-tertiary);margin-bottom:8px;display:flex;align-items:center;gap:6px}.script-card__stats{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.script-card__stat{display:flex;align-items:center;gap:3px;font-size:11px;color:var(--fg-secondary)}.script-card__stat strong{font-weight:700;letter-spacing:-.02em}.script-card__stat--accent strong{color:var(--accent)}.script-card__stat svg{width:11px;height:11px;color:var(--fg-tertiary);flex-shrink:0}.script-card__stat--date{color:var(--fg-tertiary)}.script-card__stat--avatars{margin-left:auto}.script-card__avatars{display:flex}.script-card__avatar{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;color:var(--surface);margin-left:-6px;border:2px solid var(--surface);position:relative}.script-card__avatar:first-child{margin-left:0}.script-card__avatar-more{background:var(--border-light);color:var(--fg-tertiary);font-size:8px;font-weight:600}.script-card.archived{opacity:.55}.script-card.archived .script-card__title{text-decoration:line-through;text-decoration-color:var(--fg-tertiary)}.archived-badge{font-size:10px;font-weight:600;padding:2px 6px;background:var(--border-light);border-radius:4px;color:var(--fg-tertiary)}.script-fab{position:fixed;bottom:100px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--accent);color:var(--surface);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px color-mix(in srgb,var(--accent) 40%,transparent);transition:transform .15s,filter .15s;z-index:50}.script-fab:hover{transform:scale(1.08);filter:brightness(1.1)}@media (min-width: 768px){.script-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 479px){.script-grid{grid-template-columns:1fr}}.script-create{max-width:640px}.create-header{margin-bottom:24px}.create-title{font:700 24px/1.2 var(--font-display);margin-bottom:4px}.create-desc{font-size:14px;color:var(--fg-secondary)}.create-stepper{display:flex;align-items:center;margin-bottom:24px}.step{display:flex;align-items:center;gap:8px;font:400 14px/1 var(--font-body);color:var(--fg-tertiary)}.step-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:2px solid var(--border);color:var(--fg-tertiary);background:var(--surface)}.step.active .step-dot,.step.done .step-dot{border-color:var(--accent);background:var(--accent);color:var(--surface)}.step.done{color:var(--fg)}.step-line{flex:1;height:2px;background:var(--border);margin:0 8px;min-width:24px}.step-line.done{background:var(--accent)}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-card);padding:48px 24px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.upload-zone:hover{border-color:var(--accent);background:var(--accent-bg)}.upload-zone__icon{width:48px;height:48px;color:var(--fg-tertiary);margin:0 auto 12px}.upload-zone__title{font:600 16px/1.3 var(--font-display);margin-bottom:4px}.upload-zone__desc{font-size:13px;color:var(--fg-tertiary)}.explore-grid{display:grid;grid-template-columns:1fr;gap:12px}@media (min-width: 480px){.explore-grid{grid-template-columns:1fr 1fr}}.explore-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;cursor:pointer;transition:box-shadow .2s}.explore-card:hover{box-shadow:0 4px 16px #00000012}.explore-card__img{height:100px;background:var(--border-light);display:flex;align-items:center;justify-content:center;color:var(--fg-tertiary);font-size:28px;font-weight:700}.explore-card__body{padding:12px 14px}.explore-card__tag{font-size:10px;font-weight:600;color:var(--accent);margin-bottom:4px}.explore-card__title{font:600 14px/1.3 var(--font-display);margin-bottom:2px}.explore-card__meta{font-size:12px;color:var(--fg-tertiary)}@media (min-width: 768px){.explore-grid{grid-template-columns:repeat(3,1fr)}}.script-item{display:flex;align-items:center;gap:var(--space-md);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-md);cursor:pointer;transition:box-shadow .15s,transform .15s;box-shadow:var(--shadow-card);position:relative}.script-item:hover{box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.script-item__icon{width:48px;height:48px;border-radius:10px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:22px;color:var(--accent)}.script-item__info{flex:1;min-width:0}.script-item__title{font-size:16px;font-weight:600;color:var(--fg);margin-bottom:2px}.script-item__meta{font-size:13px;color:var(--fg-tertiary)}.script-item__progress{flex-shrink:0;text-align:right}.script-item__progress .progress-bar{width:60px;margin-bottom:4px}.script-item__progress .progress-label{font-size:13px;color:var(--fg-secondary)}.script-item__progress .progress-label strong{color:var(--accent);font-weight:600}.script-item__actions{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;gap:4px;opacity:0;transition:opacity .15s}.script-item:hover .script-item__actions{opacity:1}.script-item__actions button{width:30px;height:30px;border:1px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--fg-tertiary);transition:all .15s}.script-item__actions button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.script-item__actions button svg{width:14px;height:14px}.script-item.archived{opacity:.55;background:var(--bg)}.script-item.archived .script-item__title{text-decoration:line-through;text-decoration-color:var(--fg-tertiary)}.script-item.archived .script-item__progress{display:none}.script-detail{max-width:640px}.recording-entry{padding:var(--space-md) 0}.recording-entry__card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);cursor:pointer;transition:transform .15s,box-shadow .15s}.recording-entry__card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.recording-entry__icon{width:48px;height:48px;border-radius:14px;background:var(--accent-bg);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}.recording-entry__info{flex:1;min-width:0}.recording-entry__title{font-size:15px;font-weight:600;color:var(--fg);margin-bottom:2px}.recording-entry__desc{font-size:13px;color:var(--fg-tertiary)}.recording-entry__arrow{color:var(--fg-tertiary);flex-shrink:0}.vc-grid{display:grid;grid-template-columns:1fr;gap:12px}@media (min-width: 640px){.vc-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 960px){.vc-grid{grid-template-columns:repeat(3,1fr)}}.vc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;cursor:pointer;transition:box-shadow .15s;position:relative}.vc-card:hover{box-shadow:0 4px 16px #00000012}.vc-card:active{box-shadow:0 1px 4px #0000000a}.vc-card-top{display:flex;gap:12px;padding:14px 14px 0}.vc-model{width:56px;height:72px;border-radius:10px;flex-shrink:0;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}.vc-model-sil{position:absolute;inset:0;opacity:.18;display:flex;align-items:center;justify-content:center}.vc-model-sil svg{width:40px;height:40px}.vc-model-gender{position:absolute;top:4px;right:4px;width:16px;height:16px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center}.vc-model-gender svg{width:10px;height:10px;color:#fffc}.vc-model-char{font:900 24px/1 var(--font-display);color:#fff;position:relative;z-index:1;text-shadow:0 2px 4px rgba(0,0,0,.2);margin-bottom:8px}.vc-info{flex:1;min-width:0}.vc-name{font:700 15px/1.3 var(--font-display);display:flex;align-items:center;gap:6px;margin-bottom:2px}.vc-name .char-status-dot{margin-right:0}.vc-voice-name{font:500 12px/1.4 var(--font-body);color:var(--fg-secondary);margin-bottom:6px;display:flex;align-items:center;gap:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vc-voice-name svg{width:12px;height:12px;color:var(--accent);flex-shrink:0}.vc-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.vc-tag{font-size:10px;padding:2px 7px;border-radius:4px;font-weight:500}.vc-tag-tone{background:var(--success-bg);color:var(--success)}.vc-tag-age{background:var(--brand-bg);color:var(--info)}.vc-tag-speed{background:var(--warning-bg);color:var(--warning)}.vc-tag-gender{background:var(--brand-light);color:var(--fg)}.vc-match{display:flex;align-items:center;gap:8px}.vc-match-label{font:500 11px/1 var(--font-body);color:var(--fg-tertiary);white-space:nowrap}.vc-match-track{flex:1;height:4px;border-radius:2px;background:var(--border-light);overflow:hidden;min-width:30px}.vc-match-fill{height:100%;border-radius:2px;transition:width .3s}.vc-match-pct{font:700 16px/1 var(--font-display);min-width:36px;text-align:right;letter-spacing:-.02em}.vc-desc{padding:6px 14px 0;font-size:12px;line-height:1.5;color:var(--fg-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vc-desc-role{color:var(--fg-tertiary);font-size:11px;margin-bottom:2px}.vc-wave{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 0;gap:8px}.vc-wave-bars{flex:1;display:flex;align-items:center;gap:1.5px;height:24px;padding:0 2px}.vc-wave-bars .b{width:3px;border-radius:1.5px;background:var(--border);transition:background .15s}.vc-card:hover .vc-wave-bars .b{background:var(--fg-tertiary)}.vc-play{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;flex-shrink:0;transition:all .15s}.vc-play:hover{border-color:var(--accent);background:var(--accent);color:#fff}.vc-play:hover svg{color:#fff}.vc-play svg{width:12px;height:12px;color:var(--fg-secondary);transition:color .15s;margin-left:1px}.vc-play.playing{border-color:var(--accent);background:var(--accent)}.vc-play.playing svg{color:#fff;margin-left:0}.vc-wave.playing .vc-wave-bars .b{background:var(--accent)!important;animation:wave-bar 1.2s ease-in-out infinite}.vc-reason{padding:6px 14px 4px}.vc-reason-label{font:600 11px/1 var(--font-body);color:var(--accent);margin-bottom:3px;display:flex;align-items:center;gap:4px}.vc-reason-label svg{width:12px;height:12px}.vc-reason-text{font-size:12px;color:var(--fg-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vc-bottom{display:flex;align-items:center;justify-content:space-between;padding:6px 14px 10px;gap:8px}.vc-emotions{display:flex;flex-wrap:wrap;gap:4px;flex:1;min-width:0}.vc-card .char-actions{position:absolute;top:6px;right:6px;display:flex;gap:2px;opacity:0;transition:opacity .15s}.vc-card:hover .char-actions{opacity:1}.vc-time{font:500 11px/1 var(--font-body);color:var(--fg-tertiary);white-space:nowrap}.rec-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.rec-panel-header__title{font:600 16px/1 var(--font-display);display:flex;align-items:center;gap:8px}.rec-panel-header__desc{font-size:12px;color:var(--fg-secondary);margin-top:4px}.rec-toggle{display:flex;align-items:center;gap:8px}.rec-toggle__label{font-size:12px;color:var(--fg-secondary)}.rec-toggle__btn{width:40px;height:22px;border-radius:11px;border:none;background:var(--border);cursor:pointer;position:relative;transition:background .15s}.rec-toggle__btn.active{background:var(--accent)}.rec-toggle__knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .15s}.rec-toggle__btn.active .rec-toggle__knob{transform:translate(18px)}.rec-char-filter{display:flex;flex-wrap:wrap;gap:6px;padding-bottom:12px}.rec-char-filter .pill{height:28px;padding:0 10px;font-size:12px;color:var(--fg-secondary)}.rec-char-filter .pill.active{color:#fff}.rec-scene-header{padding:6px 12px;background:var(--bg);border-radius:4px;display:flex;align-items:center;gap:8px;margin-bottom:4px}.rec-scene-header__name{font-size:12px;font-weight:600;color:var(--fg-secondary)}.rec-scene-header__count{font-size:10px;padding:0 6px;border:1px solid var(--border);border-radius:4px}.rec-line{border-radius:4px;margin-bottom:2px;padding:8px 12px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background .15s}.rec-line:hover{background:var(--border-light)}.rec-line--recording{background:var(--error-bg)}.rec-line--muted{opacity:.55}.rec-line__left{display:flex;align-items:flex-start;gap:8px;flex:1;min-width:0}.rec-line__dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}.rec-line__dot--done{background:var(--success)}.rec-line__dot--progress{background:var(--warning)}.rec-line__dot--none{background:var(--fg-tertiary)}.rec-line__speaker{font-size:12px;font-weight:600;color:var(--accent);flex-shrink:0}.rec-line--muted .rec-line__speaker{color:var(--fg-secondary);font-weight:500}.rec-line__text{font-size:14px;flex:1;min-width:0;line-height:1.5}.rec-line--muted .rec-line__text{color:var(--fg-secondary);font-style:italic}.rec-line__right{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:8px}.rec-line__badge{font-size:10px;padding:2px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:4px}.rec-line__badge--tts{background:var(--success-bg);color:var(--success)}.rec-line__badge--rec{background:var(--error-bg);color:var(--error)}.rec-line__btn{height:28px;padding:0 10px;border-radius:6px;border:1px solid var(--border);background:var(--surface);font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:all .15s}.rec-line__btn:hover,.rec-line__btn--rec{border-color:var(--accent);color:var(--accent)}.rec-line__btn--finish{border:none;background:var(--error);color:#fff}.rec-line--playing{background:var(--brand-bg);border-left:3px solid var(--accent)}.rec-takes{padding:4px 12px 12px 40px}.rec-takes__header{display:flex;gap:8px;align-items:center;margin-bottom:6px;font-size:12px;font-weight:600}.rec-take{padding:6px 0;display:flex;align-items:center;gap:8px}.rec-take__info{flex:1}.rec-take__head{display:flex;gap:4px;align-items:center;margin-bottom:4px}.rec-take__name{font-size:12px;font-weight:500}.rec-take__controls{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.rec-take__ctrl-btn{height:24px;padding:0 8px;border-radius:4px;border:1px solid var(--border);background:var(--surface);font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:3px}.rec-take__star{width:24px;height:24px;border:none;background:none;cursor:pointer;font-size:14px}.rec-take__delete{width:24px;height:24px;border:none;background:none;cursor:pointer;opacity:0;transition:opacity .15s,color .15s;color:var(--fg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:4px}.rec-take:hover .rec-take__delete{opacity:1}.rec-take__delete:hover{color:var(--error);background:var(--error-bg)}@media (hover: none){.rec-take__delete{opacity:.6}}.rec-add-take{height:28px;padding:0 12px;border-radius:6px;border:1px solid var(--accent);background:var(--surface);font-size:12px;cursor:pointer;color:var(--accent);display:inline-flex;align-items:center;gap:4px;margin-top:4px}.back-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.back-btn{width:36px;height:36px;border:1px solid var(--border);border-radius:10px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0;color:var(--fg-secondary)}.back-btn:hover{background:var(--bg)}.detail-header{margin-bottom:var(--space-lg);display:flex;gap:var(--space-md)}.detail-cover{width:72px;height:72px;border-radius:12px;object-fit:cover;flex-shrink:0}.detail-header__body{flex:1;min-width:0}.detail-title{font:700 24px/1.2 var(--font-display);color:var(--fg);letter-spacing:-.02em;margin-bottom:4px}.detail-meta{font-size:14px;color:var(--fg-secondary);margin-bottom:var(--space-md)}.detail-header-actions{display:flex;margin-left:auto;gap:4px;flex-shrink:0}.detail-header-actions__btn{width:32px;height:32px;padding:0;border:none;background:transparent;cursor:pointer;border-radius:8px;color:var(--fg-tertiary);transition:all .15s;display:flex;align-items:center;justify-content:center}.detail-header-actions__btn:hover{background:var(--accent);color:#fff}.detail-header-actions__btn--archive:hover{background:var(--error)}.detail-title-row{display:flex;align-items:center;gap:10px}.detail-stats{display:flex;gap:var(--space-lg)}.detail-stat{text-align:center}.detail-stat__value{font:700 24px/1 var(--font-display);color:var(--accent);letter-spacing:-.02em}.detail-stat__label{font-size:12px;color:var(--fg-tertiary);margin-top:2px}.detail-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:var(--space-md);flex-shrink:0}.detail-tab{padding:10px 16px;border:none;background:transparent;font:500 14px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;transition:color .15s;border-bottom:2px solid transparent;margin-bottom:-1px}.detail-tab.is-active{color:var(--accent);font-weight:600;border-bottom-color:var(--accent)}.detail-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:var(--space-md);flex-shrink:0}.toolbar-search{flex:1;height:36px;border:1px solid var(--border);border-radius:var(--radius-pill);padding:0 14px;font:400 13px/1 var(--font-body);color:var(--fg);background:var(--surface);outline:none;transition:border-color .15s}.toolbar-search:focus{border-color:var(--accent)}.toolbar-search::placeholder{color:var(--fg-tertiary)}.toolbar-btn{height:36px;padding:0 14px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface);font:500 13px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;transition:all .15s;white-space:nowrap;display:flex;align-items:center;gap:6px}.toolbar-btn:hover{border-color:var(--accent);color:var(--accent)}.toolbar-btn svg{width:14px;height:14px}.line-row{display:flex;align-items:flex-start;gap:12px;padding:4px 0;border-bottom:1px solid var(--border-light)}.line-row:last-child{border-bottom:none}.line-speaker{min-width:40px;font-size:13px;font-weight:600;color:var(--accent);flex-shrink:0;padding-top:2px}.line-speaker--other{color:var(--fg-secondary)}.line-text{font-size:15px;line-height:1.65;color:var(--fg);flex:1}.line-note{font-size:12px;color:var(--fg-secondary);margin-top:2px}.line-direction{text-align:left;background:var(--bg);border-radius:8px;padding:4px 16px;margin:0;border-bottom:1px solid var(--border-light);font-size:14px;font-style:italic;color:var(--fg-tertiary);line-height:1.65}.emo-inline{font-size:12px;font-weight:500;opacity:.7;font-style:normal}.line-row{position:relative}.line-row:hover{background:var(--border-light);border-radius:8px}.line-row:hover .line-actions{opacity:1}.line-actions{position:absolute;right:0;top:50%;transform:translateY(-50%);display:flex;gap:2px;opacity:0;transition:opacity .15s}.line-action-btn{width:28px;height:28px;border:none;border-radius:6px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--fg-tertiary);transition:all .15s}.line-action-btn:hover{background:var(--border);color:var(--fg)}.line-action-btn.delete:hover{background:var(--error-bg);color:var(--error)}.line-action-btn svg{width:14px;height:14px}.line-row{cursor:grab;touch-action:none}.line-row:active{cursor:grabbing}.line-row .line-actions{cursor:default}.line-row.dragging{opacity:.4;background:var(--accent-bg);border-radius:8px}.line-row--touch{touch-action:pan-y;cursor:default}.line-row--active{background:var(--surface);border-radius:8px;cursor:default;touch-action:auto}.line-row__content{display:flex;align-items:flex-start;gap:12px;flex:1}.line-mobile-actions{display:flex;align-items:center;gap:4px;padding:6px 4px;margin-top:2px;border-top:1px solid var(--border-light)}.drag-handle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;cursor:grab;touch-action:none;color:var(--fg-tertiary);border-radius:6px}.drag-handle:active{cursor:grabbing;background:var(--border-light)}@media (hover: hover) and (pointer: fine){.line-row--active{background:transparent}.line-mobile-actions{display:none}}.line-row.drag-over,.line-direction.drag-over{border-top:2px solid var(--accent);margin-top:-1px}.drag-placeholder{height:44px;background:var(--accent-bg);border:1px dashed var(--accent);border-radius:8px;margin:4px 0}.line-speaker[contenteditable=true]{outline:none;cursor:text;border-bottom:1px dashed var(--accent);min-width:40px}.line-text[contenteditable=true]{outline:1px solid var(--accent);outline-offset:2px;border-radius:4px;background:var(--surface);padding:4px 6px;cursor:text}.act-group{margin-bottom:8px}.act-header{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);cursor:pointer;transition:background .15s;margin-bottom:4px;user-select:none}.act-header:hover{background:var(--border-light)}.act-chevron{width:16px;height:16px;color:var(--fg-tertiary);transition:transform .2s;flex-shrink:0}.act-header.collapsed .act-chevron{transform:rotate(-90deg)}.act-title{font-size:14px;font-weight:600;color:var(--fg)}.act-count{font-size:12px;color:var(--fg-tertiary);margin-left:auto}.act-body{overflow:hidden}.act-body.collapsed{display:none}.scene-group{margin:4px 0}.scene-header{display:flex;align-items:center;gap:8px;padding:8px 12px 8px 28px;cursor:pointer;transition:background .15s;border-radius:8px;user-select:none}.scene-header:hover{background:var(--border-light)}.scene-chevron{width:14px;height:14px;color:var(--fg-tertiary);transition:transform .2s;flex-shrink:0}.scene-header.collapsed .scene-chevron{transform:rotate(-90deg)}.scene-title{font-size:13px;font-weight:500;color:var(--fg-secondary)}.scene-count{font-size:11px;color:var(--fg-tertiary);margin-left:auto}.scene-description{padding:0 12px 8px 28px;font-size:14px;line-height:1.6;color:var(--fg-tertiary);border-bottom:1px dashed var(--border);margin-bottom:4px;display:flex;align-items:flex-start;gap:6px}.scene-description:before{content:"";width:3px;min-height:12px;border-radius:2px;background:var(--fg-tertiary);opacity:.25;flex-shrink:0;margin-top:3px}.scene-lines{padding:0 0 0 28px}.scene-lines.collapsed{display:none}.scene-divider{display:flex;align-items:center;gap:10px;padding:14px 0 6px;margin-top:6px}.scene-divider:first-child{margin-top:0;padding-top:4px}.scene-divider__title{font:600 14px/1 var(--font-body);color:var(--fg);white-space:nowrap}.scene-divider__line{flex:1;height:1px;background:var(--border)}.scene-divider__edit{width:24px;height:24px;border:none;background:none;cursor:pointer;color:var(--fg-tertiary);display:flex;align-items:center;justify-content:center;border-radius:4px;padding:0;flex-shrink:0}.scene-divider__edit svg{width:14px;height:14px}.scene-divider__edit:hover{color:var(--accent);background:var(--accent-bg)}.scene-divider__desc{font-size:13px;color:var(--fg-tertiary);padding:0 0 4px;line-height:1.5}.add-line-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;border:1px dashed var(--border);border-radius:8px;background:transparent;cursor:pointer;font:500 13px/1 var(--font-body);color:var(--fg-tertiary);transition:all .15s;margin-top:4px}.add-line-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.add-line-btn svg{width:18px;height:18px}.add-scene-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px dashed var(--border);border-radius:8px;background:transparent;cursor:pointer;font:500 13px/1 var(--font-body);color:var(--fg-tertiary);transition:all .15s;margin:4px 0 4px 28px}.add-scene-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.add-scene-btn svg{width:14px;height:14px}.char-list{display:flex;flex-direction:column;gap:var(--space-md)}.char-item{position:relative;display:flex;align-items:center;gap:var(--space-md);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-md);transition:border-color .15s;flex-wrap:wrap}.char-avatar{width:44px;height:44px;border-radius:50%;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;font:700 16px/1 var(--font-display);color:var(--surface);flex-shrink:0}.char-info{flex:1}.char-name{font-size:16px;font-weight:600;color:var(--fg);margin-bottom:2px}.char-meta{font-size:13px;color:var(--fg-tertiary)}.char-row-top{display:flex;align-items:center;gap:var(--space-md);min-width:0;flex:1}.char-desc{font-size:13px;color:var(--fg-secondary);line-height:1.5;margin-top:6px}.char-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:3px}.char-badge{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:10px;background:var(--border-light);color:var(--fg);white-space:nowrap}.char-badge.role-badge{background:var(--brand-light);color:var(--fg)}.char-badge.lines-badge{background:var(--border-light);color:var(--fg-secondary)}.char-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px;vertical-align:middle}.char-status-dot.untrained{background:var(--prog-untrained)}.char-status-dot.struggling{background:var(--prog-struggling)}.char-status-dot.remembered{background:var(--prog-remembered)}.char-status-dot.fluent{background:var(--prog-fluent)}.char-actions{position:absolute;top:12px;right:12px;display:flex;gap:4px;opacity:0;transition:opacity .15s}.char-item:hover .char-actions{opacity:1}.char-actions button{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--fg-tertiary);transition:all .15s}.char-actions button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.char-actions button.delete:hover{border-color:var(--error);color:var(--error);background:var(--error-bg)}.char-actions button svg{width:14px;height:14px}.char-section{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-light);width:100%}.char-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-tertiary);margin-bottom:6px}.char-emotions{display:flex;flex-wrap:wrap;gap:4px}.char-emo-tag{font-size:12px;padding:3px 8px;border-radius:8px;font-weight:600;white-space:nowrap}.char-emo-tag.emo-calm{background:var(--border-light);color:var(--fg)}.char-emo-tag.emo-alert{background:var(--brand-bg);color:var(--fg)}.char-emo-tag.emo-strong{background:var(--error-bg);color:var(--error)}.char-emo-tag.emo-serious{background:var(--brand-light);color:var(--fg)}.char-emo-tag.emo-sad{background:var(--success-bg);color:var(--success)}.char-voice-row{display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-light)}.char-voice-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--surface);flex-shrink:0}.char-voice-info{flex:1;min-width:0}.char-voice-name{font-size:13px;font-weight:500;color:var(--fg)}.char-voice-tags{font-size:11px;color:var(--fg-tertiary);margin-top:1px}.char-voice-preview{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.char-voice-preview:hover{border-color:var(--accent);background:var(--accent-bg)}.char-voice-preview svg{width:14px;height:14px;color:var(--fg-secondary)}.char-voice-preview:hover svg{color:var(--accent)}.waveform{display:flex;align-items:center;gap:2px;height:16px}.waveform span{width:3px;border-radius:2px;background:var(--accent);animation:waveBar .8s ease-in-out infinite alternate}.waveform span:nth-child(1){height:6px;animation-delay:0s}.waveform span:nth-child(2){height:12px;animation-delay:.1s}.waveform span:nth-child(3){height:8px;animation-delay:.2s}.waveform span:nth-child(4){height:14px;animation-delay:.3s}.waveform span:nth-child(5){height:6px;animation-delay:.4s}@keyframes waveBar{0%{transform:scaleY(.3)}to{transform:scaleY(1)}}.add-char-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:52px;border:2px dashed var(--border);border-radius:var(--radius-card);background:transparent;font:500 15px/1 var(--font-body);color:var(--fg-tertiary);cursor:pointer;transition:all .15s}.add-char-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.add-char-btn svg{width:18px;height:18px}.char-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.char-toolbar-btn{height:32px;padding:0 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer;font:500 12px/1 var(--font-body);color:var(--fg-secondary);display:flex;align-items:center;gap:5px;transition:all .15s}.char-toolbar-btn:hover{border-color:var(--accent);color:var(--accent)}.char-toolbar-btn svg{width:14px;height:14px}.tts-gen-inline{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.tts-gen-inline__bar{flex:1;max-width:160px;height:4px;background:var(--border-light);border-radius:2px;overflow:hidden}.tts-gen-inline__fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.tts-gen-inline__text{font:500 11px/1 var(--font-body);color:var(--fg-secondary);white-space:nowrap}.tts-gen-inline--done{color:var(--success);font:500 12px/1 var(--font-body);gap:4px}.tts-gen-inline--error{color:var(--error);font:500 12px/1 var(--font-body);gap:8px;align-items:center}.tts-gen-inline__retry{height:22px;padding:0 10px;border:1px solid var(--error);border-radius:6px;background:transparent;font:500 11px/1 var(--font-body);color:var(--error);cursor:pointer;transition:all .15s}.tts-gen-inline__retry:hover{background:var(--error);color:#fff}.tts-gen-inline__stop{height:22px;padding:0 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);font:500 11px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.tts-gen-inline__stop:hover{border-color:var(--error);color:var(--error)}.char-item.editing{border-color:var(--accent);background:var(--accent-bg)}.char-edit-field{width:100%}.char-edit-input{width:100%;border:none;border-bottom:1px solid var(--border);background:transparent;font:500 14px/1 var(--font-body);color:var(--fg);padding:4px 0;outline:none}.char-edit-input:focus{border-bottom-color:var(--accent)}.char-edit-input.name{font-size:16px;font-weight:600}.char-edit-input.role{font-size:12px}.char-edit-textarea{width:100%;border:1px solid var(--border);border-radius:8px;background:var(--surface);font:13px/1.5 var(--font-body);color:var(--fg);padding:8px 10px;outline:none;resize:vertical;min-height:40px;margin-top:6px}.char-edit-textarea:focus{border-color:var(--accent)}.char-color-row{display:flex;gap:6px;margin-top:8px;align-items:center}.char-color-label{font-size:12px;color:var(--fg-tertiary);margin-right:4px}.char-color-dot{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:border-color .15s,transform .15s}.char-color-dot:hover{transform:scale(1.15)}.char-color-dot.active{border-color:var(--fg)}.char-regen-btn{display:flex;align-items:center;justify-content:center;gap:6px;height:36px;border:1px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer;font:500 12px/1 var(--font-body);color:var(--fg-secondary);transition:all .15s;width:100%;margin-top:6px}.char-regen-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.char-regen-btn svg{width:14px;height:14px}.char-regen-btn.regen-active{border-color:var(--success);color:var(--success);background:var(--success-bg)}.audio-list{display:flex;flex-direction:column;gap:12px}.audio-item{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:14px 16px}.audio-play{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;font-size:16px;color:var(--fg-secondary)}.audio-play:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.audio-info{flex:1}.audio-name{font-size:14px;font-weight:500;color:var(--fg)}.audio-duration{font-size:12px;color:var(--fg-tertiary);margin-top:2px}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-bottom:var(--space-lg)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-md);text-align:center}.stat-card__value{font:700 24px/1 var(--font-mono);color:var(--fg)}.stat-card__label{font-size:12px;color:var(--fg-tertiary);margin-top:4px}.stat-bar-group{display:flex;flex-direction:column;gap:12px}.stat-bar-row{display:flex;align-items:center;gap:12px}.stat-bar-label{font-size:13px;color:var(--fg-secondary);min-width:60px}.stat-bar-track{flex:1;height:6px;background:var(--border-light);border-radius:3px}.stat-bar-fill{height:100%;border-radius:3px;transition:width .3s}.stat-bar-value{font-size:13px;color:var(--fg-secondary);min-width:32px;text-align:right}.detail-actions{display:none}.detail-actions-bar{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-md)}.detail-actions-bar__btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 16px;border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--surface);font:500 13px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.detail-actions-bar__btn:hover{border-color:var(--accent);color:var(--accent)}.detail-actions-bar__btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.detail-actions-bar__btn--primary:hover{opacity:.85}.text-danger-link{background:none;border:none;cursor:pointer;padding:4px 8px;font-size:12px;color:var(--error);text-decoration:underline;text-underline-offset:2px}.text-danger-link:hover{opacity:.75}.confirm-overlay{position:fixed;inset:0;z-index:300;background:#0006;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}.confirm-overlay.show{opacity:1;pointer-events:auto}.confirm-box{background:var(--surface);border-radius:16px;padding:28px 24px 20px;max-width:340px;width:90%;box-shadow:0 20px 60px #00000026}.confirm-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.confirm-icon.warn{background:var(--warning-bg);color:var(--warning)}.confirm-icon.danger{background:var(--error-bg);color:var(--error)}.confirm-icon svg{width:24px;height:24px}.confirm-title{font:600 18px/1 var(--font-display);margin-bottom:8px;color:var(--fg)}.confirm-msg{font-size:14px;color:var(--fg-secondary);line-height:1.5;margin-bottom:24px}.confirm-msg strong{color:var(--fg);font-weight:500}.confirm-actions{display:flex;gap:10px}.confirm-actions button{flex:1;height:44px;border-radius:10px;border:none;font:600 15px/1 var(--font-body);cursor:pointer;transition:filter .15s}.confirm-actions button:hover{filter:brightness(.95)}.confirm-cancel{background:var(--bg);color:var(--fg);border:1px solid var(--border)!important}.confirm-ok{background:var(--accent);color:var(--surface)}.confirm-ok.danger{background:var(--error)}.voice-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(4px);z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}.voice-overlay.open{opacity:1;pointer-events:auto}.voice-modal{background:var(--surface);border-radius:16px;width:90%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000026;overflow:hidden}.voice-modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.voice-modal-title{font-size:18px;font-weight:600;color:var(--fg)}.voice-modal-hint{font-size:13px;color:var(--fg-tertiary);margin-top:4px}.voice-modal-filters{display:flex;gap:6px;padding:12px 24px;border-bottom:1px solid var(--border-light);flex-shrink:0;flex-wrap:wrap}.voice-filter-pill{height:28px;padding:0 12px;border-radius:14px;border:1px solid var(--border);background:transparent;font:500 12px/1 var(--font-body);color:var(--fg-tertiary);cursor:pointer;transition:all .15s}.voice-filter-pill.active{background:var(--fg);color:var(--surface);border-color:var(--fg)}.voice-filter-pill:hover:not(.active){border-color:var(--fg-secondary)}.voice-list{flex:1;overflow-y:auto;padding:8px 12px}.voice-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;cursor:pointer;transition:background .15s;border:2px solid transparent}.voice-item:hover{background:var(--bg)}.voice-item.selected{border-color:var(--accent);background:var(--accent-bg)}.voice-item-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--surface);flex-shrink:0}.voice-item-info{flex:1;min-width:0}.voice-item-name{font-size:15px;font-weight:600;color:var(--fg)}.voice-item-meta{font-size:12px;color:var(--fg-tertiary);margin-top:2px}.voice-item-tags{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.voice-item-tag{font-size:10px;padding:1px 6px;border-radius:8px;background:var(--bg);color:var(--fg-tertiary)}.voice-item-play{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.voice-item-play:hover{border-color:var(--accent);background:var(--accent-bg)}.voice-item-play svg{width:14px;height:14px;color:var(--fg-secondary)}.voice-item-play:hover svg{color:var(--accent)}.voice-item-play.playing{background:var(--accent);border-color:var(--accent)}.voice-item-play.playing svg{color:var(--surface)}.voice-modal-footer{padding:16px 24px;border-top:1px solid var(--border);flex-shrink:0}.voice-confirm-btn{width:100%;height:48px;border:none;border-radius:12px;background:var(--accent);color:var(--surface);font:600 15px/1 var(--font-body);cursor:pointer;transition:filter .15s}.voice-confirm-btn:hover{filter:brightness(1.08)}.voice-confirm-btn:disabled{opacity:.4;cursor:default;filter:none}.voice-modal__close{width:32px;height:32px;border:none;border-radius:8px;background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--fg-tertiary);transition:all .15s}.voice-modal__close:hover{background:var(--border-light);color:var(--fg)}.voice-char-block{margin-bottom:var(--space-md);padding:var(--space-md);background:var(--bg);border-radius:var(--radius-card)}.voice-char-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.voice-rec-card{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s;margin-bottom:6px}.voice-rec-card:hover,.voice-rec-card.selected{border-color:var(--accent);background:var(--accent-bg)}.voice-rec-card__left{flex:1;min-width:0}.voice-rec-card__name{font-size:13px;font-weight:500;color:var(--fg)}.voice-rec-card__tags{display:flex;gap:4px;margin-top:2px}.voice-rec-card__right{display:flex;align-items:center;gap:6px;flex-shrink:0}.voice-tag{font-size:11px;padding:1px 6px;border-radius:6px;background:var(--border-light);color:var(--fg-secondary)}.voice-match-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:8px;background:var(--accent-bg);color:var(--accent);white-space:nowrap}.voice-rec-reasons{font-size:11px;color:var(--fg-tertiary);margin-top:4px;padding-left:2px}.voice-preview-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:50%;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--fg-tertiary);font-size:12px;flex-shrink:0;transition:all .15s}.voice-preview-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.voice-lib-list{max-height:180px;overflow-y:auto;margin-top:6px}.voice-lib-card{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;transition:all .15s;margin-bottom:2px}.voice-lib-card:hover,.voice-lib-card.selected{background:var(--accent-bg)}.voice-lib-card .voice-rec-card__name{font-size:13px}.voice-search{font-size:13px!important;height:36px!important;margin-bottom:4px}.voice-hint-card{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border:1px dashed var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.voice-hint-card:hover{border-color:var(--accent);background:var(--accent-bg)}.archived-badge{font-size:11px;font-weight:600;color:var(--fg-tertiary);background:var(--border-light);padding:2px 8px;border-radius:10px;margin-left:8px}@media (min-width: 768px){.stat-grid{grid-template-columns:1fr 1fr 1fr 1fr}}.profile-page{max-width:640px;padding:var(--space-md)}.profile-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.profile-avatar{width:56px;height:56px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font:700 22px/1 var(--font-display);color:var(--surface);flex-shrink:0}.profile-name{font:700 20px/1.2 var(--font-display);color:var(--fg)}.profile-meta{font-size:13px;color:var(--fg-secondary);margin-top:2px}.profile-edit-btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:var(--surface);font:500 13px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;transition:all .15s}.profile-edit-btn:hover{border-color:var(--accent);color:var(--accent)}.profile-logout-btn{border:none;background:none;font:500 15px/1 var(--font-body);color:var(--error);cursor:pointer;padding:12px 24px}.profile-sub-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.profile-back-btn{width:36px;height:36px;border:none;background:none;cursor:pointer;color:var(--fg-secondary);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .15s}.profile-back-btn:hover{background:var(--border-light)}.profile-sub-title{font:700 20px/1.2 var(--font-display);color:var(--fg)}.profile-home-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;color:var(--fg-tertiary);text-align:center}.profile-home-welcome__title{font:600 16px/1.5 var(--font-body);color:var(--fg-secondary);margin-bottom:8px}.profile-home-welcome__desc{font-size:14px}.menu-item--active{background:var(--accent-bg)}.stats-row{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;margin-bottom:var(--space-lg)}.stat-inline{flex:1;text-align:center;padding:14px 8px;border-right:1px solid var(--border-light)}.stat-inline:last-child{border-right:none}.stat-inline__value{font:700 20px/1 var(--font-display);color:var(--fg)}.stat-inline__label{font-size:11px;color:var(--fg-tertiary);margin-top:2px}.menu-section{margin-bottom:20px}.menu-section__title{font:600 13px/1.5 var(--font-body);color:var(--fg-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;padding-left:4px}.menu-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.menu-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .15s;background:none;border-left:none;border-right:none;border-top:none;width:100%;text-align:start;font:500 15px/1 var(--font-body);color:var(--fg);min-height:44px}.menu-item:last-child{border-bottom:none}.menu-item:hover{background:var(--border-light)}.menu-item__icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.menu-item__icon svg{width:16px;height:16px}.menu-item__icon--green{background:var(--success-bg);color:var(--success)}.menu-item__icon--orange{background:var(--accent-bg);color:var(--accent)}.menu-item__icon--gray{background:var(--border-light);color:var(--fg-tertiary)}.menu-item__text{flex:1}.menu-item__title{font-size:15px;font-weight:500}.menu-item__desc{font-size:12px;color:var(--fg-tertiary);margin-top:2px}.menu-item__arrow{color:var(--fg-tertiary);flex-shrink:0;min-width:24px;width:16px;height:16px}.version{text-align:center;font-size:12px;color:var(--fg-tertiary);padding:var(--space-lg) 0}.settings-page{padding:0;max-width:480px}.setting-group{margin-bottom:24px}.setting-group__title{font:600 13px/1.5 var(--font-body);color:var(--fg-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;padding-left:4px}.setting-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-light);transition:background .15s}.setting-item:hover{background:var(--border-light)}.setting-item:last-child{border-bottom:none}.setting-item__label{font:500 15px/1 var(--font-body)}.setting-item__desc{font-size:12px;color:var(--fg-tertiary);margin-top:2px}.share-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}.share-stat{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center}.share-stat__value{font:700 22px/1 var(--font-display)}.share-stat__label{font-size:11px;color:var(--fg-tertiary);margin-top:2px}.share-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:16px;margin-bottom:12px}.share-card__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.share-card__title{font:600 15px/1.3 var(--font-display)}.share-status-pill{font-size:11px;padding:2px 7px;border-radius:10px}.share-card__tags{display:flex;gap:6px;margin:6px 0 8px;flex-wrap:wrap}.share-tag{font-size:10px;padding:1px 6px;border-radius:3px}.share-card__desc{font-size:13px;color:var(--fg-secondary);margin-bottom:8px}.share-card__footer{display:flex;justify-content:space-between;align-items:center}.share-card__date{font-size:12px;color:var(--fg-tertiary)}.share-card__actions{display:flex;gap:4px}.share-action-btn{width:32px;height:32px;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;color:var(--fg-secondary);display:flex;align-items:center;justify-content:center;transition:all .15s}.share-action-btn:hover{border-color:var(--accent);color:var(--accent)}.share-action-btn--danger{color:var(--error)}.share-action-btn--danger:hover{border-color:var(--error)}.voices-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.voices-summary{font-size:13px;color:var(--fg-secondary)}.voice-filter-reset{font:500 12px/1 var(--font-body);color:var(--accent);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:6px}.voice-filter-reset:hover{background:var(--accent-bg)}.voice-filter-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.voice-filter-label{font:500 12px/1 var(--font-body);color:var(--fg-tertiary);min-width:28px}.voice-filter-mobile{margin-bottom:14px}.voice-filter-mobile__bar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 0;min-height:36px}.voice-filter-mobile__chips{display:flex;gap:4px;flex-wrap:wrap;flex:1;min-width:0}.voice-filter-chip{padding:3px 8px;border-radius:10px;font:500 11px/1.3 var(--font-body);background:var(--accent-bg);color:var(--accent);white-space:nowrap}.voice-filter-mobile__hint{font:400 12px/1 var(--font-body);color:var(--fg-tertiary)}.voice-filter-toggle{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface);font:500 12px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;flex-shrink:0;transition:all .15s;-webkit-tap-highlight-color:transparent}.voice-filter-toggle:active{background:var(--bg)}.voice-filter-toggle.open{border-color:var(--accent);color:var(--accent)}.voice-filter-toggle__arrow{font-size:8px;opacity:.6}.voice-filter-mobile__panel{padding:12px 0 4px;display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--border);animation:vpanel-in .15s ease-out}.voice-filter-mobile__panel .voice-filter-pill{padding:3px 10px;border-radius:14px;border:1px solid var(--border);background:var(--surface);font:400 12px/1.4 var(--font-body);color:var(--fg-secondary);cursor:pointer;transition:all .15s;height:auto}.voice-filter-mobile__panel .voice-filter-pill:hover{border-color:var(--accent);color:var(--accent)}.voice-filter-mobile__panel .voice-filter-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}@keyframes vpanel-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.profile-search-box{position:relative;margin-bottom:14px;display:flex}.profile-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--fg-tertiary);display:flex}.profile-search-input{width:100%;padding:8px 12px 8px 32px;border:1px solid var(--border);border-radius:8px;font:14px/1.5 var(--font-body);background:var(--bg);color:var(--fg);outline:none}.profile-search-input:focus{border-color:var(--accent)}.voice-card-list{display:flex;flex-direction:column;gap:10px}.voice-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.voice-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;transition:border-color .15s}.voice-card:hover{border-color:var(--accent)}.voice-card__inner{display:flex;gap:12px}.voice-card__avatar{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex-shrink:0}.voice-card__body{flex:1;min-width:0}.voice-card__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.voice-card__name-row{display:flex;align-items:center;gap:6px}.voice-card__name{font:600 15px/1 var(--font-body)}.voice-card__btns{display:flex;gap:4px}.voice-icon-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s}.voice-icon-btn:hover{border-color:var(--accent);color:var(--accent)}.voice-disabled-badge{font-size:10px;padding:1px 5px;border-radius:3px;background:var(--error-bg);color:var(--error)}.voice-card__desc{font-size:12px;color:var(--fg-secondary);margin-bottom:4px}.voice-card__tags{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:4px}.voice-tag{font-size:10px;padding:1px 6px;border-radius:3px;background:var(--border-light);color:var(--fg-tertiary)}.voice-tag--lang{background:var(--info-bg);color:var(--info)}.voice-tag--gender{background:var(--accent-bg);color:var(--accent)}.voice-card__sample{font-size:11px;color:var(--fg-tertiary);font-style:italic;margin-bottom:4px;line-height:1.4}.voice-card__actions{display:flex;gap:4px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-light)}.voice-action-btn{flex:1;height:28px;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;font:500 11px/1 var(--font-body);color:var(--fg-secondary);transition:all .15s}.voice-action-btn:hover{border-color:var(--accent)}.voice-empty{text-align:center;padding:32px 0;display:flex;flex-direction:column;align-items:center;gap:12px}.profile-list-footer{text-align:center;padding:16px 0;font-size:12px;color:var(--fg-tertiary)}.voices-layout{display:grid;grid-template-columns:180px 1fr;gap:16px}.voices-sidebar{display:flex;flex-direction:column;gap:12px}.voices-sidebar-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px}.voices-sidebar-title{font:600 13px/1 var(--font-body);margin-bottom:10px}.voices-filter-field{margin-bottom:10px}.voices-filter-label{font-size:12px;font-weight:600;margin-bottom:4px;display:block}.voices-filter-select{width:100%;padding:5px 8px;border:1px solid var(--border);border-radius:6px;font:12px/1 var(--font-body);background:var(--surface);color:var(--fg);outline:none;cursor:pointer}.voices-filter-reset-btn{width:100%;padding:6px;border:1px solid var(--border);border-radius:6px;background:var(--surface);font:500 12px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer}.voices-filter-reset-btn:hover{border-color:var(--accent);color:var(--accent)}.voices-hot-tags{display:flex;flex-wrap:wrap;gap:4px}.voices-hot-tag{font-size:11px;padding:2px 7px;border-radius:10px;background:var(--border-light);color:var(--fg-secondary);cursor:pointer;transition:all .15s}.voices-hot-tag:hover{background:var(--accent-bg);color:var(--accent)}.voices-tablet-filters{display:flex;gap:10px;margin-bottom:14px;align-items:center}.voices-tablet-filters .voices-filter-select{width:auto;padding:6px 10px;font:13px/1 var(--font-body)}@media (max-width: 768px){.voice-card-grid,.voices-layout{grid-template-columns:1fr}.voices-tablet-filters{flex-wrap:wrap}.voices-tablet-filters .voices-filter-select{flex:1;min-width:80px}}.emotions-summary{font-size:13px;color:var(--fg-secondary);margin-bottom:14px}.emotion-categories{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:14px}.emotion-category{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px;text-align:center;cursor:pointer;transition:border-color .15s}.emotion-category:hover{border-color:var(--accent)}.emotion-category--active{border-color:var(--accent);background:var(--accent-light)}.emotion-category__count{font:700 16px/1 var(--font-display)}.emotion-category__name{font-size:10px;color:var(--fg-tertiary);margin-top:2px}.emotion-card-list{display:flex;flex-direction:column;gap:10px}.emotion-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;transition:border-color .15s}.emotion-card:hover{border-color:var(--accent)}.emotion-card--clickable{cursor:pointer}.emotion-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.emotion-card__tag-row{display:flex;align-items:center;gap:6px}.emotion-tag-badge{font-size:11px;font-weight:600;font-family:ui-monospace,monospace;padding:2px 8px;border-radius:6px}.emotion-tag-badge--disabled{background:var(--error-bg);color:var(--error)}.emotion-sys-badge{font-size:10px;padding:1px 4px;border-radius:3px;background:var(--bg);color:var(--fg-tertiary)}.emotion-disabled-badge{font-size:10px;padding:1px 4px;border-radius:3px;background:var(--error-bg);color:var(--error)}.emotion-card__actions{display:flex;gap:4px}.emotion-action-btn{border:none;background:none;cursor:pointer;font-size:12px;font-weight:500;padding:2px 4px;transition:color .15s}.emotion-action-btn:hover{opacity:.8}.emotion-card__title-row{margin-bottom:6px}.emotion-card__name{font:600 15px/1 var(--font-body)}.emotion-card__label{font-size:14px;color:var(--fg-secondary);margin-left:8px}.emotion-card__desc{font-size:12px;color:var(--fg-secondary);line-height:1.5;margin-bottom:8px}.emotion-card__sample{font-size:12px;color:var(--fg-tertiary);padding:6px 10px;background:var(--bg);border-radius:6px;border-left:3px solid var(--accent);margin-bottom:8px;font-style:italic}.emotion-card__pill-list{display:flex;gap:4px;flex-wrap:wrap}.emotion-pill{font-size:10px;padding:2px 8px;border-radius:10px;background:var(--bg);color:var(--fg-tertiary)}.emotion-edit{max-width:560px;padding-bottom:100px}.emotion-edit__header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.emotion-edit__title{font:700 18px/1.2 var(--font-display);color:var(--fg)}.emotion-edit__hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.emotion-edit__tag{font:600 16px/1 var(--font-mono);color:var(--accent);background:var(--accent-light);padding:6px 12px;border-radius:8px}.emotion-edit__meta{display:flex;align-items:center;gap:8px}.emotion-status-toggle{border:1px solid var(--border);background:var(--surface);font:500 12px/1 var(--font-body);padding:4px 10px;border-radius:var(--radius-pill);cursor:pointer;transition:all .15s}.emotion-status-toggle--on{color:var(--success);border-color:var(--success);background:var(--success-bg)}.emotion-status-toggle--off{color:var(--error);border-color:var(--error);background:var(--error-bg)}.emotion-edit__section{margin-bottom:20px}.emotion-edit__section-title{font:600 13px/1.5 var(--font-body);color:var(--fg-tertiary);letter-spacing:.04em;margin-bottom:8px;padding-left:4px}.emotion-edit__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.emotion-edit__field{padding:14px 16px;border-bottom:1px solid var(--border-light)}.emotion-edit__field:last-child{border-bottom:none}.emotion-edit__label{display:block;font:500 13px/1.3 var(--font-body);color:var(--fg-secondary);margin-bottom:6px}.emotion-edit__input,.emotion-edit__textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius-input);padding:10px 12px;font:400 14px/1.5 var(--font-body);color:var(--fg);background:var(--bg);outline:none;transition:border-color .15s;box-sizing:border-box}.emotion-edit__input:focus,.emotion-edit__textarea:focus{border-color:var(--accent)}.emotion-edit__input::placeholder,.emotion-edit__textarea::placeholder{color:var(--fg-tertiary)}.emotion-edit__textarea{resize:vertical;min-height:60px}.emotion-edit__category-grid{display:flex;flex-wrap:wrap;gap:6px}.emotion-edit__category-btn{padding:6px 14px;border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--surface);font:500 13px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;transition:all .15s}.emotion-edit__category-btn:hover{border-color:var(--accent)}.emotion-edit__category-btn--active{font-weight:600}.emotion-edit__footer{position:sticky;bottom:0;background:var(--surface);border-top:1px solid var(--border);padding:12px 16px;display:flex;gap:10px;z-index:10;margin:16px -16px -16px}.emotion-edit__footer .btn{height:44px;font-size:14px}.help-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px}.help-ai-card{background:var(--accent-bg);border:1px solid color-mix(in srgb,var(--accent) 15%,transparent);border-radius:var(--radius-card);padding:16px;margin-bottom:20px}.help-ai-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.help-ai-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:var(--surface);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.help-ai-name{font:600 14px/1 var(--font-body)}.help-ai-status{font-size:11px;color:var(--fg-tertiary)}.help-ai-bubble{background:var(--surface);border-radius:10px;padding:12px;margin-bottom:8px;font-size:13px;line-height:1.6;color:var(--fg-secondary)}.help-ai-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.help-ai-tag{padding:6px 12px;border-radius:20px;border:1px solid var(--border);background:var(--surface);font:500 12px/1 var(--font-body);color:var(--fg);cursor:pointer;transition:all .15s}.help-ai-tag:hover{border-color:var(--accent);color:var(--accent)}.help-ai-input-row{display:flex;gap:8px;align-items:center}.help-ai-input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:20px;font:14px/1.4 var(--font-body);background:var(--surface);color:var(--fg);outline:none}.help-ai-input:focus{border-color:var(--accent)}.help-ai-send{width:40px;height:40px;border:none;background:var(--accent);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:filter .15s}.help-ai-send:hover{filter:brightness(1.1)}.help-section-title{font:600 15px/1.4 var(--font-body);margin-bottom:10px}.help-feedback-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;margin-bottom:20px}.help-feedback-item{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.help-feedback-item:last-child{border-bottom:none}.help-feedback__title{font:500 13px/1.4 var(--font-body)}.help-feedback__meta{font-size:12px;color:var(--fg-tertiary);margin-top:2px}.help-feedback__status{font-size:11px;padding:2px 7px;border-radius:10px;white-space:nowrap}.help-faq-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;margin-bottom:20px}.help-faq-item{border-bottom:1px solid var(--border)}.help-faq-item:last-child{border-bottom:none}.help-faq-q{width:100%;padding:12px 16px;font:500 13px/1.4 var(--font-body);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;background:none;border:none;color:var(--fg);text-align:left}.help-faq-a{padding:0 16px 12px;font-size:13px;line-height:1.6;color:var(--fg-secondary)}.help-contact-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.help-contact-item{padding:12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.help-contact-item:last-child{border-bottom:none}.not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:16px}.not-found__code{font:700 96px/1 var(--font-display);color:var(--border);letter-spacing:-.04em}.not-found__title{font:700 24px/1.2 var(--font-display)}.not-found__desc{font-size:15px;color:var(--fg-secondary)}.btn-p{display:inline-flex;align-items:center;justify-content:center;height:48px;padding:0 24px;color:var(--surface);font:600 16px/1 var(--font-body);background:var(--accent);border:none;border-radius:var(--radius-btn);cursor:pointer;transition:filter .15s}.btn-p:hover{filter:brightness(1.1)}.btn-s{display:inline-flex;align-items:center;justify-content:center;height:48px;padding:0 24px;color:var(--fg);font:500 16px/1 var(--font-body);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-btn);cursor:pointer;transition:all .15s}.btn-s:hover{border-color:var(--accent);color:var(--accent)}@media (min-width: 769px){.emotion-categories{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.emotion-categories{grid-template-columns:repeat(6,1fr)}}.practice-page{display:flex;flex-direction:column;height:100%;overflow:hidden}.practice-header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.practice-header__title{font:600 16px/1 var(--font-display);flex:1}.back-btn{width:36px;height:36px;border:none;background:none;cursor:pointer;color:var(--fg-secondary);border-radius:8px;display:flex;align-items:center;justify-content:center}.back-btn:hover{background:var(--border-light)}.char-pills{display:flex;gap:6px;padding:10px 16px;overflow-x:auto;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;scrollbar-width:none}.char-pills::-webkit-scrollbar{display:none}.char-pill{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;border:1px solid var(--border);background:var(--surface);font:500 13px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;transition:all .15s}.char-pill.on{background:var(--accent);color:var(--surface);border-color:var(--accent)}.char-pill__dot{width:6px;height:6px;border-radius:50%}.char-pill__count{font-size:11px;color:var(--fg-tertiary)}.char-pill.on .char-pill__count{color:#ffffffb3}.mode-bar{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.mode-btn{flex:1;padding:10px;border:none;background:none;font:600 14px/1 var(--font-body);color:var(--fg-tertiary);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.mode-btn.on{color:var(--accent);border-bottom-color:var(--accent)}.scene-bar{display:flex;gap:6px;padding:8px 16px 4px;overflow-x:auto;scrollbar-width:none;background:var(--surface);flex-shrink:0}.scene-bar::-webkit-scrollbar{display:none}.scene-pill{height:32px;padding:0 14px;border-radius:16px;border:1px solid var(--border);background:var(--surface);font:500 12px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;white-space:nowrap;transition:all .15s;font-family:inherit}.scene-pill.on{background:var(--accent);color:var(--surface);border-color:var(--accent)}.scene-pill:hover:not(.on){border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.settings-card{margin:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:2px 16px;flex-shrink:0}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.settings-row+.settings-row{border-top:1px solid var(--border)}.settings-label{font:500 15px/1 var(--font-display);color:var(--fg);white-space:nowrap;margin-right:12px}.settings-pills{display:flex;gap:6px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.spill{height:32px;padding:0 12px;border-radius:16px;border:1px solid var(--border);background:transparent;color:var(--fg-secondary);font:500 12px/1 var(--font-body);cursor:pointer;transition:all .15s;white-space:nowrap;font-family:inherit}.spill.on{background:var(--accent);color:var(--surface);border-color:var(--accent)}.spill:hover:not(.on){border-color:var(--accent);color:var(--accent)}.line-area{flex:1;overflow-y:auto;padding:16px}.practice-line{display:flex;flex-direction:row;align-items:flex-start;margin-bottom:10px;gap:8px}.practice-line--right{flex-direction:row-reverse}.practice-line__avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font:600 13px/1 var(--font-body);color:var(--surface);flex-shrink:0;margin-top:2px}.practice-line__content{display:flex;flex-direction:column;max-width:78%}.practice-line--right .practice-line__content{align-items:flex-end}.practice-line__name{font:600 11px/1 var(--font-body);margin-bottom:4px;padding:0 2px}.practice-line--right .practice-line__name{color:var(--accent)}.practice-line--left .practice-line__name{color:var(--fg-secondary)}.practice-line__bubble{padding:10px 14px;border-radius:12px;font:400 15px/1.6 var(--font-body);position:relative}.practice-line--left .practice-line__bubble{background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px}.practice-line--right .practice-line__bubble{background:var(--accent);color:var(--surface);border-bottom-right-radius:4px}.practice-line__bubble--covered{color:transparent!important;background:#d9775740!important;border:1px dashed var(--accent)!important;user-select:none;min-height:22px;position:relative}.practice-line__bubble--covered:after{content:"🔒";position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:12px;opacity:.5}.practice-line__bubble--revealed{background:var(--success-bg)!important;color:var(--fg)!important;border:1px solid var(--success-bg)!important;position:relative}.practice-line__bubble--revealed:after{content:"✓";position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--success);font-weight:700}.practice-line--active .practice-line__bubble{box-shadow:0 0 0 2px var(--accent);background:var(--accent-bg)!important;color:var(--accent)!important;font-weight:600}.practice-line--right.practice-line--active .practice-line__bubble{background:var(--accent)!important;color:var(--surface)!important}.ai-line{display:flex;flex-direction:row;align-items:flex-start;gap:8px;margin-bottom:10px}.ai-line--user{flex-direction:row-reverse}.ai-line__avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font:600 13px/1 var(--font-body);color:var(--surface);flex-shrink:0;margin-top:2px}.ai-line__content{display:flex;flex-direction:column;max-width:80%}.ai-line--user .ai-line__content{align-items:flex-end}.ai-line__name{font:600 11px/1 var(--font-body);color:var(--accent);margin-bottom:4px;padding:0 2px}.ai-line__bubble{padding:8px 14px;font:400 14px/1.6 var(--font-body);transition:background .3s}.ai-line--ai .ai-line__bubble{background:var(--surface);border:1px solid var(--border);border-radius:4px 16px 16px}.ai-line--user .ai-line__bubble{background:var(--accent);color:var(--surface);border-radius:16px 4px 16px 16px}.ai-line--active .ai-line__bubble{box-shadow:0 0 0 2px #d977574d}.ai-line__note{font-size:11px;color:var(--accent);margin-top:2px}.ai-line--user .ai-line__note{text-align:right}.ai-line__dur{font-size:11px;margin-left:4px}.ai-line--matched .ai-line__bubble{background:var(--success)!important;color:var(--surface)!important;border:none}.ai-line--failed .ai-line__bubble{background:var(--error)!important;color:var(--surface)!important;border:none}.ai-line--past{opacity:.7}.ai-line--future{opacity:.35;transition:opacity .3s}.ai-status-bar{display:flex;align-items:center;gap:12px;padding:14px 20px;margin:0 16px 12px;background:var(--surface);border:1px solid var(--border);border-radius:16px}.ai-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ai-status-bar__text{font-size:14px;color:var(--fg-secondary)}.ai-role-skip{margin:0 16px 12px;padding:8px 12px;background:var(--bg);border-radius:8px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.ai-role-skip__label{font-size:12px;color:var(--fg-tertiary);margin-right:4px}.ai-start-btn{width:100%;height:52px;border-radius:14px;border:none;background:var(--accent);color:var(--surface);font:600 17px/1 var(--font-display);cursor:pointer;font-family:inherit;letter-spacing:-.01em}.ai-start-btn:hover{filter:brightness(1.1)}.ai-controls{display:flex;align-items:center;justify-content:center;gap:16px}.ai-ctrl-btn{width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--surface)}.ai-ctrl-btn--stop{background:var(--error)}.ai-ctrl-btn--mic{width:64px;height:64px;background:var(--accent);font-size:24px}.ai-ctrl-btn--mic.listening{background:var(--error)}.ai-ctrl-btn--skip{background:var(--border);color:var(--fg)}.ai-ctrl-btn--speaking{width:64px;height:64px;background:var(--fg-tertiary);color:var(--surface);cursor:default;font-size:13px;font-weight:600;line-height:1.1}.ai-result-btns{display:flex;gap:8px}.ai-result-btns button{flex:1;height:48px;border-radius:14px;font:600 15px/1 var(--font-body);cursor:pointer;font-family:inherit}.ai-btn-s{border:1px solid var(--border);background:var(--surface);color:var(--fg)}.ai-btn-p{border:none;background:var(--accent);color:var(--surface)}.ai-scene-div{display:flex;align-items:center;margin:16px 0 8px;padding:0 16px}.ai-scene-div__line{flex:1;height:1px;background:var(--border)}.ai-scene-div__text{padding:0 12px;font-size:12px;color:var(--fg-tertiary);white-space:nowrap}.ai-stage-dir{text-align:center;padding:4px 48px}.ai-stage-dir span{font-size:12px;color:var(--fg-tertiary);font-style:italic;background:var(--bg);padding:2px 12px;border-radius:8px}.ai-asr-typing{display:flex;flex-direction:row-reverse;gap:8px;padding:2px 16px}.ai-asr-typing__bubble{background:var(--accent-bg);border-radius:0 0 16px 16px;padding:4px 14px;font-size:12px;color:var(--accent);max-width:70%}.ai-waiting{text-align:center;font-size:13px;color:var(--fg-tertiary);padding:8px 0}@keyframes aiTypeIn{0%{opacity:0}to{opacity:1}}.ai-type{display:inline;opacity:0;animation:aiTypeIn .04s ease forwards;will-change:opacity}.ai-typing-cursor{display:inline-block;width:2px;height:16px;background:var(--accent);margin-left:1px;animation:aiCursorBlink .5s infinite}@keyframes aiCursorBlink{0%,to{opacity:1}50%{opacity:0}}.bottom-tab-bar{height:82px;padding-bottom:20px;display:flex;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;position:sticky;bottom:0;z-index:5}.bottom-tab-bar__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:none;background:none;cursor:pointer;color:var(--fg-tertiary);transition:color .15s;font-family:inherit}.bottom-tab-bar__item.on{color:var(--accent)}.bottom-tab-bar__item svg{width:24px;height:24px}.bottom-tab-bar__label{font-size:11px;font-weight:600;letter-spacing:.01em}.practice-bottom-bar{display:flex;align-items:center;gap:10;padding:10px 20px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px));background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;z-index:10}.practice-bottom-bar__settings{width:44px;height:44px;border-radius:50%;border:none;background:var(--bg);color:var(--fg-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s}.practice-bottom-bar__settings:hover{background:var(--border)}.practice-bottom-bar__action{flex:1;height:48px;border-radius:14px;border:none;background:var(--accent);color:#fff;font:600 16px/1 var(--font-body);cursor:pointer;font-family:inherit;letter-spacing:-.01em}.speed-card{margin:0 16px 12px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px 20px}.speed-label{font:600 12px/1 var(--font-body);text-transform:uppercase;letter-spacing:.06em;color:var(--fg-secondary);margin-bottom:10px}.speed-hint{font-size:11px;color:var(--fg-tertiary);margin-top:6px}.speed-row{display:flex;align-items:center;gap:12px}.speed-row input[type=range]{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:var(--border);border-radius:2px;outline:none}.speed-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--surface);box-shadow:0 1px 4px #0003}.speed-val{font:600 14px/1 var(--font-display);color:var(--fg);min-width:32px;text-align:right}.cue-card{margin:0 16px 12px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;flex-shrink:0}.cue-card__label{font:600 11px/1 var(--font-body);text-transform:uppercase;letter-spacing:.06em;color:var(--fg-tertiary);margin-bottom:8px}.cue-card__target-hidden{color:transparent!important;position:relative}.cue-card__target-hidden:after{content:"???";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#ffffffe6;font-weight:600;font-size:16px}.cue-card__actions{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:8px;margin-top:16px}.cue-card__actions .spill{height:40px;border-radius:10px}.cue-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:40px;padding:0 14px;border-radius:10px;font:600 14px/1 var(--font-body);cursor:pointer;white-space:nowrap;font-family:inherit;border:none;transition:all .15s}.cue-btn--p{background:var(--accent);color:var(--surface)}.cue-btn--p:hover{filter:brightness(1.1)}.cue-btn--s{background:var(--surface);color:var(--fg);border:1px solid var(--border)}.cue-btn--s:hover{border-color:var(--accent);color:var(--accent)}.cue-btn--voice{background:var(--error);color:var(--surface)}.cue-btn--voice:hover{opacity:.9}.cue-card__result{text-align:center;margin-top:12px;font-size:14px}.cue-card__result--ok{color:var(--success)}.cue-card__result--fail{color:var(--error)}.cue-card__asr{display:flex;flex-direction:row-reverse;gap:8px;padding:2px 0}.cue-card__asr-bubble{background:var(--accent-bg);border-radius:0 0 16px 16px;padding:4px 14px;font-size:12px;color:var(--accent);max-width:70%}.cue-card__countdown{text-align:center;font:700 20px/1 var(--font-display);color:var(--error)}.cue-auto-continue{text-align:center;font-size:12px;color:var(--fg-tertiary);margin-top:6px}.mode-pills{display:flex;gap:8px;justify-content:center;margin-bottom:10px}.mode-pills .spill{height:32px}.cue-stats{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--fg-tertiary);margin-top:8px}.cue-stats button{background:none;border:none;cursor:pointer;color:var(--fg-tertiary);padding:2px;display:flex;align-items:center}.cue-banner{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--info-bg);border-radius:10px;margin:0 16px 8px;font-size:13px;color:var(--info);flex-shrink:0}.cue-mark{display:inline-flex;align-items:center;gap:2px;margin-left:6px;padding:1px 6px;border-radius:4px;background:var(--success-bg);color:var(--success);font-size:11px;font-weight:600}.cue-mark--pending{background:var(--warning-bg);color:var(--warning)}.cue-bottom{padding:12px 16px;flex-shrink:0;background:var(--surface);border-top:1px solid var(--border);position:sticky;bottom:0;z-index:5}.cue-bottom__start{flex:1;height:52px;border-radius:14px;border:none;background:var(--accent);color:var(--surface);font:600 17px/1 var(--font-display);cursor:pointer;font-family:inherit;letter-spacing:-.01em}.cue-bottom__edit{height:52px;padding:0 20px;border-radius:14px;border:1px solid var(--border);background:var(--surface);font:500 15px/1 var(--font-body);color:var(--fg);cursor:pointer;font-family:inherit;white-space:nowrap}.cue-bottom__edit.on{background:var(--accent);color:var(--surface);border-color:var(--accent)}.cue-bottom__row{display:flex;gap:8px}.cue-card .practice-line--left .practice-line__bubble{border-radius:4px 16px 16px}.cue-card .practice-line--right .practice-line__bubble{border-radius:16px 4px 16px 16px}.cue-note{font-size:11px;color:var(--accent);margin-top:2px;text-align:right;padding:0 2px}.cue-editable{cursor:pointer!important;transition:box-shadow .15s}.cue-editable:hover{box-shadow:0 0 0 2px var(--accent);border-radius:12px}@keyframes cue-pulse{0%{box-shadow:0 0 #d9775766}50%{box-shadow:0 0 0 6px #d9775726}to{box-shadow:0 0 #d9775700}}.cue-editable--guide{animation:cue-pulse .8s ease-out 2;border-radius:12px}.action-popup{position:fixed;display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 8px;box-shadow:0 2px 12px #00000026;z-index:20;white-space:nowrap}.action-popup button{padding:6px 8px;border:none;background:none;cursor:pointer;font-size:12px;color:var(--fg);border-radius:4px;display:flex;align-items:center;gap:4px}.action-popup button:hover{background:var(--bg)}.action-popup__arrow{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--surface)}.alert{padding:10px 14px;border-radius:10px;margin-bottom:8px;font-size:13px;line-height:1.5}.alert--info{background:var(--info-bg);color:var(--info);border:1px solid var(--info-bg)}.alert--stuck{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-bg)}.alert--success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-bg)}.pill-sm{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:600}.pill-sm--green{background:var(--success-bg);color:var(--success)}.pill-sm--orange{background:var(--warning-bg);color:var(--warning)}.pill-sm--red{background:var(--error-bg);color:var(--error)}.onboarding-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#1a1a1a66;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.onboarding-glass{background:#ffffffd9;backdrop-filter:blur(20px);border-radius:20px;padding:24px 20px;max-width:340px;width:100%;text-align:center;box-shadow:0 8px 32px #0000001f}.onboarding-icon{width:48px;height:48px;border-radius:14px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.onboarding-glass h2{font:700 20px/1.2 var(--font-display);margin-bottom:4px}.onboarding-glass p{font-size:13px;color:var(--fg-secondary);margin-bottom:20px;line-height:1.5}.onboarding-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;text-align:start;cursor:pointer;transition:border-color .15s}.onboarding-card:hover{border-color:var(--accent)}.onboarding-card__icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.onboarding-card__title{font:600 15px/1.3 var(--font-display)}.onboarding-card__desc{font-size:12px;color:var(--fg-tertiary);margin-top:3px}.practice-sidebar nav{display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);flex-shrink:0;height:100%}.practice-sidebar__back{padding:20px 0;display:flex;justify-content:center;border-bottom:1px solid var(--border)}.practice-sidebar__back-btn{width:36px;height:36px;border-radius:10px;background:var(--accent);color:var(--surface);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px}.practice-sidebar__modes{display:flex;flex-direction:column;gap:4px;padding:12px 8px;flex:1}.practice-sidebar__mode-btn{display:flex;flex-direction:column;justify-content:center;gap:6px;padding:12px 6px;border-radius:10px;border:none;background:transparent;cursor:pointer;text-align:center;color:var(--fg-tertiary);transition:all .15s;font-family:inherit}.practice-sidebar__mode-btn.on{background:var(--accent-bg);color:var(--accent)}.practice-sidebar__mode-label{font-size:12px;font-weight:600;letter-spacing:.01em}.empty-state{text-align:center;padding:40px;flex:1}.empty-state svg{color:var(--fg-tertiary)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.toggle-row span{font-size:14px;color:var(--fg);font-weight:500}.toggle{width:48px;height:28px;border-radius:14px;background:var(--border);position:relative;cursor:pointer;transition:background .2s;border:none}.toggle.on{background:var(--accent)}.toggle:after{content:"";width:24px;height:24px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #00000026}.toggle.on:after{transform:translate(20px)}.setup-panel{transition:all .3s ease;overflow:hidden}.setup-panel.collapsed{max-height:0;margin:0;padding:0;opacity:0;border:none;box-shadow:none}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;font:600 14px/1.5 var(--font-body);color:var(--fg);margin-bottom:6px}.form-input{width:100%;height:44px;border:1px solid var(--border);border-radius:var(--radius-input);padding:0 14px;font:400 15px/1 var(--font-body);color:var(--fg);background:var(--surface);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--fg-tertiary)}.form-textarea{width:100%;min-height:100px;border:1px solid var(--border);border-radius:var(--radius-input);padding:12px 14px;font:400 15px/1.65 var(--font-body);color:var(--fg);background:var(--surface);outline:none;resize:vertical;transition:border-color .15s}.form-textarea:focus{border-color:var(--accent)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:var(--space-lg)}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-modal);padding:var(--space-2xl) var(--space-xl);box-shadow:var(--shadow-modal)}.auth-title{text-align:center;margin-bottom:var(--space-xl)}.auth-title h1{font:700 24px/1.2 var(--font-display);color:var(--fg);margin:0 0 4px}.auth-title p{font-size:14px;color:var(--fg-secondary)}.auth-footer{text-align:center;margin-top:var(--space-lg);font-size:14px;color:var(--fg-secondary)}.auth-footer a{color:var(--accent);font-weight:500;cursor:pointer;text-decoration:none}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:12px;color:var(--fg-secondary)}.page-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:16px;text-align:center;padding:var(--space-2xl)}.share-page{max-width:640px}.share-list{display:flex;flex-direction:column;gap:var(--space-md)}.share-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-md)}.tc-page{display:flex;flex:1;overflow:hidden}.tc-page__list{width:380px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface)}.tc-page__detail{flex:1;overflow-y:auto;background:var(--bg)}.tc-header{padding:20px 20px 0;flex-shrink:0}.tc-header__title{font:600 20px/1.2 var(--font-display);margin-bottom:16px}.tc-header__filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.tc-filter{padding:5px 12px;border-radius:var(--radius-pill);border:1px solid var(--border);font:500 12px/1 var(--font-body);color:var(--fg-secondary);background:var(--surface);cursor:pointer;transition:all .15s;white-space:nowrap}.tc-filter:hover{border-color:var(--accent);color:var(--accent)}.tc-filter.active{background:var(--accent);color:var(--surface);border-color:var(--accent)}.tc-filter .count{margin-left:4px;font-weight:400;opacity:.7}.tc-search{margin:0 20px 16px;position:relative}.tc-search__input{width:100%;padding:8px 12px 8px 36px;border:1px solid var(--border);border-radius:8px;font:14px/1.5 var(--font-body);background:var(--bg);color:var(--fg);outline:none;transition:border .15s}.tc-search__input:focus{border-color:var(--accent)}.tc-search__icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--fg-tertiary);display:flex}.tc-list{flex:1;overflow-y:auto;padding:0 12px 12px}.tc-list::-webkit-scrollbar{width:4px}.tc-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.tc-card{padding:12px;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:all .15s;margin-bottom:4px}.tc-card:hover{background:var(--border-light)}.tc-card.active{background:var(--accent-bg);border-color:var(--accent)}.tc-card__header{display:flex;gap:10px;align-items:flex-start}.tc-card__icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg);color:var(--fg-secondary)}.tc-card__icon.running{background:var(--accent-bg);color:var(--accent)}.tc-card__info{flex:1;min-width:0}.tc-card__title{font:500 14px/1.4 var(--font-body);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.tc-card__meta{display:flex;align-items:center;gap:6px;margin-top:4px;flex-wrap:wrap}.tc-card__time{font-size:12px;color:var(--fg-tertiary)}.tc-card__progress{margin-top:8px;height:3px;border-radius:2px;background:var(--border-light);overflow:hidden}.tc-card__progress-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .3s}.tc-pill--running{background:var(--accent-bg);color:var(--accent)}.tc-pill--done{background:var(--success-bg);color:var(--success)}.tc-pill--failed{background:var(--error-bg);color:var(--error)}.tc-pill--review{background:var(--warning-bg);color:var(--warning)}.tc-pill--type{background:var(--info-bg);color:var(--info);font-size:10px;height:18px;padding:0 6px}.tc-detail{padding:var(--space-xl);max-width:900px}.tc-detail__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;color:var(--fg-tertiary);text-align:center}.tc-detail__empty-icon{font-size:48px;margin-bottom:16px;opacity:.3}.tc-detail__empty-text{font-size:15px}.tc-detail-header{margin-bottom:var(--space-lg)}.tc-detail-header__title{font:600 22px/1.3 var(--font-display);margin-bottom:8px}.tc-detail-header__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.tc-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:var(--space-lg)}.tc-stat{padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px}.tc-stat__label{font-size:11px;color:var(--fg-tertiary);margin-bottom:4px;letter-spacing:.02em}.tc-stat__value{font:600 20px/1.2 var(--font-display)}.tc-stat__value--success{color:var(--success)}.tc-stat__value--warning{color:var(--warning)}.tc-stat__value--error{color:var(--error)}.tc-stat__value--accent{color:var(--accent)}.tc-stat__value--small{font-size:14px;font-weight:500}.tc-progress{margin-bottom:var(--space-lg)}.tc-progress__bar{height:6px;border-radius:3px;background:var(--border-light);overflow:hidden;margin-bottom:6px}.tc-progress__fill{height:100%;border-radius:3px;background:var(--accent);transition:width .4s}.tc-progress__fill--done{background:var(--success)}.tc-progress__fill--error{background:var(--error)}.tc-progress__label{font-size:12px;color:var(--fg-secondary)}.tc-actions{display:flex;gap:8px;margin-bottom:var(--space-lg)}.tc-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font:500 13px/1 var(--font-body);cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--fg);transition:all .15s}.tc-btn:hover{border-color:var(--accent);color:var(--accent)}.tc-btn--primary{background:var(--accent);color:var(--surface);border-color:var(--accent)}.tc-btn--primary:hover{background:var(--accent-dark)}.tc-alert-error{background:var(--error-bg);border:1px solid var(--error);border-radius:8px;padding:12px 16px;margin-bottom:var(--space-lg);font-size:13px;color:var(--error);display:flex;align-items:flex-start;gap:8px;line-height:1.5}.tc-alert-error__icon{flex-shrink:0;margin-top:1px}.tc-stepper{display:flex;align-items:flex-start;margin-bottom:var(--space-lg);flex-wrap:wrap}.tc-stepper__step{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:70px}.tc-stepper__dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:2px solid var(--border);background:var(--surface);color:var(--fg-tertiary);transition:all .2s}.tc-stepper__dot--done{background:var(--success);border-color:var(--success);color:var(--surface)}.tc-stepper__dot--running{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);animation:tcPulse 1.5s ease-in-out infinite}.tc-stepper__dot--error{background:var(--error-bg);border-color:var(--error);color:var(--error)}.tc-stepper__label{font-size:11px;color:var(--fg-tertiary);text-align:center;max-width:80px}.tc-stepper__label--active{color:var(--accent);font-weight:500}.tc-stepper__label--done{color:var(--fg)}.tc-stepper__connector{width:32px;height:2px;background:var(--border);margin-top:14px;flex-shrink:0}.tc-stepper__connector--done{background:var(--success)}@keyframes tcPulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--accent) 40%,transparent)}50%{box-shadow:0 0 0 4px transparent}}.tc-log{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.tc-log__header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.tc-log__title{font:600 14px/1 var(--font-body);display:flex;align-items:center;gap:6px}.tc-log__count{font-size:12px;color:var(--fg-tertiary)}.tc-log__body{padding:0}.tc-timeline{position:relative;padding:16px}.tc-timeline__item{position:relative;padding-left:28px;padding-bottom:16px}.tc-timeline__item:last-child{padding-bottom:0}.tc-timeline__dot{position:absolute;left:0;top:4px;width:10px;height:10px;border-radius:50%;border:2px solid var(--surface);z-index:1}.tc-timeline__dot--done{background:var(--success)}.tc-timeline__dot--running{background:var(--accent);animation:tcPulse 1.5s ease-in-out infinite}.tc-timeline__dot--warning{background:var(--warning)}.tc-timeline__dot--error{background:var(--error)}.tc-timeline__dot--info{background:var(--info)}.tc-timeline__line{position:absolute;left:4px;top:16px;bottom:0;width:2px;background:var(--border)}.tc-timeline__item:last-child .tc-timeline__line{display:none}.tc-timeline__step{display:flex;justify-content:space-between;align-items:center}.tc-timeline__step-name{font:600 13px/1.4 var(--font-body)}.tc-timeline__step-time{font-size:11px;color:var(--fg-tertiary);font-variant-numeric:tabular-nums}.tc-timeline__step-duration{font-size:11px;color:var(--fg-secondary);margin-left:6px}.tc-timeline__msg{font-size:12px;color:var(--fg-secondary);margin-top:2px;line-height:1.5}.tc-timeline__msg--error{color:var(--error)}.tc-timeline-detail{margin-top:8px;border:1px solid var(--border);border-radius:6px;overflow:hidden}.tc-timeline-detail__header{padding:6px 12px;display:flex;justify-content:space-between;align-items:center;font-size:11px}.tc-timeline-detail__header--input{background:var(--accent-bg)}.tc-timeline-detail__header--output{background:var(--success-bg)}.tc-timeline-detail__pill{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.tc-timeline-detail__pill--input{color:var(--accent)}.tc-timeline-detail__pill--output{color:var(--success)}.tc-timeline-detail__duration{color:var(--fg-tertiary)}.tc-timeline-detail__content{padding:8px 12px;font:12px/1.6 var(--font-mono);background:var(--bg);white-space:pre-wrap;word-break:break-all;max-height:200px;overflow:auto;color:var(--fg-secondary)}.tc-timeline-detail__meta{display:flex;flex-wrap:wrap;gap:4px;padding:4px 12px 8px}.tc-detail-toggle{background:none;border:none;font:500 11px/1 var(--font-body);color:var(--accent);cursor:pointer;padding:2px 0;margin-top:4px;display:inline-flex;align-items:center;gap:3px}.tc-detail-toggle:hover{text-decoration:underline}.tc-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:tcSpin .8s linear infinite;display:inline-block}@keyframes tcSpin{to{transform:rotate(360deg)}}.tc-timeline__dot--running{animation:tc-pulse-dot 1.5s ease-in-out infinite}@keyframes tc-pulse-dot{0%,to{box-shadow:0 0 #d9775766}50%{box-shadow:0 0 0 6px #d9775700}}.tc-streaming{border:1px solid var(--border);border-radius:8px;margin:12px 0;position:relative;overflow:hidden}.tc-streaming__label{font:600 11px/1 var(--font-body);color:var(--fg-tertiary);text-transform:uppercase;letter-spacing:.06em;padding:8px 12px 0}.tc-streaming__content{max-height:240px;overflow-y:auto;padding:8px 12px;position:relative}.tc-streaming__text{font:400 12px/1.6 var(--font-mono);white-space:pre-wrap;word-break:break-all;margin:0}.tc-streaming__cursor{display:inline-block;width:2px;height:14px;background:var(--accent);animation:tc-blink-cursor .8s step-end infinite;vertical-align:text-bottom;margin-left:1px}@keyframes tc-blink-cursor{0%,to{opacity:1}50%{opacity:0}}.tc-streaming__copy{position:absolute;top:6px;right:8px;background:var(--surface);border:1px solid var(--border);border-radius:4px;font-size:11px;padding:2px 8px;cursor:pointer;color:var(--fg-secondary)}.tc-streaming__copy:hover{color:var(--accent);border-color:var(--accent)}.tc-mobile-back{display:none;background:none;border:none;font:500 14px/1 var(--font-body);color:var(--accent);cursor:pointer;padding:0;gap:4px;align-items:center;margin-bottom:12px}.tc-section{margin-bottom:var(--space-lg)}.tc-section__title{font:600 14px/1.4 var(--font-body);margin-bottom:12px;display:flex;align-items:center;gap:6px;color:var(--fg)}.tc-streaming{margin-bottom:var(--space-lg);background:var(--brand-bg);border:1px solid var(--brand-light);border-radius:var(--radius-card);overflow:hidden}.tc-streaming__header{padding:10px 14px;border-bottom:1px solid var(--brand-light);font:600 13px/1 var(--font-body);color:var(--accent);display:flex;align-items:center;gap:6px}.tc-streaming__body{padding:12px 14px;font:12px/1.7 var(--font-mono);color:var(--fg);white-space:pre-wrap;word-break:break-all;max-height:300px;overflow:auto}@media (min-width: 769px) and (max-width: 1024px){.tc-page__list{width:300px}.tc-detail{padding:20px}}@media (max-width: 768px){.tc-page{position:relative;overflow:hidden}.tc-page__list{width:100%;border-right:none;position:absolute;inset:0;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1}.tc-page__detail{position:absolute;inset:0;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:2}.tc-page.detail-open .tc-page__list{transform:translate(-30%);pointer-events:none}.tc-page.detail-open .tc-page__detail{transform:translate(0)}.tc-mobile-back{display:inline-flex}.tc-header{padding:12px 16px 0}.tc-header__title{font-size:18px;margin-bottom:12px}.tc-header__filters{gap:4px;margin-bottom:10px}.tc-filter{padding:4px 10px;font-size:11px}.tc-search{margin:0 16px 12px}.tc-list{padding:0 8px 8px}.tc-card{padding:10px}.tc-card__icon{width:32px;height:32px}.tc-detail{padding:16px}.tc-detail-header__title{font-size:18px}.tc-stats{grid-template-columns:repeat(2,1fr);gap:8px}.tc-stat{padding:10px 12px}.tc-stat__value{font-size:17px}.tc-actions{gap:6px}.tc-btn{padding:7px 14px;font-size:12px}.tc-stepper__step{min-width:52px}.tc-stepper__dot{width:24px;height:24px;font-size:11px}.tc-stepper__label{font-size:10px;max-width:52px}.tc-stepper__connector{width:20px}.tc-timeline{padding:12px}.tc-timeline-detail__content{font-size:11px;max-height:160px}.tc-timeline__step-name{font-size:12px}}.task-card__info{flex:1;min-width:0}.task-card__title-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.task-card__title{font-weight:600;font-size:14px;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-card__meta{display:flex;align-items:center;gap:8px}.task-card__time{font-size:12px;color:var(--fg-tertiary)}.task-card__detail{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.task-detail__progress{display:flex;align-items:center;gap:10px;margin-bottom:12px}.task-detail__progress .progress-bar{flex:1}.task-detail__progress-label{font-size:12px;font-weight:600;color:var(--accent);min-width:32px;text-align:right;font-variant-numeric:tabular-nums}.task-detail__stats{display:flex;flex-wrap:wrap;gap:12px 20px;margin-bottom:12px}.task-detail__stat{display:flex;flex-direction:column;gap:2px}.task-detail__stat-label{font-size:11px;color:var(--fg-tertiary);text-transform:uppercase;letter-spacing:.04em}.task-detail__stat-value{font-size:14px;font-weight:500;color:var(--fg)}.task-detail__actions{display:flex;gap:16px;margin-bottom:4px}.task-detail__action{background:none;border:none;cursor:pointer;padding:0;font-size:13px;color:var(--accent);font-weight:500;display:flex;align-items:center;gap:4px;transition:opacity .15s}.task-detail__action:hover{opacity:.8}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:var(--surface);border-radius:var(--radius-modal);padding:var(--space-lg);width:min(90%,400px);max-width:92vw;box-shadow:var(--shadow-modal)}.modal-card__title{font:600 18px/1.4 var(--font-display);color:var(--fg);margin-bottom:var(--space-md)}.modal-card__body{margin-bottom:var(--space-lg)}.modal-card__footer{display:flex;justify-content:flex-end;gap:var(--space-sm)}.stage-list-page{max-width:640px}.stage-tabs{display:flex;align-items:center;gap:0;border-bottom:1px solid var(--border);margin-bottom:var(--space-md)}.stage-tabs__action{height:36px;padding:0 14px;font-size:13px;gap:6px;display:inline-flex;align-items:center}.stage-list{display:flex;flex-direction:column;gap:var(--space-sm)}.stage-item{display:flex;align-items:center;gap:14px;padding:16px;background:var(--surface);border:1px solid var(--border);border-left-width:4px;border-radius:var(--radius-card);margin-bottom:8px;cursor:pointer;transition:box-shadow .2s,border-color .2s,opacity .2s}.stage-item:hover{box-shadow:0 2px 8px #0000000f}.stage-item--active{border-left-color:var(--success);background:var(--success-bg)}.stage-item--active:hover{box-shadow:0 2px 12px color-mix(in srgb,var(--success) 8%,transparent)}.stage-item--waiting{border-left-color:var(--warning);background:var(--warning-bg)}.stage-item--end{border-left-color:var(--fg-tertiary);opacity:.65}.stage-item--end:hover{opacity:.85}.stage-empty{text-align:center;padding:40px 20px;color:var(--fg-tertiary)}.stage-empty svg{margin-bottom:12px;opacity:.4}.stage-item__icon{width:40px;height:40px;border-radius:10px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent)}.stage-item__icon svg{width:20px;height:20px}.stage-item__info{flex:1;min-width:0}.stage-item__title{font:600 15px/1.3 var(--font-display);color:var(--fg);margin-bottom:2px}.stage-item__meta{font-size:12px;color:var(--fg-tertiary)}.stage-item__status{display:flex;align-items:center;gap:6px;flex-shrink:0}.stage-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.stage-status-text{font-size:12px;color:var(--fg-secondary)}.stage-item__action{font-size:13px;font-weight:500;color:var(--accent);flex-shrink:0}.stage-detail{padding:16px}.stage-participants{display:flex;gap:-8px;margin:12px 0}.stage-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--surface);border:2px solid var(--surface);margin-right:-6px}.stage-detail__header{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}@media (max-width: 479px){.stage-detail__header{flex-wrap:wrap}.stage-detail__title-row{flex-basis:calc(100% - 48px)}.stage-detail__actions{flex-basis:100%;justify-content:flex-end}}.stage-detail__title-row{flex:1}.stage-detail__title{font:700 22px/1.2 var(--font-display);color:var(--fg);margin-bottom:4px}.stage-detail__subtitle{font-size:14px;color:var(--fg-secondary)}.stage-detail__actions{display:flex;gap:8px}.stage-detail__stat-row{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}@media (max-width: 359px){.stage-detail__stat-row{gap:8px}.stage-detail__stat-item{padding:8px 10px}}.stage-detail__stat-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 16px;flex:1;text-align:center}.stage-detail__stat-item--accent{background:var(--accent-bg);border-color:color-mix(in srgb,var(--accent) 20%,transparent)}.stage-detail__stat-value{font:700 18px/1 var(--font-display)}.stage-detail__stat-item--accent .stage-detail__stat-value{color:var(--accent)}.stage-detail__stat-label{font-size:10px;color:var(--fg-tertiary);margin-top:2px}.stage-detail__stat-item--accent .stage-detail__stat-label{color:var(--accent)}.stage-detail__participants-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:16px;margin-bottom:16px}.stage-detail__participants-title{font:600 14px/1 var(--font-body);color:var(--fg-secondary);margin-bottom:12px}.stage-detail__participant{display:flex;align-items:center;gap:8px}.stage-detail__participant-name{font:500 14px/1 var(--font-body)}.stage-detail__participant-role{font-size:11px;color:var(--fg-tertiary)}.stage-detail__invite-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px}.stage-detail__invite-label{font-size:10px;color:var(--fg-tertiary);margin-bottom:2px}.stage-detail__invite-code{font:600 16px/1 var(--font-display);letter-spacing:.05em;font-variant-numeric:tabular-nums}.stage-detail__voice-heading{font:600 16px/1 var(--font-display);margin-bottom:12px}.visibility-btn{padding:8px 16px;border-radius:8px;font:500 14px/1 var(--font-body);cursor:pointer;transition:all .15s}.visibility-btn--active{border:1px solid var(--accent);background:var(--accent-bg);color:var(--accent)}.visibility-btn--default{border:1px solid var(--border);background:transparent;color:var(--fg-secondary)}.visibility-btn--default:hover{border-color:var(--fg-secondary)}.join-code-input{font-size:24px;text-align:center;letter-spacing:8px}@media (min-width: 768px){.stage-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}}.practice-control-bar{position:fixed;bottom:0;left:0;right:0;z-index:999;background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.06);box-shadow:0 -2px 8px #0000000f}.practice-control-bar__toggle{display:flex;justify-content:center;margin-top:-1px}.practice-control-bar__collapse-btn{width:40px;height:20px;border:none;background:none;cursor:pointer;color:var(--fg-tertiary);display:flex;align-items:center;justify-content:center}.practice-control-bar__body{display:flex;align-items:center;justify-content:space-between;padding:4px 16px 8px;gap:16px}.practice-control-bar__status{display:flex;align-items:center;gap:6px;min-width:100px}.practice-control-bar__dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.practice-control-bar__label{font-size:12px;color:var(--fg-tertiary);white-space:nowrap}.practice-control-bar__center{display:flex;align-items:center;justify-content:center;flex:1}.practice-control-bar__extra{display:flex;align-items:center;justify-content:flex-end;min-width:100px;padding-right:48px}@media (max-width: 767px){.practice-control-bar__status{min-width:auto}.practice-control-bar__extra{min-width:auto;padding-right:0}.practice-control-bar__body{gap:8px}}@media (min-width: 768px) and (max-width: 1199px){.practice-control-bar{left:72px}}@media (min-width: 1200px){.practice-control-bar{left:220px}}.ctrl-circle{width:44px;height:44px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0;font-size:18px}.ctrl-circle--primary{background:var(--accent);color:var(--surface)}.ctrl-circle--primary:hover{filter:brightness(1.08);transform:scale(1.04)}.ctrl-circle--primary:disabled{opacity:.4;cursor:default;transform:none;filter:none}.ctrl-circle--danger{background:var(--error);color:var(--surface)}.ctrl-circle--danger:hover{filter:brightness(1.08);transform:scale(1.04)}.ctrl-circle--default{background:var(--surface);border:1px solid var(--border);color:var(--fg-secondary)}.ctrl-circle--default:hover{border-color:var(--accent);color:var(--accent)}.ctrl-circle--default:disabled{opacity:.4;cursor:default}.custom-check{width:18px;height:18px;border:1.5px solid var(--border);border-radius:4px;background:var(--surface);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.custom-check.is-checked{background:var(--accent);border-color:var(--accent)}.custom-check.is-checked svg{color:var(--surface)}.custom-check.is-indeterminate{background:var(--accent);border-color:var(--accent)}.custom-check.is-indeterminate:after{content:"";width:8px;height:2px;background:#fff;border-radius:1px}.ctrl-text-btn{display:inline-flex;align-items:center;gap:4px;border:none;background:none;cursor:pointer;font-size:13px;color:var(--fg-secondary);padding:4px 8px;border-radius:6px;transition:all .15s;white-space:nowrap}.ctrl-text-btn:hover{background:var(--border-light);color:var(--fg)}.ctrl-text-btn:disabled{opacity:.4;cursor:default}.ctrl-text-btn--save{color:var(--accent);font-weight:600}.ctrl-text-btn--save:hover{background:var(--accent-bg)}.share-public-page{max-width:640px;margin:0 auto;padding:var(--space-lg);min-height:100vh}.share-header{margin-bottom:var(--space-lg)}.share-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:8px}.share-error__title{font-size:18px;font-weight:600;color:var(--fg)}.share-error__text{font-size:15px;color:var(--fg-secondary)}.notif-bell{position:relative;width:36px;height:36px;border:none;background:none;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--fg-secondary);transition:background .15s}.notif-bell:hover{background:var(--border-light)}.notif-bell__badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;border-radius:8px;background:var(--error);color:var(--surface);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}.notif-panel__drawer{width:350px;display:flex;flex-direction:column}.notif-panel__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.notif-panel__title{font:600 16px/1 var(--font-display);display:flex;align-items:center;gap:8px;margin:0}.notif-panel__title-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;background:var(--error);color:var(--surface);font-size:11px;font-weight:600;padding:0 5px}.notif-panel__actions{display:flex;gap:4px}.notif-panel__btn{width:32px;height:32px;border:none;background:none;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--fg-secondary);transition:background .15s}.notif-panel__btn:hover{background:var(--border-light)}.notif-panel__btn:disabled{opacity:.4;cursor:default}.notif-panel__btn:disabled:hover{background:none}.notif-list{flex:1;overflow-y:auto}.notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .15s}.notif-item:hover{background:var(--border-light)}.notif-item--unread{background:var(--success-bg);border-left:3px solid var(--success)}.notif-item__icon{width:28px;height:28px;border-radius:50%;background:var(--border-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.notif-item__icon--success{color:var(--success)}.notif-item__icon--warning{color:var(--warning)}.notif-item__icon--error{color:var(--error)}.notif-item__icon--info{color:var(--info)}.notif-item__body{flex:1;min-width:0}.notif-item__row{display:flex;align-items:center;gap:6px;margin-bottom:2px}.notif-item__title{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.notif-item--read .notif-item__title{font-weight:400}.notif-item__dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block;animation:notifPulse 2s linear infinite;flex-shrink:0}@keyframes notifPulse{0%,to{opacity:1}50%{opacity:.3}}.notif-item__content{font-size:13px;color:var(--fg-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-item__time{font-size:11px;color:var(--fg-tertiary);margin-top:4px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.notif-item__cat{font-size:10px;height:18px;padding:0 6px;border:1px solid var(--border);border-radius:4px;display:inline-flex;align-items:center}.notif-item__actions{display:flex;gap:2px;flex-shrink:0;align-items:flex-start}.notif-item__act{width:28px;height:28px;border:none;background:none;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--fg-secondary);font-size:14px;transition:all .15s}.notif-item__act:hover{background:var(--border-light)}.notif-item__act--del:hover{color:var(--error)}.notif-item__action{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;margin-top:6px;border-radius:6px;font:500 11px/1 var(--font-body);cursor:pointer;transition:all .15s;border:1px solid var(--accent);color:var(--accent);background:var(--accent-bg)}.notif-item__action:hover{background:var(--accent);color:var(--surface)}.notif-empty{text-align:center;padding:40px 20px;color:var(--fg-tertiary);font-size:14px}.notif-overlay{position:fixed;inset:0;background:#0000004d;z-index:200;display:none}.notif-overlay.open{display:block}.notif-drawer{position:fixed;top:0;right:-352px;width:350px;height:100%;background:var(--surface);border-left:1px solid var(--border);z-index:201;display:flex;flex-direction:column;transition:right .3s ease;box-shadow:-4px 0 20px #00000014}.notif-drawer.open{right:0}.m-notif-page{display:none;position:fixed;inset:0;background:var(--bg);z-index:150;overflow-y:auto;-webkit-overflow-scrolling:touch;flex-direction:column}.m-notif-page.open{display:flex}.m-notif-page__nav{display:flex;align-items:center;gap:12px;padding:52px 20px 12px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:2}.m-notif-page__back{width:32px;height:32px;border:none;background:none;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--fg-secondary);transition:background .15s}.m-notif-page__back:hover{background:var(--border-light)}.m-notif-page__title{font:600 17px/1 var(--font-display);display:flex;align-items:center;gap:8px}.m-notif-page__title-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;background:var(--error);color:var(--surface);font-size:11px;font-weight:600;padding:0 5px}.m-notif-page__actions{margin-left:auto;display:flex;gap:2px}.m-notif-page__btn{width:32px;height:32px;border:none;background:none;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--fg-secondary);font-size:14px;transition:background .15s}.m-notif-page__btn:hover{background:var(--border-light)}.m-notif-page__btn:disabled{opacity:.4;cursor:default}.m-notif-list{padding:0 16px 16px;flex:1}.m-notif-item{display:flex;gap:10px;padding:12px 0;border-bottom:1px solid var(--border-light);cursor:pointer;position:relative}.m-notif-item:last-child{border-bottom:none}.m-notif-item--unread{background:var(--success-bg)}.m-notif-item--unread:before{content:"";position:absolute;left:-16px;top:12px;width:6px;height:6px;border-radius:50%;background:var(--success)}.m-notif-item__body{flex:1;min-width:0}.m-notif-item__title{font:500 14px/1.4 var(--font-body);display:flex;align-items:center;gap:6px}.m-notif-item__content{font-size:13px;color:var(--fg-secondary);margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}.m-notif-item__meta{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.m-notif-item__time{font-size:12px;color:var(--fg-tertiary)}.m-notif-item__cat{font-size:11px;color:var(--accent);background:var(--accent-bg);padding:1px 6px;border-radius:4px}.m-notif-item__action{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;margin-top:6px;border-radius:6px;font:500 11px/1 var(--font-body);cursor:pointer;transition:all .15s;border:1px solid var(--accent);color:var(--accent);background:var(--accent-bg)}.m-notif-item__action:hover{background:var(--accent);color:var(--surface)}.m-notif-empty{display:none;text-align:center;padding:60px 20px;color:var(--fg-tertiary);font-size:14px}.m-notif-empty.show{display:block}.m-notif-empty__icon{font-size:40px;margin-bottom:12px;opacity:.3}.auth-shell{display:flex;min-height:100vh;min-height:100dvh;background:var(--bg)}.auth-brand-panel{width:420px;flex-shrink:0;background:linear-gradient(160deg,var(--accent-light) 0%,var(--accent-bg) 50%,var(--bg) 100%);padding:48px 40px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid var(--border)}.auth-brand-logo{font:700 24px/1 var(--font-display);color:var(--brand);letter-spacing:-.02em;margin-bottom:24px}.auth-brand-logo span{color:var(--fg)}.auth-brand-headline{font:700 32px/1.2 var(--font-display);color:var(--fg);letter-spacing:-.02em;margin-bottom:12px}.auth-brand-desc{font:400 15px/1.65 var(--font-body);color:var(--fg-secondary);margin-bottom:40px}.auth-brand-features{display:flex;flex-direction:column;gap:20px}.auth-brand-feature{display:flex;gap:14px}.auth-brand-feature__icon{width:40px;height:40px;flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--brand)}.auth-brand-feature__icon svg{width:20px;height:20px}.auth-brand-feature__text h4{font:600 14px/1.4 var(--font-display);color:var(--fg);margin-bottom:2px}.auth-brand-feature__text p{font:400 13px/1.5 var(--font-body);color:var(--fg-secondary)}.auth-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:48px}.auth-form-container{width:100%;max-width:400px}.auth-mobile-logo{display:none}.auth-mobile-logo__icon{width:32px;height:32px;color:var(--brand)}.auth-mobile-logo__icon svg{width:100%;height:100%}.auth-mobile-logo__text{font:700 20px/1 var(--font-display);color:var(--brand)}.auth-mobile-logo__text span{color:var(--fg)}.auth-form-title{font:700 28px/1.2 var(--font-display);color:var(--fg);margin-bottom:6px}.auth-form-subtitle{font:400 15px/1.5 var(--font-body);color:var(--fg-secondary);margin-bottom:28px}.auth-field{margin-bottom:18px}.auth-field__label{display:block;font:500 14px/1 var(--font-body);color:var(--fg);margin-bottom:6px}.auth-field__wrap{position:relative}.auth-field__input{width:100%;height:48px;padding:0 16px;border:1px solid var(--border);border-radius:var(--radius-input);font:400 15px/1 var(--font-body);color:var(--fg);background:var(--surface);outline:none;transition:border-color .15s}.auth-field__input:focus{border-color:var(--accent)}.auth-field__input::placeholder{color:var(--fg-tertiary)}.auth-field__input--has-icon{padding-right:44px}.auth-field__input--error{border-color:var(--error)}.auth-field__toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:36px;height:36px;border:none;background:none;cursor:pointer;color:var(--fg-tertiary);display:flex;align-items:center;justify-content:center;border-radius:8px}.auth-field__toggle:hover{color:var(--fg-secondary)}.auth-field__toggle svg{width:18px;height:18px}.auth-field__error{font-size:12px;color:var(--error);margin-top:4px}.auth-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.auth-remember{display:flex;align-items:center;gap:8px;font:400 14px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer}.auth-remember input[type=checkbox]{accent-color:var(--accent)}.auth-forgot{font:500 14px/1 var(--font-body);color:var(--accent);text-decoration:none}.auth-pwd-strength{display:flex;gap:4px;margin-top:8px}.auth-pwd-strength .bar{flex:1;height:3px;background:var(--border);border-radius:2px;transition:background .2s}.auth-pwd-strength .bar.filled.s1{background:var(--error)}.auth-pwd-strength .bar.filled.s2{background:var(--warning)}.auth-pwd-strength .bar.filled.s3{background:var(--strength-lime)}.auth-pwd-strength .bar.filled.s4{background:var(--success)}.auth-strength-text{font-size:12px;color:var(--fg-tertiary);margin-top:4px}.auth-terms{display:flex;align-items:flex-start;gap:8px;font:400 13px/1.5 var(--font-body);color:var(--fg-secondary);margin-bottom:20px;cursor:pointer}.auth-terms input[type=checkbox]{margin-top:2px;accent-color:var(--accent)}.auth-terms a{color:var(--accent);text-decoration:none}.auth-submit{width:100%;height:48px;border:none;border-radius:var(--radius-btn);background:var(--accent);color:var(--surface);font:600 16px/1 var(--font-body);cursor:pointer;transition:filter .15s,transform .15s}.auth-submit:hover{filter:brightness(1.08);transform:translateY(-1px)}.auth-submit:active{transform:translateY(0)}.auth-submit:disabled{opacity:.5;cursor:default;transform:none;filter:none}.auth-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--fg-tertiary);font-size:13px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-social-buttons{display:flex;gap:12px}.auth-social-btn{flex:1;height:44px;border:1px solid var(--border);border-radius:var(--radius-btn);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font:500 14px/1 var(--font-body);color:var(--fg);transition:background .15s}.auth-social-btn:hover{background:var(--border-light)}.auth-social-btn svg{width:18px;height:18px}.auth-social-btn--wechat svg{color:var(--wechat-green)}.auth-social-btn--apple svg{color:var(--fg)}.auth-footer{text-align:center;margin-top:24px;font:400 14px/1 var(--font-body);color:var(--fg-secondary)}.auth-footer a{color:var(--accent);text-decoration:none;font-weight:500}.auth-success-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:40px;text-align:center;background:var(--surface)}.auth-success-icon{width:64px;height:64px;border-radius:50%;background:var(--success-bg);color:var(--success);display:flex;align-items:center;justify-content:center;margin-bottom:20px}.auth-success-icon svg{width:32px;height:32px}.auth-success-title{font:700 24px/1.2 var(--font-display);color:var(--fg);margin-bottom:8px}.auth-success-desc{font:400 15px/1.6 var(--font-body);color:var(--fg-secondary);margin-bottom:24px}.auth-success-btn{height:48px;padding:0 32px;border:none;border-radius:var(--radius-btn);background:var(--accent);color:var(--surface);font:600 16px/1 var(--font-body);cursor:pointer}@media (max-width: 768px){.auth-shell{flex-direction:column}.auth-brand-panel{display:none}.auth-mobile-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px}.auth-form-panel{padding:32px 20px;align-items:flex-start}.auth-form-title{font-size:24px}}@media (min-width: 769px) and (max-width: 1024px){.auth-brand-panel{width:280px;padding:36px 28px}.auth-brand-features{display:none}.auth-brand-headline{font-size:26px}.auth-brand-desc{font-size:14px}.auth-form-panel{padding:36px}.auth-form-container{max-width:360px}}@media (min-width: 1025px){.auth-brand-panel{width:420px;padding:48px 40px}}.ce-back{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--fg-secondary);cursor:pointer;padding:4px 0;margin-bottom:8px;background:none;border:none}.ce-back:hover{color:var(--accent)}.ce-header{margin-bottom:16px}.ce-title{font:700 22px/1.2 var(--font-display);margin-bottom:2px}.ce-subtitle{font-size:14px;color:var(--fg-secondary)}.char-avatar-sm{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0}.char-section-divider{display:flex;align-items:center;gap:8px;font:600 15px/1 var(--font-display);color:var(--fg);padding:12px 0 8px;border-top:1px solid var(--border);margin-top:8px}.char-section-divider svg{color:var(--accent);width:16px;height:16px}.voice-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:16px;margin-bottom:16px}.voice-card-assigned{display:flex;align-items:center;gap:12px;padding:12px;background:var(--accent-bg);border-radius:8px}.voice-play-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}.voice-match-badge{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:22px;border-radius:11px;border:2px solid var(--success);font:600 11px/1 var(--font-body);padding:0 6px}.voice-rec-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px;cursor:pointer;transition:all .15s}.voice-rec-item:hover{border-color:var(--accent)}.voice-rec-item.selected{border-color:var(--accent);background:var(--accent-bg)}.char-edit-actions{display:flex;gap:8px;margin-bottom:16px}.ce-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}.ce-tab{padding:10px 16px;border:none;background:none;font:500 14px/1 var(--font-body);color:var(--fg-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.ce-tab.is-active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.ce-tab:hover{color:var(--accent)}.recording-page{max-width:640px;padding:var(--space-md)}.recording-stats{display:flex;gap:0;border-radius:var(--radius-card);background:var(--surface);border:1px solid var(--border);margin-bottom:var(--space-md);overflow:hidden}.recording-stat{flex:1;text-align:center;padding:14px 8px;border-right:1px solid var(--border-light)}.recording-stat:last-child{border-right:none}.recording-stat__value{font:700 18px/1.2 var(--font-display);color:var(--fg);font-variant-numeric:tabular-nums}.recording-stat__label{font-size:11px;color:var(--fg-tertiary);margin-top:3px}.recording-search{position:relative;margin-bottom:10px}.recording-search__icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--fg-tertiary);pointer-events:none}.recording-search__input{width:100%;height:40px;padding:0 12px 0 38px;border:1px solid var(--border);border-radius:var(--radius-input);font:400 14px/1 var(--font-body);color:var(--fg);background:var(--surface);outline:none;transition:border-color .15s}.recording-search__input:focus{border-color:var(--accent)}.recording-search__input::placeholder{color:var(--fg-tertiary)}.recording-filters{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:var(--space-md);flex-wrap:wrap}.recording-pills{display:flex;gap:6px}.recording-sort{height:32px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface);font:500 13px/1 var(--font-body);color:var(--fg-secondary);outline:none;cursor:pointer}.recording-sort:focus{border-color:var(--accent)}.recording-list{display:flex;flex-direction:column;gap:6px}.recording-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);transition:box-shadow .15s}.recording-item:hover{box-shadow:0 2px 8px #0000000d}.recording-item__play{width:36px;height:36px;border-radius:50%;border:none;background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s}.recording-item__play:hover,.recording-item__play.is-playing{background:var(--accent);color:var(--surface)}.recording-item__body{flex:1;min-width:0}.recording-item__title{font:500 15px/1.3 var(--font-body);color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recording-item__meta{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--fg-tertiary);margin-top:3px}.recording-item__dot{opacity:.4}.recording-item__actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.recording-badge{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:4px;font:600 11px/1 var(--font-body);white-space:nowrap}.recording-badge--practice{background:var(--warning-bg);color:var(--warning)}.recording-badge--perf{background:var(--accent-bg);color:var(--accent)}.recording-badge--published{background:var(--success-bg);color:var(--success)}.recording-item__delete{width:28px;height:28px;border-radius:6px;border:none;background:none;color:var(--fg-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.recording-item__delete:hover{background:var(--error-bg);color:var(--error)}.recording-item__delete:disabled{opacity:.3;cursor:default}.recording-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-top:var(--space-md)}.recording-page-btn{height:32px;padding:0 14px;border:1px solid var(--border);border-radius:var(--radius-btn);background:var(--surface);font:500 13px/1 var(--font-body);color:var(--fg);cursor:pointer;transition:all .15s}.recording-page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.recording-page-btn:disabled{opacity:.35;cursor:default}.recording-page-info{font-size:13px;color:var(--fg-tertiary);min-width:48px;text-align:center;font-variant-numeric:tabular-nums}.legal-page{min-height:100vh;background:var(--bg);padding:24px 16px 48px}.legal-page__container{max-width:720px;margin:0 auto}.legal-page__back{display:inline-flex;align-items:center;gap:6px;color:var(--fg-secondary);text-decoration:none;font-size:14px;margin-bottom:20px;transition:color .15s}.legal-page__back:hover{color:var(--accent)}.legal-page__title{font-size:28px;font-weight:700;color:var(--fg);margin:0 0 4px}.legal-page__updated{font-size:13px;color:var(--fg-tertiary);margin:0 0 32px}.legal-page__content h2{font-size:17px;font-weight:600;color:var(--fg);margin:28px 0 12px}.legal-page__content h2:first-child{margin-top:0}.legal-page__content p{font-size:15px;line-height:1.7;color:var(--fg-secondary);margin:0 0 12px}.legal-page__content ul{padding-left:20px;margin:0 0 12px}.legal-page__content li{font-size:15px;line-height:1.7;color:var(--fg-secondary);margin-bottom:6px}.legal-page__link{color:var(--accent);text-decoration:none}.legal-page__link:hover{text-decoration:underline}
