.admin-topbar[data-v-1b221e2b]{background:linear-gradient(135deg,#1e1b4b,#312e81);border-bottom:none}.admin-topbar .nav-item[data-v-1b221e2b]{color:#ffffffb3}.admin-topbar .nav-item[data-v-1b221e2b]:hover,.admin-topbar .nav-item.router-link-active[data-v-1b221e2b]{background:#ffffff1f;color:#fff}.admin-topbar .brand[data-v-1b221e2b]{color:#e0e7ff}.admin-badge[data-v-1b221e2b]{background:#ffffff26;color:#e0e7ff;padding:2px 12px;border-radius:20px;font-size:.75rem;font-weight:600}.admin-avatar[data-v-1b221e2b]{background:#6366f1}.lang-switcher[data-v-1b221e2b]{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.lang-current[data-v-1b221e2b]{font-size:.78rem;color:var(--text-muted);padding:3px 8px;border-radius:4px;border:1px solid var(--border);transition:all .12s}.lang-current[data-v-1b221e2b]:hover{border-color:var(--primary);color:var(--primary)}.admin-topbar .lang-current[data-v-1b221e2b]{color:#fff9;border-color:#fff3}.admin-topbar .lang-current[data-v-1b221e2b]:hover{border-color:#fff6;color:#fff}.lang-dropdown[data-v-1b221e2b]{position:absolute;top:100%;right:0;margin-top:6px;background:#fff;border-radius:8px;box-shadow:0 4px 16px #0000001f;border:1px solid var(--border);min-width:110px;z-index:300;overflow:hidden}.lang-item[data-v-1b221e2b]{padding:8px 14px;font-size:.82rem;color:var(--text);cursor:pointer;transition:background .1s}.lang-item[data-v-1b221e2b]:hover{background:var(--primary-light)}.lang-item.active[data-v-1b221e2b]{color:var(--primary);font-weight:600;background:var(--primary-light)}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #6366f1;--primary-dark: #4f46e5;--primary-light: #eef2ff;--bg: #f8fafc;--bg-card: #ffffff;--text: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #e2e8f0;--border-light: #f1f5f9;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 4px 24px rgba(0,0,0,.1)}html,body,#app{height:100%;width:100%;margin:0;padding:0;overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}.topbar{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;height:56px}.topbar-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;height:100%;padding:0 20px;gap:20px}.brand{display:flex;align-items:center;gap:8px;text-decoration:none;font-weight:700;font-size:1.1rem;color:var(--primary)}.brand-icon{font-size:1.4rem}.nav-links{display:flex;gap:4px;flex:1}.nav-item{padding:6px 14px;border-radius:8px;text-decoration:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:all .15s}.nav-item:hover,.nav-item.router-link-active{background:var(--primary-light);color:var(--primary)}.topbar-right{display:flex;align-items:center;gap:12px}.free-badge{background:#dcfce7;color:#15803d;padding:2px 10px;border-radius:20px;font-size:.78rem;font-weight:600}.balance-display{cursor:pointer;padding:4px 12px;border-radius:8px;background:#f5f3ff;display:flex;gap:6px;align-items:baseline}.balance-label{font-size:.8rem;color:var(--text-muted)}.balance-amount{font-weight:700;color:var(--primary)}.user-menu{position:relative;cursor:pointer;display:flex;align-items:center;gap:6px}.avatar-circle{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.username{font-size:.9rem;color:var(--text-secondary)}.dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--border);min-width:180px;z-index:200;overflow:hidden}.dropdown-item{display:block;padding:10px 16px;font-size:.88rem;color:var(--text);text-decoration:none;cursor:pointer;transition:background .1s}.dropdown-item:hover{background:var(--primary-light)}.dropdown-divider{height:1px;background:var(--border);margin:4px 0}.bottombar{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);padding:6px 0;z-index:100}.bottom-item{display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none;color:var(--text-muted);font-size:.85rem;font-size:.7rem}.bottom-item.router-link-active{color:var(--primary)}.main-content{max-width:1200px;margin:0 auto;padding:24px 20px 80px;min-height:calc(100vh - 56px)}.page{animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 24px;border-radius:var(--radius-sm);font-size:.92rem;font-weight:600;border:none;cursor:pointer;transition:all .15s;text-decoration:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:var(--border-light);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-sm{padding:6px 14px;font-size:.82rem}.btn-full{width:100%}.card{background:var(--bg-card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:box-shadow .2s}.card:hover{box-shadow:var(--shadow-lg)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state .empty-icon{font-size:3rem;display:block;margin-bottom:12px}.empty-state p{margin-bottom:16px;font-size:.95rem}.empty-state-sm{text-align:center;padding:20px;color:var(--text-muted);font-size:.9rem}.field{margin-bottom:16px}.field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px;color:var(--text-secondary)}.field input,.field select,.field textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.92rem;outline:none;transition:border .15s;background:#fff;color:var(--text)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.error-msg{background:#fef2f2;color:var(--error);padding:10px 14px;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:12px}.steps{display:flex;gap:8px;margin-bottom:24px}.step{flex:1;padding:10px;text-align:center;background:var(--border-light);border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}.step span{width:22px;height:22px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem}.step.active{background:var(--primary-light);color:var(--primary)}.step.active span{background:var(--primary);color:#fff}.step.done{background:#dcfce7;color:#15803d}.step.done span{background:var(--success);color:#fff}.step-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.form-section{background:#fff;padding:24px;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin:16px 0}.avatar-card{border:2px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .15s}.avatar-card:hover{border-color:var(--primary)}.avatar-card.selected{border-color:var(--primary);box-shadow:0 0 0 3px #6366f133}.avatar-preview{aspect-ratio:9/16;background:#f1f5f9;display:flex;align-items:center;justify-content:center}.avatar-preview video,.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:2.5rem}.avatar-name{padding:8px;font-size:.82rem;font-weight:600;text-align:center}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:40px;text-align:center;cursor:pointer;margin:12px 0;transition:all .15s}.upload-area:hover{border-color:var(--primary);background:var(--primary-light)}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.9rem;color:var(--text-muted)}.up-icon{font-size:2.5rem}.up-hint{font-size:.78rem;color:var(--text-muted)}.auth-check{display:flex;align-items:flex-start;gap:8px;margin:12px 0;font-size:.85rem;color:var(--text-secondary)}.auth-check input{margin-top:3px}.script-editor{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;font-size:.92rem;resize:vertical;font-family:inherit;outline:none}.script-editor:focus{border-color:var(--primary)}.char-count{text-align:right;font-size:.8rem;color:var(--text-muted);margin-top:4px}.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.config-item label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px;color:var(--text-secondary)}.config-value{font-weight:600;color:var(--primary);margin-left:8px}.color-picker{width:48px;height:40px;padding:2px;border:1px solid var(--border);border-radius:6px;cursor:pointer}.switch-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400}.switch-label input{width:18px;height:18px}.cost-preview{background:#f5f3ff;border-radius:var(--radius);padding:16px 20px;margin-top:20px}.cost-detail{margin-top:8px}.cost-row{display:flex;justify-content:space-between;padding:6px 0;font-size:.9rem}.cost-row.total{border-top:1px solid #ddd6fe;margin-top:6px;padding-top:10px;font-weight:700}.total-price{color:var(--primary);font-size:1.1rem}.cost-free{color:var(--success);font-weight:700;margin-top:8px}.order-summary{margin:16px 0}.summary-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-light);font-size:.9rem}.summary-row.total{border-top:2px solid var(--border);border-bottom:none;margin-top:8px;padding-top:12px;font-weight:700}.invite-input{display:flex;gap:8px;align-items:center}.invite-valid{color:var(--success);font-weight:600;font-size:.85rem}.welcome-banner{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:var(--radius);padding:28px 32px;color:#fff;display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:24px}.welcome-text h2{font-size:1.4rem;margin-bottom:4px}.welcome-text p{opacity:.85;font-size:.9rem}.welcome-actions{display:flex;gap:12px}.welcome-actions .btn-primary{background:#fff;color:var(--primary)}.welcome-actions .btn-secondary{background:#ffffff26;color:#fff;border-color:#ffffff4d}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px;position:relative}.stat-icon{font-size:1.6rem}.stat-value{font-size:1.5rem;font-weight:800;color:var(--text)}.stat-label{font-size:.82rem;color:var(--text-muted)}.stat-link{position:absolute;top:16px;right:16px;font-size:.78rem;color:var(--primary);text-decoration:none}.quick-section{margin-bottom:24px}.quick-section h3{font-size:1.05rem;margin-bottom:14px}.quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.quick-card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);cursor:pointer;transition:all .15s;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}.quick-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.qc-icon{font-size:1.8rem}.qc-title{font-weight:700}.qc-desc{font-size:.82rem;color:var(--text-muted)}.pricing-preview{background:#fff;border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow)}.price-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-light);font-size:.9rem}.price-item:last-child{border-bottom:none}.price-value.free{color:var(--success)}.task-list{display:flex;flex-direction:column;gap:8px}.task-item{background:#fff;border-radius:var(--radius-sm);padding:12px 16px;box-shadow:var(--shadow);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .1s}.task-item:hover{box-shadow:var(--shadow-lg)}.task-script{font-size:.9rem;margin-bottom:4px}.task-meta{font-size:.78rem;color:var(--text-muted)}.task-status{font-size:.78rem;font-weight:600;padding:2px 10px;border-radius:20px}.task-status.pending{background:#fef3c7;color:#92400e}.task-status.processing{background:#dbeafe;color:#1e40af}.task-status.success{background:#dcfce7;color:#15803d}.task-status.failed{background:#fef2f2;color:#dc2626}.filter-tabs{display:flex;gap:4px}.filter-tabs button{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:#fff;font-size:.82rem;cursor:pointer;color:var(--text-secondary);transition:all .15s}.filter-tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.filter-tabs button:hover:not(.active){border-color:var(--primary);color:var(--primary)}.processing-bar{background:#dbeafe;padding:10px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:.88rem;color:#1e40af}.processing-dot{animation:pulse 1.2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.task-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}.task-card{background:#fff;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;transition:all .15s;position:relative}.task-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.task-preview{aspect-ratio:9/4;background:#f1f5f9;display:flex;align-items:center;justify-content:center;overflow:hidden}.task-preview video{width:100%;height:100%;object-fit:cover}.preview-placeholder{font-size:1.5rem}.spin{animation:spin 1.5s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.task-body{padding:8px 10px}.task-script{font-size:.75rem;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.task-meta-row{display:flex;gap:6px;align-items:center;font-size:.7rem}.task-duration{color:var(--text-muted)}.task-badge{font-size:.65rem;font-weight:600;padding:1px 6px;border-radius:20px}.task-badge.pending{background:#fef3c7;color:#92400e}.task-badge.processing{background:#dbeafe;color:#1e40af}.task-badge.success{background:#dcfce7;color:#15803d}.task-badge.failed{background:#fef2f2;color:#dc2626}.task-time{font-size:.65rem;color:var(--text-muted);margin-top:2px}.task-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.task-card:hover .task-overlay{opacity:1}.task-overlay .btn-sm{font-size:.7rem;padding:4px 10px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:500;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:#fff;border-radius:var(--radius);padding:28px;max-width:520px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal h3{margin-bottom:16px}.modal-sm{max-width:380px}.detail-grid{margin-bottom:16px}.detail-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border-light);font-size:.88rem}.detail-script{background:var(--border-light);border-radius:var(--radius-sm);padding:14px;margin:12px 0;font-size:.88rem;line-height:1.7}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.balance-card{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:var(--radius);padding:24px;margin-bottom:20px}.balance-label{font-size:.85rem;opacity:.8}.balance-value{font-size:2.5rem;font-weight:800;margin:4px 0}.balance-tip{font-size:.78rem;opacity:.65}.free-trial-card{background:#dcfce7;color:#15803d;padding:12px 20px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:.9rem}.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:16px 0 24px}.plan-card{background:#fff;border-radius:var(--radius);padding:24px;text-align:center;border:2px solid var(--border);position:relative;transition:all .2s}.plan-card:hover{border-color:var(--primary);transform:translateY(-2px)}.plan-card.recommend{border-color:var(--primary);background:linear-gradient(180deg,#f5f3ff,#fff)}.plan-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--primary);color:#fff;padding:2px 16px;border-radius:20px;font-size:.75rem;font-weight:600}.plan-price{font-size:2rem;font-weight:800;color:var(--text);margin:8px 0}.plan-total{font-size:.88rem;color:var(--text-secondary);margin-bottom:12px}.plan-bonus{color:var(--success);font-weight:700}.plan-features{list-style:none;padding:0;margin:12px 0}.plan-features li{padding:4px 0;font-size:.85rem;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.pricing-details{margin:20px 0}.pricing-details summary{cursor:pointer;font-weight:600;font-size:.9rem;padding:8px 0}.pricing-content{padding:12px 0}.pricing-row{display:flex;justify-content:space-between;padding:6px 0;font-size:.85rem;border-bottom:1px solid var(--border-light)}.pay-channel-list{display:flex;flex-direction:column;gap:8px;margin:16px 0}.pay-channel{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-weight:600}.pay-channel:hover{border-color:var(--primary);background:var(--primary-light)}.pc-icon{font-size:1.5rem}.invite-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.invite-stat-card{background:#fff;border-radius:var(--radius);padding:16px;text-align:center;box-shadow:var(--shadow)}.isc-value{font-size:1.5rem;font-weight:800;color:var(--primary)}.isc-label{font-size:.82rem;color:var(--text-muted)}.isc-limit{font-size:.7rem;color:var(--text-muted)}.invite-rules-card{background:#f5f3ff;border-radius:var(--radius);padding:20px;margin-bottom:20px;border:1px solid #ddd6fe}.rules-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}.rule-item{display:flex;gap:12px;align-items:flex-start;font-size:.88rem}.rule-icon{font-size:1.5rem}.code-list{display:flex;flex-direction:column;gap:8px}.code-card{display:flex;align-items:center;gap:16px;background:#fff;padding:12px 16px;border-radius:var(--radius-sm);box-shadow:var(--shadow)}.code-value{font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:700;letter-spacing:2px;color:var(--primary);min-width:140px}.code-meta{display:flex;gap:12px;align-items:center;font-size:.82rem;flex:1}.code-status{font-size:.75rem;font-weight:600;padding:1px 8px;border-radius:20px}.code-status.active{background:#dcfce7;color:#15803d}.code-status.used{background:var(--border-light);color:var(--text-muted)}.order-list{display:flex;flex-direction:column;gap:10px}.order-card{background:#fff;border-radius:var(--radius-sm);padding:14px 18px;box-shadow:var(--shadow)}.order-header{display:flex;justify-content:space-between;margin-bottom:8px}.order-no{font-family:monospace;font-size:.82rem;color:var(--text-muted)}.order-status{font-size:.78rem;font-weight:600;padding:1px 8px;border-radius:20px}.order-status.paid{background:#dcfce7;color:#15803d}.order-status.pending{background:#fef3c7;color:#92400e}.order-status.refunded{background:var(--border-light);color:var(--text-muted)}.order-body{display:flex;justify-content:space-between;align-items:center}.order-type{font-size:.9rem}.order-amount{font-size:1.1rem;font-weight:700}.amount-paid{color:var(--primary)}.order-footer{font-size:.78rem;color:var(--text-muted);margin-top:6px}.load-more{text-align:center;padding:20px}.profile-card{background:#fff;border-radius:var(--radius);padding:28px;display:flex;align-items:center;gap:20px;box-shadow:var(--shadow);margin-bottom:20px}.avatar-large{width:64px;height:64px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.profile-info h3{font-size:1.2rem;margin-bottom:2px}.profile-phone{font-size:.88rem;color:var(--text-muted)}.profile-since{font-size:.82rem;color:var(--text-muted)}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.stat-box{background:#fff;border-radius:var(--radius-sm);padding:16px;text-align:center;box-shadow:var(--shadow)}.sb-value{font-size:1.3rem;font-weight:800;color:var(--primary)}.sb-label{font-size:.82rem;color:var(--text-muted)}.settings-section{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-light)}.setting-item:last-child{border-bottom:none}.setting-right{display:flex;gap:8px;align-items:center}.setting-input{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:.88rem;outline:none}.setting-input:focus{border-color:var(--primary)}.login-page{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);padding:20px;z-index:1000}.login-card{background:#fff;border-radius:16px;padding:40px 36px;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:24px}.login-logo{font-size:2.5rem;display:block;margin-bottom:8px}.login-header h1{font-size:1.2rem;color:var(--text)}.login-sub{font-size:.82rem;color:var(--text-muted);margin-top:4px}.login-tabs{display:flex;margin-bottom:20px;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.login-tabs .tab{flex:1;padding:10px;text-align:center;border:none;background:#fff;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text-muted);transition:all .15s}.login-tabs .tab.active{background:var(--primary);color:#fff}.login-form .field{margin-bottom:14px}.login-form .field input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-size:.92rem;outline:none;transition:border .15s}.login-form .field input:focus{border-color:var(--primary)}.submit-btn{width:100%;padding:12px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .15s}.submit-btn:hover{background:var(--primary-dark)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.wechat-btn{width:100%;padding:12px;margin-top:12px;background:#07c160;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s}.wechat-btn:hover{background:#06ad56}.login-agreement{text-align:center;font-size:.78rem;color:var(--text-muted);margin-top:16px}.login-agreement a{color:var(--primary);text-decoration:none}.login-divider{display:flex;align-items:center;margin:20px 0 12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-divider span{padding:0 12px;font-size:.75rem;color:var(--text-muted)}.admin-login-btn{width:100%;padding:10px;border:1px dashed var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.82rem;cursor:pointer;transition:all .15s}.admin-login-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.admin-page{max-width:1200px}.admin-page h2{margin-bottom:20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014;font-size:.85rem}.admin-table th{background:#f8f9fc;padding:12px 14px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border)}.admin-table td{padding:10px 14px;border-bottom:1px solid var(--border-light)}.admin-table tr:hover td{background:#fafaff}.cell-id{font-family:monospace;font-size:.8rem;color:var(--text-muted);max-width:120px;overflow:hidden;text-overflow:ellipsis}.cell-time{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.status-select{padding:4px 8px;border:1px solid var(--border);border-radius:6px;font-size:.8rem;cursor:pointer}.tag-blue{display:inline-block;padding:1px 8px;border-radius:20px;font-size:.75rem;background:#e8f4fd;color:#1a73e8;font-weight:600}.tag-purple{display:inline-block;padding:1px 8px;border-radius:20px;font-size:.75rem;background:#f0e6ff;color:#7c3aed;font-weight:600}.status-active{color:#16a34a;font-weight:600}.status-frozen{color:#ea580c;font-weight:600}.status-disabled{color:#dc2626;font-weight:600}.status-paid,.status-success{color:#16a34a;font-weight:600}.status-pending{color:#ea580c;font-weight:600}.status-failed{color:#dc2626;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 768px){.topbar{height:50px}.topbar-inner{padding:0 12px;gap:10px}.nav-links{display:none}.bottombar{display:flex;justify-content:space-around;align-items:center;height:56px}.bottom-item{font-size:.7rem;padding:4px;min-width:0}.bottom-item span{font-size:.65rem}.main-content{padding:16px 12px 80px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:14px}.plan-grid,.config-grid{grid-template-columns:1fr}.invite-stats{grid-template-columns:repeat(2,1fr)}.rules-grid,.quick-grid{grid-template-columns:1fr}.welcome-banner{flex-direction:column;text-align:center}.welcome-actions{flex-direction:column;width:100%}.welcome-actions a{width:100%}.steps{flex-wrap:wrap}.step{flex:none;width:calc(50% - 4px);font-size:.78rem;padding:8px 6px}.filter-tabs{flex-wrap:wrap;gap:4px}.filter-tabs button{font-size:.78rem;padding:6px 12px}.username{display:none}.grid-2,.grid-3{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr)}.modal{margin:0;max-width:100%!important;border-radius:16px 16px 0 0;max-height:90vh;position:fixed;bottom:0;left:0;right:0}.modal-overlay{align-items:flex-end}.modal-lg{max-width:100%!important}.admin-topbar .nav-links{display:flex;overflow-x:auto;gap:0;flex:1}.admin-topbar .nav-item{font-size:.72rem;white-space:nowrap;padding:6px 10px}.admin-topbar .brand-text{display:none}.btn-primary,.btn-secondary,.btn-sm{min-height:40px;display:inline-flex;align-items:center;justify-content:center}.btn-sm{font-size:.8rem;padding:8px 14px}.admin-table{font-size:.75rem}.admin-table th,.admin-table td{padding:8px 6px}.cell-id{max-width:60px}.card{padding:14px}.script-editor{font-size:.92rem;padding:10px}.upload-panel{padding:14px}.upload-area{padding:24px 16px}.upload-fields{grid-template-columns:1fr}.category-tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}.cat-tab{font-size:.8rem;white-space:nowrap;padding:6px 12px;flex-shrink:0}.preview-body{max-height:300px}.preview-meta{grid-template-columns:1fr}.login-page{padding:0}.login-card{border-radius:0;min-height:100vh;padding:40px 20px}.login-card .field input{font-size:.95rem;padding:12px 14px}.submit-btn,.wechat-btn{padding:14px;font-size:.95rem}.admin-login-btn{padding:12px}}.section-tabs{display:flex;gap:0;margin-bottom:20px;background:var(--bg-card);border-radius:var(--radius);padding:4px;box-shadow:var(--shadow)}.section-tab{flex:1;padding:10px 20px;border:none;border-radius:calc(var(--radius) - 4px);background:transparent;font-size:.92rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s;text-align:center}.section-tab:hover{color:var(--text);background:var(--border-light)}.section-tab.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #6366f140}.material-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.material-card{background:var(--bg-card);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;transition:all .15s;position:relative;border:2px solid transparent}.material-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.material-card.selected{border-color:var(--primary)}.mat-checkbox{position:absolute;top:4px;left:4px;z-index:2}.check-box{width:18px;height:18px;border-radius:3px;border:2px solid rgba(255,255,255,.7);background:#0000004d;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#fff;transition:all .12s}.check-box.checked{background:var(--primary);border-color:var(--primary)}.mat-thumb{position:relative;aspect-ratio:4/3;background:#f1f5f9;display:flex;align-items:center;justify-content:center;overflow:hidden}.mat-thumb video,.mat-thumb img{width:100%;height:100%;object-fit:cover}.mat-type-badge{position:absolute;bottom:3px;right:3px;font-size:.55rem;padding:1px 5px;border-radius:3px;background:#0000008c;color:#fff}.audio-placeholder,.mat-placeholder{font-size:1.6rem}.mat-info{padding:5px 7px}.mat-name{font-size:.75rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mat-meta{display:flex;gap:5px;font-size:.62rem;color:var(--text-muted);margin-top:2px}.mat-category{background:var(--primary-light);color:var(--primary);padding:0 5px;border-radius:3px;font-size:.6rem}.mat-actions{display:flex;gap:3px;padding:3px 7px 5px;justify-content:flex-end;opacity:0;transition:opacity .15s}.material-card:hover .mat-actions{opacity:1}.mat-actions .btn-sm{padding:2px 7px;font-size:.7rem}.filter-bar{margin-bottom:12px}.filter-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}.filter-row.secondary{margin-bottom:0}.filter-search{position:relative;flex:1;min-width:180px;max-width:320px}.filter-search .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:.82rem;pointer-events:none}.input-search{width:100%;padding:7px 30px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.83rem;outline:none;transition:border .15s;background:#fff}.input-search:focus{border-color:var(--primary)}.search-clear{position:absolute;right:5px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:.75rem;color:var(--text-muted)}.filter-chips{display:flex;gap:4px;flex-wrap:wrap}.chip{padding:4px 12px;border-radius:16px;border:1px solid var(--border);background:#fff;font-size:.76rem;cursor:pointer;color:var(--text-secondary);transition:all .12s;white-space:nowrap}.chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.chip:hover:not(.active){border-color:var(--primary);color:var(--primary)}.filter-select{padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.78rem;background:#fff;outline:none;color:var(--text)}.filter-order-btn{padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;cursor:pointer;font-size:.85rem;transition:all .12s}.filter-order-btn:hover{border-color:var(--primary);color:var(--primary)}.filter-date-range{display:flex;align-items:center;gap:5px}.input-date{padding:4px 7px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.78rem;outline:none}.btn-text{background:none;border:none;cursor:pointer;font-size:.78rem;color:var(--primary);padding:4px 8px}.btn-text:hover{text-decoration:underline}.filter-count{font-size:.76rem;color:var(--text-muted);white-space:nowrap}.category-tabs{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap}.cat-tab{padding:4px 12px;border-radius:16px;border:1px solid var(--border);background:#fff;font-size:.78rem;cursor:pointer;color:var(--text-secondary);transition:all .12s}.cat-tab.active{background:var(--primary-light);color:var(--primary);border-color:var(--primary);font-weight:600}.cat-tab:hover:not(.active){border-color:var(--primary)}.cat-count{font-size:.68rem;color:var(--text-muted);margin-left:3px}.cat-add-btn{width:26px;height:26px;border-radius:50%;border:1px dashed var(--border);background:#fff;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .12s}.cat-add-btn:hover{border-color:var(--primary);color:var(--primary)}.new-category-form{display:flex;gap:8px;align-items:center;margin-bottom:12px}.input-sm{padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.83rem;outline:none}.input-sm:focus{border-color:var(--primary)}.batch-bar{display:flex;align-items:center;justify-content:space-between;background:var(--primary-light);border:1px solid var(--primary);border-radius:var(--radius-sm);padding:7px 12px;margin-bottom:12px}.batch-info{font-size:.82rem;font-weight:600;color:var(--primary)}.batch-actions{display:flex;gap:8px}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:20px}.page-info{font-size:.83rem;color:var(--text-muted)}.loading-state{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:.92rem}.empty-hint{font-size:.8rem;color:var(--text-muted)}.upload-panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;overflow:hidden}.upload-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-bottom:1px solid var(--border-light)}.upload-panel-header h3{font-size:.92rem}.upload-body{padding:18px}.upload-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}.file-selected{display:flex;flex-direction:column;align-items:center;gap:6px}.file-name{font-weight:600;font-size:.85rem;color:var(--text)}.file-size{font-size:.75rem;color:var(--text-muted)}.file-change{font-size:.72rem;color:var(--primary)}.upload-status{padding:7px 12px;border-radius:var(--radius-sm);font-size:.82rem;margin-bottom:12px}.upload-status.success{background:#dcfce7;color:#15803d}.upload-status.error{background:#fef2f2;color:#dc2626}.upload-status.info{background:#dbeafe;color:#1e40af}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.modal-header h3{margin-bottom:0}.preview-body{background:#f1f5f9;border-radius:var(--radius-sm);overflow:hidden;margin-bottom:14px}.preview-video,.preview-image{width:100%;max-height:380px;object-fit:contain;display:block}.preview-audio{padding:40px;text-align:center}.audio-icon{font-size:2.5rem;margin-bottom:10px}.preview-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px}.meta-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--border-light);font-size:.82rem}.roles-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.roles-desc{font-size:.83rem;color:var(--text-muted);flex:1}.role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.role-card{background:var(--bg-card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;transition:all .15s;position:relative;border:2px solid transparent}.role-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.role-preview{aspect-ratio:4/3;background:#f1f5f9;display:flex;align-items:center;justify-content:center;overflow:hidden}.role-preview video,.role-preview img{width:100%;height:100%;object-fit:cover}.role-placeholder{font-size:1.8rem}.role-body{padding:7px 9px 9px}.role-name{font-size:.82rem;font-weight:600;margin-bottom:3px}.role-voice-badge{font-size:.68rem;color:var(--text-muted);margin-bottom:3px}.role-desc-preview{font-size:.7rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-style:italic}.role-del-btn{position:absolute;top:5px;right:5px;background:#00000059;border:none;border-radius:5px;padding:2px 5px;cursor:pointer;font-size:.72rem;opacity:0;transition:opacity .15s}.role-card:hover .role-del-btn{opacity:1}.role-avatar-select{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:8px;max-height:160px;overflow-y:auto;padding:4px}.role-av-item{border:2px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:all .12s;text-align:center;padding:4px}.role-av-item:hover{border-color:var(--primary-light)}.role-av-item.selected{border-color:var(--primary);background:var(--primary-light)}.role-av-thumb{aspect-ratio:1;background:#f1f5f9;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:4px}.role-av-thumb video,.role-av-thumb img{width:100%;height:100%;object-fit:cover}.role-av-name{font-size:.65rem;color:var(--text-secondary);display:block;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-voice-type{display:flex;gap:10px}.voice-type-option{flex:1;display:flex;align-items:center;gap:6px;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .12s;font-size:.83rem}.voice-type-option.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.voice-type-option input{display:none}.role-audio-upload{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.audio-file-name{font-size:.75rem;color:var(--text-muted)}.textarea-sm{resize:vertical;min-height:56px}.field-hint{display:block;font-size:.7rem;color:var(--text-muted);margin-top:3px}@media (max-width: 768px){.material-grid,.role-grid{grid-template-columns:repeat(2,1fr);gap:8px}.roles-header{flex-direction:column;gap:10px;align-items:stretch}.filter-search{min-width:140px;max-width:100%}.upload-fields{grid-template-columns:1fr}}.step1-tabs{display:flex;gap:8px;margin-bottom:16px}.step1-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius);background:var(--bg-card);cursor:pointer;transition:all .2s;position:relative;font-size:.92rem;font-weight:600;color:var(--text-secondary)}.step1-tab:hover{border-color:var(--primary-light);background:var(--primary-light);color:var(--primary)}.step1-tab.active{border-color:var(--primary);background:linear-gradient(135deg,#f5f3ff,#eef2ff);color:var(--primary);box-shadow:0 2px 12px #6366f126}.tab-icon{font-size:1.3rem;line-height:1}.tab-label{line-height:1}.tab-count{font-size:.7rem;font-weight:700;padding:1px 8px;border-radius:20px;background:var(--border-light);color:var(--text-muted);line-height:1.4}.step1-tab.active .tab-count{background:var(--primary);color:#fff}.create-select-info{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--primary-light);border:1px solid var(--primary);border-radius:var(--radius-sm);margin-bottom:12px;font-size:.85rem;font-weight:600;color:var(--primary)}.avatar-checkbox{position:absolute;top:6px;left:6px;z-index:2}.av-check-box{width:20px;height:20px;border-radius:4px;border:2px solid rgba(255,255,255,.7);background:#0000004d;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#fff;transition:all .12s}.av-check-box.checked{background:var(--primary);border-color:var(--primary)}.upload-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-muted);font-size:.82rem}.upload-divider:before,.upload-divider:after{content:"";flex:1;height:1px;background:var(--border)}.camera-recorder{background:var(--bg);border-radius:var(--radius);padding:20px;max-width:500px;margin:0 auto}.cr-phase{display:flex;flex-direction:column;align-items:center;gap:16px}.cr-idle{padding:32px 16px;text-align:center}.cr-idle-icon{font-size:3.5rem;margin-bottom:8px}.cr-idle-text{font-size:.92rem;color:var(--text-secondary);margin-bottom:8px}.cr-video-wrapper{width:100%;border-radius:var(--radius);overflow:hidden;background:#000;position:relative;aspect-ratio:9/16;max-height:420px}.cr-video{width:100%;height:100%;object-fit:contain;display:block;background:#000}.cr-watermark{position:absolute;bottom:12px;left:12px;color:#fff9;font-size:.78rem;background:#0006;padding:3px 10px;border-radius:4px;pointer-events:none}.cr-rec-indicator{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:6px;color:#f44;font-size:.88rem;font-weight:700;background:#00000080;padding:4px 12px;border-radius:20px;pointer-events:none}.cr-rec-dot{width:10px;height:10px;border-radius:50%;background:#f44;animation:cr-blink 1s ease-in-out infinite}@keyframes cr-blink{0%,to{opacity:1}50%{opacity:.3}}.cr-controls{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;width:100%}.cr-record-btn{background:#ef4444!important}.cr-record-btn:hover{background:#dc2626!important}.cr-stop-btn{background:#ef4444!important;color:#fff!important}.cr-stop-btn:hover{background:#dc2626!important}.cr-switch-btn{font-size:.8rem}.cr-rec-meta{font-size:.88rem;color:var(--text-secondary);font-weight:600}.cr-progress-bar{width:100%;height:8px;background:var(--border);border-radius:4px;margin:12px 0;position:relative;overflow:hidden}.cr-progress-fill{height:100%;background:var(--primary);border-radius:4px;transition:width .3s ease}.cr-progress-text{position:absolute;right:0;top:-20px;font-size:.75rem;color:var(--text-muted)}.cr-error{background:#fef2f2;color:var(--error);padding:12px 16px;border-radius:var(--radius-sm);font-size:.85rem;display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}.cr-success{background:#dcfce7;color:#15803d;padding:12px 16px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;text-align:center;width:100%}.camera-record-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border:2px dashed var(--primary);border-radius:var(--radius);background:var(--primary-light);color:var(--primary);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .15s;margin:12px 0}.camera-record-btn:hover{background:#ddd6fe;transform:translateY(-1px)}.cr-btn-desc{font-size:.78rem;font-weight:400;opacity:.75}.cr-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.cr-modal{background:#fff;border-radius:var(--radius);padding:24px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.cr-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.cr-modal-header h3{font-size:1.1rem;margin:0}.cr-modal-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text-muted);padding:4px 8px;border-radius:4px;transition:all .12s}.cr-modal-close:hover{background:var(--border-light);color:var(--text)}@media (max-width: 768px){.camera-recorder{padding:12px;max-width:100%}.cr-video-wrapper{aspect-ratio:9/16;max-height:360px}.cr-controls{gap:8px}.cr-modal{margin:0;max-width:100%;border-radius:16px 16px 0 0;max-height:92vh;position:fixed;bottom:0;left:0;right:0}.cr-modal-overlay{align-items:flex-end;padding:0}.cr-record-btn,.cr-stop-btn{padding:12px 32px;font-size:1rem;min-height:48px}}
