:root{--color-primary-50:#eef2ff;--color-primary-100:#e0e7ff;--color-primary-200:#c7d2fe;--color-primary-300:#a5b4fc;--color-primary-400:#818cf8;--color-primary-500:#6366f1;--color-primary-600:#4f46e5;--color-primary-700:#4338ca;--color-primary-800:#3730a3;--color-primary-900:#312e81;--color-success-50:#ecfdf5;--color-success-100:#d1fae5;--color-success-200:#a7f3d0;--color-success-300:#6ee7b7;--color-success-400:#34d399;--color-success-500:#10b981;--color-success-600:#059669;--color-success-700:#047857;--color-success-800:#065f46;--color-success-900:#064e3b;--color-warning-50:#fffbeb;--color-warning-100:#fef3c7;--color-warning-200:#fde68a;--color-warning-300:#fcd34d;--color-warning-400:#fbbf24;--color-warning-500:#f59e0b;--color-warning-600:#d97706;--color-warning-700:#b45309;--color-warning-800:#92400e;--color-warning-900:#78350f;--color-error-50:#fef2f2;--color-error-100:#fee2e2;--color-error-200:#fecaca;--color-error-300:#fca5a5;--color-error-400:#f87171;--color-error-500:#ef4444;--color-error-600:#dc2626;--color-error-700:#b91c1c;--color-error-800:#991b1b;--color-error-900:#7f1d1d;--color-neutral-50:#f9fafb;--color-neutral-100:#f3f4f6;--color-neutral-200:#e5e7eb;--color-neutral-300:#d1d5db;--color-neutral-400:#9ca3af;--color-neutral-500:#6b7280;--color-neutral-600:#4b5563;--color-neutral-700:#374151;--color-neutral-800:#1f2937;--color-neutral-900:#111827;--color-background:var(--color-neutral-50);--color-surface:#fff;--color-surface-hover:var(--color-neutral-100);--color-surface-active:var(--color-neutral-200);--color-text-primary:var(--color-neutral-900);--color-text-secondary:var(--color-neutral-600);--color-text-tertiary:var(--color-neutral-500);--color-text-disabled:var(--color-neutral-400);--color-border:var(--color-neutral-200);--color-border-hover:var(--color-neutral-300);--color-border-focus:var(--color-primary-500);--font-family-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--font-family-mono:"SF Mono",Monaco,"Cascadia Code","Roboto Mono",Consolas,"Courier New",monospace;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.625;--spacing-0:0;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-20:5rem;--spacing-24:6rem;--radius-none:0;--radius-sm:0.25rem;--radius-base:0.5rem;--radius-md:0.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-base:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--shadow-2xl:0 25px 50px -12px #00000040;--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease;--transition-colors:color var(--transition-base),background-color var(--transition-base),border-color var(--transition-base);--transition-transform:transform var(--transition-base);--transition-opacity:opacity var(--transition-base);--transition-all:all var(--transition-base);--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px;--card-background:var(--color-surface);--card-border:1px solid var(--color-border);--card-radius:var(--radius-md);--card-shadow:var(--shadow-base);--card-shadow-hover:var(--shadow-md);--card-padding:var(--spacing-6);--button-radius:var(--radius-base);--button-padding-x:var(--spacing-4);--button-padding-y:var(--spacing-3);--button-font-weight:var(--font-weight-medium);--button-transition:var(--transition-colors),var(--transition-transform);--input-background:var(--color-surface);--input-border:1px solid var(--color-border);--input-border-focus:2px solid var(--color-border-focus);--input-radius:var(--radius-base);--input-padding-x:var(--spacing-4);--input-padding-y:var(--spacing-3);--input-font-size:var(--font-size-base);--input-transition:var(--transition-colors);--nav-height:4rem;--nav-background:var(--color-surface);--nav-border:1px solid var(--color-border);--nav-shadow:var(--shadow-sm);--sidebar-width:16rem;--sidebar-background:var(--color-surface);--sidebar-border:1px solid var(--color-border)}.btn{border:none;border-radius:var(--button-radius);font-family:var(--font-family-sans);font-weight:var(--button-font-weight);line-height:var(--line-height-tight);padding:var(--button-padding-y) var(--button-padding-x);transition:var(--button-transition);white-space:nowrap}.btn:focus{outline:2px solid var(--color-primary-500);outline-offset:2px}.btn-primary{background-color:var(--color-primary-600)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-700);transform:translateY(-1px)}.btn-primary:active{background-color:var(--color-primary-800);transform:translateY(0)}.btn-secondary{background-color:initial;border:1px solid var(--color-primary-600);color:var(--color-primary-600)}.btn-secondary:hover:not(:disabled){background-color:var(--color-primary-50);border-color:var(--color-primary-700);color:var(--color-primary-700)}.btn-success{background-color:var(--color-success-600);color:#fff}.btn-success:hover:not(:disabled){background-color:var(--color-success-700);transform:translateY(-1px)}.btn-danger{background-color:var(--color-error-600);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--color-error-700);transform:translateY(-1px)}.btn-ghost{background-color:initial;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-surface-hover);color:var(--color-text-primary)}.btn-lg{font-size:var(--font-size-base);padding:var(--spacing-4) var(--spacing-6)}.btn-xl{font-size:var(--font-size-lg);padding:var(--spacing-5) var(--spacing-8)}.card{background:var(--card-background);border:var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow);overflow:hidden;transition:var(--transition-all)}.card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-2px)}.card-header{border-bottom:1px solid var(--color-border);padding:var(--spacing-6)}.card-body{padding:var(--card-padding)}.card-footer{background-color:var(--color-surface-hover);border-top:1px solid var(--color-border);padding:var(--spacing-6)}.card-interactive{cursor:pointer;transition:var(--transition-all)}.card-interactive:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-selected{border-color:var(--color-primary-500);box-shadow:0 0 0 1px var(--color-primary-500)}.form-group{margin-bottom:var(--spacing-6)}.form-label{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-2)}.form-input,.form-select,.form-textarea{background:var(--input-background);border:var(--input-border);border-radius:var(--input-radius);color:var(--color-text-primary);font-family:var(--font-family-sans);font-size:var(--input-font-size);padding:var(--input-padding-y) var(--input-padding-x);transition:var(--input-transition);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border:var(--input-border-focus);box-shadow:0 0 0 3px #6366f11a}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-tertiary)}.form-error{color:var(--color-error-600)}.form-error,.form-help{font-size:var(--font-size-xs);margin-top:var(--spacing-1)}.form-help{color:var(--color-text-tertiary)}.tabs{border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-6)}.tab{background:#0000;color:var(--color-text-secondary);font-family:var(--font-family-sans);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--spacing-4) var(--spacing-6);transition:var(--transition-colors)}.tab:hover{background-color:var(--color-surface-hover);color:var(--color-text-primary)}.tab.active{border-bottom-color:var(--color-primary-600);color:var(--color-primary-600)}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:var(--line-height-tight);padding:var(--spacing-1) var(--spacing-2)}.badge-primary{background-color:var(--color-primary-100);color:var(--color-primary-800)}.badge-success{background-color:var(--color-success-100);color:var(--color-success-800)}.badge-warning{background-color:var(--color-warning-100);color:var(--color-warning-800)}.badge-error{background-color:var(--color-error-100);color:var(--color-error-800)}.loading-spinner{border-top:2px solid var(--color-neutral-200);border:2px solid var(--color-neutral-200);border-top-color:var(--color-primary-600)}.loading-spinner-sm{border-width:1.5px}.loading-spinner-lg{border-width:3px;height:32px;width:32px}.alert{border-radius:var(--radius-base);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4);padding:var(--spacing-4)}.alert-success{background-color:var(--color-success-50);border:1px solid var(--color-success-200);color:var(--color-success-800)}.alert-warning{background-color:var(--color-warning-50);border:1px solid var(--color-warning-200);color:var(--color-warning-800)}.alert-error{background-color:var(--color-error-50);border:1px solid var(--color-error-200);color:var(--color-error-800)}.alert-info{background-color:var(--color-primary-50);border:1px solid var(--color-primary-200);color:var(--color-primary-800)}.progress{background-color:var(--color-neutral-200);height:8px;overflow:hidden;width:100%}.progress,.progress-bar{border-radius:var(--radius-full)}.progress-bar{background-color:var(--color-primary-600);height:100%;transition:width var(--transition-base)}.progress-success .progress-bar{background-color:var(--color-success-600)}.progress-warning .progress-bar{background-color:var(--color-warning-600)}.progress-error .progress-bar{background-color:var(--color-error-600)}.pagination{gap:var(--spacing-1);margin-top:var(--spacing-8)}.pagination-btn{align-items:center;background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-base);color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:var(--font-size-sm);height:40px;justify-content:center;transition:var(--transition-colors);width:40px}.pagination-btn:hover:not(:disabled){background-color:var(--color-surface-hover);border-color:var(--color-border-hover);color:var(--color-text-primary)}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-btn.active{background-color:var(--color-primary-600);border-color:var(--color-primary-600);color:#fff}.upload-area{background-color:var(--color-surface-hover);border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-12);transition:var(--transition-all)}.upload-area:hover{background-color:var(--color-primary-50);border-color:var(--color-primary-400)}.upload-area.dragover{background-color:var(--color-primary-100);border-color:var(--color-primary-500)}.upload-area.has-file{background-color:var(--color-success-50);border-color:var(--color-success-400)}.empty-state{color:var(--color-text-secondary);padding:var(--spacing-16) var(--spacing-8)}.empty-state-icon{font-size:var(--font-size-5xl);margin-bottom:var(--spacing-4);opacity:.5}.empty-state-title{color:var(--color-text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-2)}.empty-state-description{font-size:var(--font-size-base);margin-bottom:var(--spacing-6)}.container{margin:0 auto;max-width:1280px}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-row-reverse{flex-direction:row-reverse}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.gap-5{gap:var(--spacing-5)}.gap-6{gap:var(--spacing-6)}.gap-8{gap:var(--spacing-8)}.m-0{margin:0}.m-1{margin:var(--spacing-1)}.m-2{margin:var(--spacing-2)}.m-3{margin:var(--spacing-3)}.m-4{margin:var(--spacing-4)}.m-5{margin:var(--spacing-5)}.m-6{margin:var(--spacing-6)}.m-8{margin:var(--spacing-8)}.mx-auto{margin-right:auto}.ml-auto,.mx-auto{margin-left:auto}.mr-auto{margin-right:auto}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-1)}.mt-2{margin-top:var(--spacing-2)}.mt-3{margin-top:var(--spacing-3)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mt-8{margin-top:var(--spacing-8)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-1)}.mb-2{margin-bottom:var(--spacing-2)}.mb-3{margin-bottom:var(--spacing-3)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.mb-8{margin-bottom:var(--spacing-8)}.p-0{padding:0}.p-1{padding:var(--spacing-1)}.p-2{padding:var(--spacing-2)}.p-3{padding:var(--spacing-3)}.p-4{padding:var(--spacing-4)}.p-5{padding:var(--spacing-5)}.p-6{padding:var(--spacing-6)}.p-8{padding:var(--spacing-8)}.px-0{padding-left:0;padding-right:0}.px-1{padding-left:var(--spacing-1);padding-right:var(--spacing-1)}.px-2{padding-left:var(--spacing-2);padding-right:var(--spacing-2)}.px-3{padding-left:var(--spacing-3);padding-right:var(--spacing-3)}.px-4{padding-left:var(--spacing-4);padding-right:var(--spacing-4)}.px-6{padding-left:var(--spacing-6);padding-right:var(--spacing-6)}.py-0{padding-bottom:0;padding-top:0}.py-1{padding-bottom:var(--spacing-1);padding-top:var(--spacing-1)}.py-2{padding-bottom:var(--spacing-2);padding-top:var(--spacing-2)}.py-3{padding-bottom:var(--spacing-3);padding-top:var(--spacing-3)}.py-4{padding-bottom:var(--spacing-4);padding-top:var(--spacing-4)}.py-6{padding-bottom:var(--spacing-6);padding-top:var(--spacing-6)}.w-full{width:100%}.w-auto{width:auto}.w-fit{width:-webkit-fit-content;width:fit-content}.h-full{height:100%}.h-auto{height:auto}.h-fit{height:-webkit-fit-content;height:fit-content}.min-h-0{min-height:0}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-disabled{color:var(--color-text-disabled)}.text-success{color:var(--color-success-600)}.text-warning{color:var(--color-warning-600)}.text-error{color:var(--color-error-600)}.leading-tight{line-height:var(--line-height-tight)}.leading-normal{line-height:var(--line-height-normal)}.leading-relaxed{line-height:var(--line-height-relaxed)}.bg-white{background-color:#fff}.bg-surface{background-color:var(--color-surface)}.bg-background{background-color:var(--color-background)}.bg-hover{background-color:var(--color-surface-hover)}.bg-primary{background-color:var(--color-primary-600)}.bg-success{background-color:var(--color-success-600)}.bg-warning{background-color:var(--color-warning-600)}.bg-error{background-color:var(--color-error-600)}.border{border:1px solid var(--color-border)}.border-0{border:none}.border-t{border-top:1px solid var(--color-border)}.border-b{border-bottom:1px solid var(--color-border)}.border-l{border-left:1px solid var(--color-border)}.border-r{border-right:1px solid var(--color-border)}.border-primary{border-color:var(--color-primary-600)}.border-success{border-color:var(--color-success-600)}.border-warning{border-color:var(--color-warning-600)}.border-error{border-color:var(--color-error-600)}.rounded-none{border-radius:var(--radius-none)}.rounded-sm{border-radius:var(--radius-sm)}.rounded{border-radius:var(--radius-base)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-none{box-shadow:none}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow-base)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.transition-none{transition:none}.transition-all{transition:var(--transition-all)}.transition-colors{transition:var(--transition-colors)}.transition-transform{transition:var(--transition-transform)}.transition-opacity{transition:var(--transition-opacity)}.transform{transform:translateZ(0)}.scale-95{transform:scale(.95)}.scale-100{transform:scale(1)}.scale-105{transform:scale(1.05)}.translate-y-0{transform:translateY(0)}.translate-y-1{transform:translateY(var(--spacing-1))}.-translate-y-1{transform:translateY(calc(var(--spacing-1)*-1))}.-translate-y-2{transform:translateY(calc(var(--spacing-2)*-1))}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.cursor-default{cursor:default}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:-webkit-sticky;position:sticky}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}@media (min-width:640px){.sm\:block{display:block}.sm\:hidden{display:none}.sm\:flex{display:flex}.sm\:grid{display:grid}.sm\:text-sm{font-size:var(--font-size-sm)}.sm\:text-base{font-size:var(--font-size-base)}.sm\:text-lg{font-size:var(--font-size-lg)}.sm\:p-6{padding:var(--spacing-6)}.sm\:px-6{padding-left:var(--spacing-6);padding-right:var(--spacing-6)}.sm\:py-6{padding-bottom:var(--spacing-6);padding-top:var(--spacing-6)}}@media (min-width:768px){.md\:block{display:block}.md\:hidden{display:none}.md\:flex{display:flex}.md\:grid{display:grid}.md\:text-base{font-size:var(--font-size-base)}.md\:text-lg{font-size:var(--font-size-lg)}.md\:text-xl{font-size:var(--font-size-xl)}.md\:p-8{padding:var(--spacing-8)}.md\:px-8{padding-left:var(--spacing-8);padding-right:var(--spacing-8)}.md\:py-8{padding-bottom:var(--spacing-8);padding-top:var(--spacing-8)}}@media (min-width:1024px){.lg\:block{display:block}.lg\:hidden{display:none}.lg\:flex{display:flex}.lg\:grid{display:grid}.lg\:text-lg{font-size:var(--font-size-lg)}.lg\:text-xl{font-size:var(--font-size-xl)}.lg\:text-2xl{font-size:var(--font-size-2xl)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,20%,53%,80%,to{transform:translateZ(0)}40%,43%{transform:translate3d(0,-8px,0)}70%{transform:translate3d(0,-4px,0)}90%{transform:translate3d(0,-2px,0)}}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-4px)}20%,40%,60%,80%{transform:translateX(4px)}}@keyframes progress{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-fade-out{animation:fadeOut .3s ease-out}.animate-slide-in-up{animation:slideInUp .3s ease-out}.animate-slide-in-down{animation:slideInDown .3s ease-out}.animate-slide-in-left{animation:slideInLeft .3s ease-out}.animate-slide-in-right{animation:slideInRight .3s ease-out}.animate-scale-in{animation:scaleIn .2s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-bounce{animation:bounce 1s infinite}.animate-shake{animation:shake .5s ease-in-out}.animate-spin{animation:spin 1s linear infinite}.hover-lift{transition:transform var(--transition-base),box-shadow var(--transition-base)}.hover-lift:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.hover-glow:hover{box-shadow:0 0 20px #6366f14d}.loading-dots{display:inline-flex;gap:4px}.loading-dots:after,.loading-dots:before{animation:loading-dots 1.4s ease-in-out infinite both;background-color:currentColor;border-radius:50%;content:"";display:inline-block;height:4px;width:4px}.loading-dots:before{animation-delay:-.16s;margin-right:4px}@keyframes loading-dots{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.progress-indeterminate{overflow:hidden;position:relative}.progress-indeterminate:before{animation:progress 1.5s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);bottom:0;content:"";left:0;position:absolute;top:0;width:100%}.stagger-children>*{animation:slideInUp .4s ease-out}.stagger-children>:first-child{animation-delay:.1s}.stagger-children>:nth-child(2){animation-delay:.2s}.stagger-children>:nth-child(3){animation-delay:.3s}.stagger-children>:nth-child(4){animation-delay:.4s}.stagger-children>:nth-child(5){animation-delay:.5s}.stagger-children>:nth-child(6){animation-delay:.6s}.focus-ring{transition:box-shadow var(--transition-fast)}.focus-ring:focus{box-shadow:0 0 0 3px #6366f133;outline:none}.btn-ripple{overflow:hidden;position:relative}.btn-ripple:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s;width:0}.btn-ripple:active:before{height:300px;width:300px}.card-hover{transition:all var(--transition-base)}.card-hover:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px)}.card-hover:hover .card-image{transform:scale(1.05)}.card-image{transition:transform var(--transition-slow)}.toast-enter{animation:slideInRight .3s ease-out}.toast-exit{animation:slideInRight .3s ease-out reverse}.dropdown-enter{animation:slideInDown .2s ease-out}.dropdown-exit{animation:slideInDown .2s ease-out reverse}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.container{padding:0 var(--spacing-4)}.grid-responsive{grid-gap:var(--spacing-4);display:grid;gap:var(--spacing-4);grid-template-columns:1fr}@media (min-width:640px){.container{padding:0 var(--spacing-6)}.grid-responsive{gap:var(--spacing-6);grid-template-columns:repeat(2,1fr)}.sm\:grid-cols-1{grid-template-columns:repeat(1,1fr)}.sm\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.sm\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.sm\:text-center{text-align:center}.sm\:text-left{text-align:left}.sm\:flex-row{flex-direction:row}.sm\:flex-col{flex-direction:column}.sm\:justify-start{justify-content:flex-start}.sm\:justify-center{justify-content:center}.sm\:justify-between{justify-content:space-between}.sm\:items-start{align-items:flex-start}.sm\:items-center{align-items:center}.sm\:items-end{align-items:flex-end}}@media (min-width:768px){.container{margin:0 auto;max-width:768px}.grid-responsive{grid-template-columns:repeat(3,1fr)}.md\:grid-cols-1{grid-template-columns:repeat(1,1fr)}.md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.md\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.md\:grid-cols-4{grid-template-columns:repeat(4,1fr)}.md\:flex-row{flex-direction:row}.md\:flex-col{flex-direction:column}.md\:text-left{text-align:left}.md\:text-center{text-align:center}.md\:text-right{text-align:right}.card{min-height:auto}.btn{padding:var(--spacing-3) var(--spacing-5)}.btn-sm{padding:var(--spacing-2) var(--spacing-4)}.btn-lg{padding:var(--spacing-4) var(--spacing-8)}}@media (min-width:1024px){.container{max-width:1024px}.grid-responsive{grid-template-columns:repeat(4,1fr)}.lg\:grid-cols-1{grid-template-columns:repeat(1,1fr)}.lg\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.lg\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.lg\:grid-cols-4{grid-template-columns:repeat(4,1fr)}.lg\:grid-cols-5{grid-template-columns:repeat(5,1fr)}.lg\:grid-cols-6{grid-template-columns:repeat(6,1fr)}.lg\:flex-row{flex-direction:row}.lg\:flex-col{flex-direction:column}.card:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px)}.btn:hover{transform:translateY(-1px)}}@media (min-width:1280px){.container{max-width:1280px}.grid-responsive{grid-template-columns:repeat(5,1fr)}.xl\:grid-cols-1{grid-template-columns:repeat(1,1fr)}.xl\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.xl\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.xl\:grid-cols-4{grid-template-columns:repeat(4,1fr)}.xl\:grid-cols-5{grid-template-columns:repeat(5,1fr)}.xl\:grid-cols-6{grid-template-columns:repeat(6,1fr)}}@media (min-width:1536px){.container{max-width:1536px}.grid-responsive{grid-template-columns:repeat(6,1fr)}}@media (max-width:639px){h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}.text-responsive-xl,h3{font-size:var(--font-size-lg)}.text-responsive-lg{font-size:var(--font-size-base)}.text-responsive-base{font-size:var(--font-size-sm)}}@media (min-width:640px){.text-responsive-xl{font-size:var(--font-size-xl)}.text-responsive-lg{font-size:var(--font-size-lg)}.text-responsive-base{font-size:var(--font-size-base)}}@media (min-width:1024px){.text-responsive-xl{font-size:var(--font-size-2xl)}.text-responsive-lg{font-size:var(--font-size-xl)}.text-responsive-base{font-size:var(--font-size-lg)}}@media (max-width:639px){.spacing-responsive-sm{margin:var(--spacing-2)}.spacing-responsive-md{margin:var(--spacing-4)}.spacing-responsive-lg{margin:var(--spacing-6)}.padding-responsive-sm{padding:var(--spacing-2)}.padding-responsive-md{padding:var(--spacing-4)}.padding-responsive-lg{padding:var(--spacing-6)}}@media (min-width:640px){.spacing-responsive-sm{margin:var(--spacing-4)}.spacing-responsive-md{margin:var(--spacing-6)}.spacing-responsive-lg{margin:var(--spacing-8)}.padding-responsive-sm{padding:var(--spacing-4)}.padding-responsive-md{padding:var(--spacing-6)}.padding-responsive-lg{padding:var(--spacing-8)}}@media (min-width:1024px){.spacing-responsive-sm{margin:var(--spacing-6)}.spacing-responsive-md{margin:var(--spacing-8)}.spacing-responsive-lg{margin:var(--spacing-12)}.padding-responsive-sm{padding:var(--spacing-6)}.padding-responsive-md{padding:var(--spacing-8)}.padding-responsive-lg{padding:var(--spacing-12)}}@media (max-width:639px){.card{margin-bottom:var(--spacing-4)}.card-body,.card-footer,.card-header{padding:var(--spacing-4)}}@media (min-width:640px){.card-body,.card-footer,.card-header{padding:var(--spacing-6)}}@media (max-width:639px){.form-input,.form-select,.form-textarea{font-size:16px}.btn{justify-content:center;width:100%}.btn+.btn{margin-top:var(--spacing-2)}}@media (min-width:640px){.btn{width:auto}.btn+.btn{margin-left:var(--spacing-2);margin-top:0}}@media (max-width:767px){.tabs{flex-direction:column;gap:0}.tab{border-bottom:1px solid var(--color-border);border-radius:0;text-align:left}.tab:last-child{border-bottom:none}}@media (min-width:768px){.tabs{border-bottom:1px solid var(--color-border);flex-direction:row}.tab{border-bottom:2px solid #0000;border-radius:0}}@media (max-width:639px){.modal-content{margin:var(--spacing-4);max-height:calc(100vh - var(--spacing-8));overflow-y:auto}}@media (min-width:640px){.modal-content{margin:var(--spacing-12) auto;max-width:500px}}@media (min-width:1024px){.modal-content{max-width:600px}}.hide-mobile{display:none}.hide-desktop{display:block}@media (min-width:768px){.hide-mobile{display:block}.hide-desktop{display:none}}@media (hover:none) and (pointer:coarse){.btn,.pagination-btn,.tab{min-height:44px;min-width:44px}.card-interactive{transform:none}.card-interactive:active{transform:scale(.98)}}@media print{.hide-print{display:none!important}.card{border:1px solid #ccc;box-shadow:none;break-inside:avoid;page-break-inside:avoid}.btn{display:none}}*,:after,:before{box-sizing:border-box}html{-webkit-text-size-adjust:100%;tab-size:4}body,html{font-family:var(--font-family-sans);line-height:var(--line-height-normal)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-background);font-size:var(--font-size-base)}body,h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);margin:0}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-base)}h6{font-size:var(--font-size-sm)}p{color:var(--color-text-secondary);margin:0 0 var(--spacing-4) 0}a{color:var(--color-primary-600);text-decoration:none;transition:var(--transition-colors)}a:hover{color:var(--color-primary-700);text-decoration:underline}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:var(--line-height-normal);margin:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:initial;background-image:none}button:focus{outline:1px dotted;outline:1px auto -webkit-focus-ring-color}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:var(--color-text-tertiary);opacity:1}[role=button]{cursor:pointer}table{border-collapse:collapse;border-color:inherit;text-indent:0}hr{border-top-width:1px;color:inherit;height:0}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:var(--color-neutral-100)}::-webkit-scrollbar-thumb{background:var(--color-neutral-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-neutral-400)}::selection{background-color:var(--color-primary-200);color:var(--color-primary-900)}@media print{*,:after,:before{background:#0000!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}pre{white-space:pre-wrap!important}blockquote,pre{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}}.login-page-container{background:#f0f2f5;display:flex;font-family:ui-sans-serif,system-ui,sans-serif;line-height:1.5;min-height:100vh}.login-page-container .brand-section{align-items:center;background:linear-gradient(215deg,#06b6d4 4.66%,#2563eb 66.69%);display:flex;flex:1 1;justify-content:center;overflow:hidden;position:relative}.login-page-container .brand-background{background-image:url(https://app.psyai.com/images/cube-bg.png);background-position:bottom 0 right 0;background-repeat:no-repeat;background-size:540px auto;inset:0;opacity:.15;pointer-events:none;position:absolute;transform:translateX(20%)}.login-page-container .brand-content{position:relative;z-index:10}.login-page-container .psyche-logo{align-items:center;display:flex;gap:16px}.login-page-container .logo-icon{align-items:center;display:flex;height:60px;position:relative;width:60px}.login-page-container .logo-shape{border-radius:8px;position:absolute}.login-page-container .logo-shape-1{background:linear-gradient(135deg,#ff6b9d,#ff8a80);height:45px;left:0;top:50%;transform:translateY(-50%) rotate(-10deg);width:35px}.login-page-container .logo-shape-2{background:linear-gradient(135deg,#4fc3f7,#29b6f6);height:50px;right:0;top:50%;transform:translateY(-50%) rotate(15deg);width:40px;z-index:2}.login-page-container .logo-text{color:#fff;font-size:48px;font-weight:700;letter-spacing:2px}.login-page-container .geometric-bg{bottom:0;left:0;opacity:.1;position:absolute;right:0;top:0}.login-page-container .geometric-shape{background:#fff3;border-radius:12px;position:absolute}.login-page-container .shape-1{height:200px;right:10%;top:20%;transform:rotate(25deg);width:200px}.login-page-container .shape-2{bottom:20%;height:150px;left:10%;transform:rotate(-15deg);width:150px}.login-page-container .shape-3{height:100px;right:20%;top:60%;transform:rotate(45deg);width:100px}.login-page-container .login-section{align-items:center;background:#f0f2f5;display:flex;flex:1 1;justify-content:center;min-width:500px;padding:40px}.login-page-container .login-container{max-width:400px;width:100%}.login-page-container .login-card{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:40px}.login-page-container .login-header{margin-bottom:32px;text-align:center}.login-page-container .login-header h2{color:#262626;font-size:24px;font-weight:600;margin:0}.login-page-container .login-tabs{border-bottom:1px solid #f0f0f0;display:flex;margin-bottom:32px}.login-page-container .tab-btn{background:#0000;border:none;color:#8c8c8c;cursor:pointer;flex:1 1;font-size:14px;padding:12px 0;position:relative;text-align:center;transition:color .2s}.login-page-container .tab-btn.active{color:#1890ff}.login-page-container .tab-btn.active:after{background:#1890ff;bottom:-1px;content:"";height:2px;left:0;position:absolute;right:0}.login-page-container .tab-btn:hover:not(.active){color:#595959}.login-page-container .wechat-login{align-items:center;display:flex;justify-content:center;min-height:300px}.login-page-container .wechat-qr{text-align:center}.login-page-container .qr-placeholder{align-items:center;border:2px dashed #d9d9d9;border-radius:8px;display:flex;flex-direction:column;gap:16px;height:200px;justify-content:center;margin-bottom:16px;width:200px}.login-page-container .wechat-icon{font-size:48px}.login-page-container .qr-placeholder p{color:#8c8c8c;font-size:14px;margin:0}.login-page-container .login-form{gap:20px}.login-page-container .form-group,.login-page-container .login-form{display:flex;flex-direction:column}.login-page-container .form-input{background:#fff;border:1px solid #d9d9d9;border-radius:6px;font-size:14px;padding:12px 16px;transition:border-color .2s}.login-page-container .form-input:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff1a;outline:none}.login-page-container .form-input:disabled{background:#f5f5f5;cursor:not-allowed}.login-page-container .form-input::placeholder{color:#bfbfbf}.login-page-container .code-input-group{display:flex;gap:8px}.login-page-container .code-input{flex:1 1}.login-page-container .send-code-btn{background:#fff;border:1px solid #1890ff;border-radius:6px;color:#1890ff;cursor:pointer;font-size:14px;padding:12px 16px;transition:all .2s;white-space:nowrap}.login-page-container .send-code-btn:hover:not(:disabled){background:#1890ff;color:#fff}.login-page-container .send-code-btn:disabled{background:#f5f5f5;border-color:#d9d9d9;color:#bfbfbf;cursor:not-allowed}.login-page-container .form-options{align-items:center;display:flex;margin:8px 0}.login-page-container .checkbox-label{align-items:center;color:#595959;cursor:pointer;display:flex;font-size:14px;gap:8px}.login-page-container .checkbox-input{display:none}.login-page-container .checkbox-custom{border:1px solid #d9d9d9;border-radius:2px;flex-shrink:0;height:16px;position:relative;width:16px}.login-page-container .checkbox-input:checked+.checkbox-custom{background:#1890ff;border-color:#1890ff}.login-page-container .checkbox-input:checked+.checkbox-custom:after{color:#fff;content:"✓";font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.login-page-container .error-message{background:#fff2f0;border:1px solid #ffccc7;border-radius:6px;color:#ff4d4f;font-size:14px;padding:12px 16px;text-align:center}.login-page-container .submit-btn{background:#1890ff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:14px 16px;transition:background-color .2s}.login-page-container .submit-btn:hover:not(:disabled){background:#40a9ff}.login-page-container .submit-btn:disabled{background:#bfbfbf;cursor:not-allowed}.login-page-container .terms-agreement{margin-top:16px}.login-page-container .terms-text{color:#8c8c8c;font-size:12px;line-height:1.5}.login-page-container .terms-link{color:#1890ff;text-decoration:none}.login-page-container .terms-link:hover{text-decoration:underline}@media (max-width:768px){.login-page-container{flex-direction:column}.login-page-container .brand-section{flex:none;min-height:200px}.login-page-container .logo-text{font-size:32px}.login-page-container .login-section{min-width:auto;padding:24px}.login-page-container .login-card{padding:24px}.login-page-container .shape-1,.login-page-container .shape-2,.login-page-container .shape-3{display:none}}@media (max-width:480px){.login-page-container .login-section{padding:16px}.login-page-container .code-input-group{flex-direction:column}.login-page-container .send-code-btn{width:100%}}.global-header{background-color:#001529;box-shadow:inset 0 -1px 0 0 #f0f0f0;height:48px;justify-content:space-between;padding:0 16px}.global-header,.logo-section{align-items:center;display:flex}.logo-section{gap:12px;padding:8px 16px 8px 0}.logo{background:linear-gradient(135deg,#1890ff,#0050b3);border-radius:3px;height:32px;position:relative;width:23px}.logo-text{color:#fff;font-size:16px;font-weight:500;line-height:2em}.header-right{align-items:center;display:flex;gap:16px}.api-link{color:#1890ff;font-size:14px;text-decoration:none;transition:color .3s}.api-link:hover{color:#40a9ff}.user-section{position:relative}.user-info{align-items:center;border-radius:4px;color:#fff;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:background-color .2s}.user-info:hover{background-color:#ffffff1a}.user-phone{font-size:14px}.dropdown-arrow{font-size:10px;transition:transform .2s}.user-menu{background:#fff;border:1px solid #d9d9d9;border-radius:4px;box-shadow:0 4px 12px #0000001a;margin-top:4px;min-width:120px;position:absolute;right:0;top:100%;z-index:1000}.user-menu-item{color:#333;cursor:pointer;font-size:14px;padding:12px 16px;transition:background-color .2s}.user-menu-item:hover{background-color:#f5f5f5}.sidebar{background:#fff;box-shadow:0 2px 8px 0 #00000026;display:flex;flex-direction:column;justify-content:space-between;transition:width .3s ease;width:208px}.sidebar.collapsed{width:68px}.menu{padding:4px 0}.menu-item{align-items:center;color:inherit;cursor:pointer;display:flex;height:40px;padding:0 24px;position:relative;text-decoration:none;transition:all .3s}.menu-item:hover{background-color:#f5f5f5}.menu-item.active{background-color:#e6f7ff}.menu-item.active:after{background-color:#1890ff;bottom:0;content:"";position:absolute;right:0;top:0;width:3px}.menu-item.active .menu-icon,.menu-item.active .menu-text{color:#1890ff}.menu-icon{flex-shrink:0;height:14px;margin-right:10px;width:14px}.menu-icon,.menu-text{color:#000000a6;transition:color .3s}.menu-text{font-size:14px;overflow:hidden;white-space:nowrap}.sidebar.collapsed .menu-text{opacity:0;width:0}.sidebar.collapsed .menu-icon{margin-right:0}.sidebar-trigger{align-items:center;border-top:1px solid #f0f0f0;cursor:pointer;display:flex;height:40px;padding:0 16px;transition:background-color .3s}.sidebar-trigger:hover{background-color:#f5f5f5}@media (max-width:768px){.sidebar{height:auto}.sidebar,.sidebar.collapsed{width:100%}}.layout{background-color:#f0f2f5;min-height:100vh}.layout-content{display:flex;min-height:calc(100vh - 48px)}.main-content{flex:1 1;overflow-y:auto;padding:24px;transition:margin-left .3s ease}.main-content.collapsed{margin-left:-140px}@media (max-width:768px){.layout-content{flex-direction:column}.main-content{padding:16px}}.breadcrumb{align-items:center;display:flex;gap:4px;margin-bottom:16px}.breadcrumb-link{color:#00000073;font-size:14px;text-decoration:none;transition:color .3s}.breadcrumb-link:hover{color:#1890ff}.breadcrumb-separator{color:#00000073;font-size:14px;margin:0 4px}.breadcrumb-current{color:#000000d9;font-size:14px}.loading-spinner{align-items:center;display:flex;justify-content:center}.spinner{border:3px solid #f3f4f6;border-top-color:#4f46e5}.loading-spinner.small .spinner{border-width:2px;height:20px;width:20px}.loading-spinner.medium .spinner{border-width:3px;height:32px;width:32px}.loading-spinner.large .spinner{border-width:4px;height:48px;width:48px}.support-inline .support-content{align-items:flex-start;display:flex;flex-direction:column}.dashboard-page{margin:0 auto;max-width:1400px;padding:0 var(--spacing-6)}.welcome-hero{background:linear-gradient(135deg,#0e1b4d,#1a2a6c);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);color:#f6f8ff;margin-bottom:var(--spacing-8);overflow:hidden;padding:var(--spacing-8);position:relative}.hero-content{align-items:center;display:flex;justify-content:space-between;position:relative;z-index:2}.hero-text{flex:1 1}.hero-title{color:#ffffffeb;font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin:var(--spacing-2) 0;text-shadow:0 6px 20px #00000040}.hero-subtitle{color:#ffffffbf;font-size:var(--font-size-lg);font-weight:var(--font-weight-normal);margin:0;opacity:.9;text-shadow:0 4px 12px #0003}.hero-tag{align-items:center;background:#ffffff2e;border-radius:var(--radius-full);color:#fffffff2;display:inline-flex;font-size:var(--font-size-sm);gap:var(--spacing-2);letter-spacing:.08em;padding:var(--spacing-1) var(--spacing-3);text-shadow:0 4px 10px #0003}.hero-illustration{height:120px;position:relative;width:200px}.floating-elements{height:100%;position:absolute;width:100%}.element{animation:float 6s ease-in-out infinite;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:var(--radius-full);position:absolute}.element-1{animation-delay:0s;height:60px;right:20px;top:10px;width:60px}.element-2{animation-delay:2s;height:40px;right:80px;top:60px;width:40px}.element-3{animation-delay:4s;height:30px;right:140px;top:30px;width:30px}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(180deg)}}.stats-grid{grid-gap:var(--spacing-6);display:grid;gap:var(--spacing-6);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-bottom:var(--spacing-8)}.stats-grid.stats-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-base);padding:var(--spacing-6);transition:var(--transition-all);.support-inline{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-base);display:flex;flex-direction:column;gap:var(--spacing-4);justify-content:center;min-height:100%;padding:var(--spacing-6)}.support-inline .support-content{align-items:center;flex-direction:row}.support-inline .support-text{text-align:left}}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-header{grid-column-gap:var(--spacing-4);grid-row-gap:var(--spacing-3);align-items:center;column-gap:var(--spacing-4);display:grid;grid-template-columns:64px 1fr;grid-template-rows:auto auto;row-gap:var(--spacing-3)}.stat-icon{align-items:center;background:radial-gradient(circle at top,#fffffff2,#ffffffb3);border-radius:20px;box-shadow:0 12px 25px #1e40af1f;color:var(--color-primary-600);display:flex;font-size:2rem;grid-row:1/span 2;height:64px;justify-content:center;width:64px}.stat-info{display:flex;flex-direction:column;gap:var(--spacing-1)}.stat-title{color:#0f172a73;font-size:var(--font-size-sm);letter-spacing:.06em;text-transform:uppercase}.stat-value{color:var(--color-text-primary);font-size:2.75rem;font-weight:var(--font-weight-semibold);line-height:1}.stat-meta{align-items:center;border-top:1px solid #0f172a14;display:flex;grid-column:1/-1;justify-content:space-between;padding-top:var(--spacing-3)}.stat-meta-text{display:flex;flex-direction:column;gap:2px}.stat-meta-title{color:#0f172a66;font-size:var(--font-size-xs);letter-spacing:.05em;text-transform:uppercase}.stat-meta-value{color:var(--color-text-secondary);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.dashboard-grid{grid-gap:var(--spacing-8);display:grid;gap:var(--spacing-8);grid-template-columns:1fr}.dashboard-main{display:flex;flex-direction:column;gap:var(--spacing-8)}.dashboard-sidebar{display:flex;flex-direction:column;gap:var(--spacing-6)}.section-title{color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-6) 0}.quick-actions{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-base);padding:var(--spacing-6)}.actions-grid{grid-gap:var(--spacing-4);display:grid;gap:var(--spacing-4);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.action-card{align-items:center;border:1px solid #0000;border-radius:var(--radius-base);cursor:pointer;display:flex;gap:var(--spacing-4);padding:var(--spacing-4);transition:var(--transition-all)}.action-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.action-card.color-blue{background:linear-gradient(135deg,var(--color-primary-50) 0,var(--color-primary-100) 100%);border-color:var(--color-primary-200)}.action-card.color-purple{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);border-color:#d8b4fe}.action-card.color-green{background:linear-gradient(135deg,var(--color-success-50) 0,var(--color-success-100) 100%);border-color:var(--color-success-200)}.action-card.color-orange{background:linear-gradient(135deg,var(--color-warning-50) 0,var(--color-warning-100) 100%);border-color:var(--color-warning-200)}.action-icon{align-items:center;background:#fffc;border-radius:var(--radius-base);display:flex;flex-shrink:0;font-size:1.5rem;height:40px;justify-content:center;width:40px}.action-content{flex:1 1;min-width:0}.action-title{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-1) 0}.action-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:var(--line-height-normal);margin:0}.action-arrow{color:var(--color-text-tertiary);transition:var(--transition-colors)}.action-card:hover .action-arrow{color:var(--color-text-secondary);transform:translateX(4px)}.recent-activity{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-base);padding:var(--spacing-6)}.activity-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-6)}.activity-tabs{display:flex;gap:var(--spacing-2)}.tab-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);padding:var(--spacing-2) var(--spacing-4);transition:var(--transition-all)}.tab-btn:hover{border-color:var(--color-primary-300);color:var(--color-primary-600)}.tab-btn.active{background:var(--color-primary-600);border-color:var(--color-primary-600);color:#fff}.activity-list{flex-direction:column;margin-bottom:var(--spacing-6)}.activity-item,.activity-list{display:flex;gap:var(--spacing-4)}.activity-item{border-radius:var(--radius-base);padding:var(--spacing-4);transition:var(--transition-colors)}.activity-item:hover{background:var(--color-surface-hover)}.activity-icon{align-items:center;background:var(--color-neutral-100);border-radius:var(--radius-base);display:flex;flex-shrink:0;font-size:1.25rem;height:36px;justify-content:center;width:36px}.activity-content{flex:1 1;min-width:0}.activity-main{margin-bottom:var(--spacing-2)}.activity-title{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);margin:0 0 var(--spacing-1) 0}.activity-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:var(--line-height-normal);margin:0}.activity-meta{align-items:center;display:flex;font-size:var(--font-size-xs);gap:var(--spacing-3)}.activity-amount{font-weight:var(--font-weight-semibold)}.activity-amount.positive{color:var(--color-success-600)}.activity-amount.negative{color:var(--color-error-600)}.activity-time{color:var(--color-text-tertiary)}.activity-status{border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--spacing-1) var(--spacing-2)}.status-completed{background:var(--color-success-100);color:var(--color-success-700)}.status-processing{background:var(--color-warning-100);color:var(--color-warning-700)}.activity-footer{text-align:center}.support-section-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-base);padding:var(--spacing-6)}.support-content{align-items:center;display:flex;gap:var(--spacing-4)}.support-qr img{border:1px solid #0f172a14;border-radius:var(--radius-md);box-shadow:0 10px 24px #0f172a1f;height:132px;width:132px}.support-text{flex:1 1}.support-text p{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:var(--line-height-tight);margin:0}.announcement-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-base);overflow:hidden}.announcement-header{background:var(--color-neutral-50);border-bottom:1px solid var(--color-border);padding:var(--spacing-4) var(--spacing-6)}.announcement-header h3{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0}.announcement-content{padding:var(--spacing-4) var(--spacing-6)}.announcement-item{border-bottom:1px solid var(--color-border);padding:var(--spacing-3) 0}.announcement-item:last-child{border-bottom:none}.announcement-title{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-1)}.announcement-desc{color:var(--color-text-secondary);font-size:var(--font-size-xs);line-height:var(--line-height-normal);margin-bottom:var(--spacing-1)}.announcement-time{color:var(--color-text-tertiary);font-size:var(--font-size-xs)}.announcement-footer{background:var(--color-neutral-50);border-top:1px solid var(--color-border);padding:var(--spacing-4) var(--spacing-6);text-align:center}.btn{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-base);display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-2);justify-content:center;padding:var(--spacing-3) var(--spacing-4);text-decoration:none;transition:var(--transition-all)}.btn-sm{font-size:var(--font-size-xs);padding:var(--spacing-2) var(--spacing-3)}.btn-primary{background:var(--color-primary-600);border-color:var(--color-primary-600)}.btn-primary:hover{background:var(--color-primary-700);border-color:var(--color-primary-700)}.btn-secondary{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text-primary)}.btn-secondary:hover{border-color:var(--color-primary-300);color:var(--color-primary-600)}.btn-outline{background:#0000;border-color:var(--color-border);color:var(--color-text-secondary)}.btn-outline:hover{background:var(--color-primary-50);border-color:var(--color-primary-600);color:var(--color-primary-600)}.btn-text{background:#0000;border-color:#0000;color:var(--color-text-secondary);padding:var(--spacing-2)}.btn-text:hover{background:var(--color-primary-50);color:var(--color-primary-600)}@media (max-width:1024px){.dashboard-grid{gap:var(--spacing-6);grid-template-columns:1fr}.dashboard-sidebar{order:-1}}@media (max-width:768px){.dashboard-page{padding:0 var(--spacing-4)}.welcome-hero{padding:var(--spacing-6);text-align:center}.hero-content{flex-direction:column;gap:var(--spacing-4)}.hero-illustration{display:none}.stats-grid{gap:var(--spacing-4)}.actions-grid,.stats-grid{grid-template-columns:1fr}.activity-header{align-items:stretch;flex-direction:column;gap:var(--spacing-4)}.activity-tabs{justify-content:center}.support-content{text-align:center}.support-content,.support-inline .support-content{flex-direction:column}.support-inline .support-text{text-align:center}.support-qr img{height:120px;width:120px}}.bills-page{max-width:1200px}.content-card{padding:24px}.card-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}.card-header .radio-group{margin-bottom:0}.card-actions{align-items:center;display:flex}.action-link{color:#1890ff;font-size:14px;text-decoration:none}.action-link:hover{text-decoration:underline}.radio-group{margin-bottom:24px}.radio-group.outlined{border:1px solid #d9d9d9}.radio-group.small{height:32px}.radio-option{background:#fafafa;color:#000000a6;padding:6px 16px}.radio-option.active{background:#1890ff}.radio-option:hover:not(.active){background:#e6f7ff;color:#1890ff}.table-wrap{border:1px solid #f0f0f0;border-radius:4px;overflow:hidden}.table-header{background:#fafafa;border-bottom:1px solid #f0f0f0;display:grid;grid-template-columns:2fr 2fr 1fr}.th{border-right:1px solid #f0f0f0;color:#000000d9;font-size:14px;font-weight:500;padding:12px 16px}.th:last-child{border-right:none}.table-body{background:#fff}.tr{border-bottom:1px solid #f0f0f0;display:grid;grid-template-columns:2fr 2fr 1fr;transition:background-color .2s}.tr:last-child{border-bottom:none}.tr:hover{background:#fafafa}.td{align-items:center;border-right:1px solid #f0f0f0;color:#000000d9;display:flex;font-size:14px;padding:12px 16px}.td:last-child{border-right:none}.td.type{font-weight:500}.td.time{color:#000000a6;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.td.amount{font-weight:600;justify-content:flex-end}.td.amount.consume{color:#ff4d4f}.td.amount.gain{color:#52c41a}.loading-message{color:#00000073;font-size:14px;padding:40px 20px;text-align:center}.pagination{border-top:1px solid #f0f0f0;gap:12px;justify-content:center;padding-top:16px}.pagination button{background:#fff;border:1px solid #d9d9d9;border-radius:4px;color:#000000a6;cursor:pointer;font-size:14px;padding:6px 12px;transition:all .2s}.pagination button:hover:not(:disabled){border-color:#1890ff;color:#1890ff}.pagination button:disabled{background:#f5f5f5;border-color:#d9d9d9;color:#00000040;cursor:not-allowed}.pagination span{color:#000000a6;font-size:14px}.empty-state,.empty-state .td{padding:48px 24px}.empty-state .td{color:#00000073;font-size:14px;justify-content:center}@media (max-width:768px){.card-header{align-items:stretch;flex-direction:column}.card-actions{justify-content:flex-end;width:100%}.table-header,.tr{grid-template-columns:1fr}.td,.th{border-bottom:1px solid #f0f0f0;border-right:none}.td:last-child,.th:last-child{border-bottom:none}.td.amount{justify-content:flex-start}.pagination{flex-direction:column;gap:8px}}.recharge-page{background:#f5f5f5;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.page-title{color:#333;font-size:20px;line-height:1.4;margin-bottom:20px}.recharge-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:24px}.success-banner{background:#f6ffed;border:1px solid #b7eb8f;border-radius:8px;gap:12px;margin-bottom:16px;padding:16px}.success-banner,.success-icon{align-items:center;display:flex}.success-icon{background:#52c41a;border-radius:50%;color:#fff;font-weight:700;height:32px;justify-content:center;width:32px}.success-icon:before{content:"✓";font-size:18px}.success-texts{flex:1 1}.success-title{color:#389e0d;font-size:16px;font-weight:500;margin-bottom:4px}.success-sub{color:#52c41a;font-size:14px;letter-spacing:.033em}.intro-text{color:#000000d9;font-size:16px;font-weight:500;margin-bottom:16px}.radio-group.outlined{border:1px solid #40a9ff;border-radius:4px;display:inline-flex;height:36px;margin-bottom:20px;min-width:600px;overflow:hidden}.radio-group .radio-option{align-items:center;background:#fff;border:none;color:#40a9ff;cursor:pointer;display:inline-flex;flex:1 1;font-size:14px;gap:4px;justify-content:center;padding:8px 24px;transition:all .2s;white-space:nowrap}.radio-group .radio-option.left{border-right:1px solid #40a9ff}.radio-group .radio-option.active{background:#40a9ff;color:#fff}.plans-grid{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.plan-card{background:#fff;border:2px solid #e8e8e8;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;height:120px;justify-content:space-between;padding:16px;position:relative;transition:all .2s;width:300px}.plan-card:hover{border-color:#40a9ff;box-shadow:0 2px 8px #40a9ff26}.plan-card.primary{background:linear-gradient(135deg,#f0f8ff,#e6f7ff);border-color:#40a9ff}.plan-card.selected{border-color:#40a9ff;box-shadow:0 0 0 2px #40a9ff33}.plan-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.plan-amount{color:#40a9ff;font-size:36px;font-weight:700;line-height:1}.plan-amount.dark{color:#333}.plan-unit{color:#666;font-size:14px;margin-left:4px}.plan-label{background:#40a9ff1a;border-radius:4px;color:#40a9ff;font-size:12px;padding:2px 8px}.plan-label.dark{background:#0000000d;color:#666}.plan-description{color:#999;font-size:12px;margin-bottom:12px}.plan-pricing{align-items:center;display:flex;gap:8px}.plan-price{color:#ff4d4f;font-size:18px;font-weight:700}.plan-price.dark{color:#333}.plan-original{color:#999;font-size:12px;margin-left:8px;text-decoration:line-through}.plan-badge{background:#ff4d4f;border-radius:4px;color:#fff;font-size:12px;font-weight:500;padding:2px 6px}.plan-badge.muted{background:#f5f5f5;color:#999}.plan-card.dashed{align-items:center;border:1px dashed #d9d9d9;display:flex;justify-content:center}.contact-text{color:#999;font-size:14px}.pay-section{align-items:flex-start;background:#fafafa;border:1px solid #e8e8e8;border-radius:8px;display:flex;gap:20px;margin-bottom:24px;padding:16px}.qr-block{flex-shrink:0}.qr-block,.qr-image{height:120px;width:120px}.qr-image{align-items:center;background:#f0f0f0;border:1px solid #e8e8e8;border-radius:8px;display:flex;justify-content:center}.pay-info{flex:1 1}.amount-line{align-items:center;display:flex;gap:8px;margin-bottom:16px}.amount-label{color:#333;font-size:14px}.amount-value{color:#ff4d4f;font-size:20px;font-weight:700}.note-text{color:#0006;display:flex;flex-direction:column;font-size:12px;letter-spacing:.033em;line-height:2}.plan-banner{border:1px solid #1890ff;border-radius:8px;height:160px;margin-top:8px;position:relative;transition:all .2s ease;width:556px}.plan-banner.clickable:hover{border-color:#40a9ff;box-shadow:0 2px 8px #40a9ff26;transform:translateY(-1px)}.banner-left{background:#fff;height:160px;left:0;position:absolute;top:0;width:266px}.banner-bottom{background:#f0f8ff;bottom:0;height:44px;left:0;position:absolute;width:556px}.banner-title{color:#1890ff;font-size:24px;height:33px;left:206px;line-height:1.2;min-width:145px;position:absolute;text-align:center;top:30px;white-space:nowrap;width:auto}.banner-desc{color:#0006;font-size:12px;height:24px;left:123px;line-height:2;position:absolute;top:74px;width:310px}.banner-price{color:#1890ff;font-size:20px;font-weight:700;height:22px;left:225px;position:absolute;text-align:center;top:127px;width:105px}.wechat-icon{background:#fff;height:15px;margin-left:77px;margin-top:10px;width:17px}.error-message{padding:16px}.error-message:before{color:#ff4d4f;content:"⚠";font-size:16px}@media (max-width:1200px){.plans-grid{justify-content:center}}@media (max-width:900px){.plans-grid{align-items:center;flex-direction:column}.plan-card{max-width:400px;width:100%}.pay-section{align-items:center;flex-direction:column;text-align:center}}@media (max-width:600px){.recharge-page{padding:16px}.plans-grid{gap:12px}.plan-card{max-width:none}.qr-block,.qr-image{height:100px;width:100px}.radio-group.outlined{min-width:auto;width:100%}.radio-group .radio-option{flex:1 1;font-size:13px;justify-content:center;padding:8px 12px}}.loading-overlay{align-items:center;background:#ffffffe6;border-radius:8px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.loading-spinner{height:24px;width:24px}.payment-status{align-items:center;border-radius:8px;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.payment-status.success{background:#f6ffed;border:1px solid #b7eb8f;color:#52c41a}.payment-status.error{background:#fff2f0;border:1px solid #ffccc7;color:#ff4d4f}.payment-status.expired{background:#fff7e6;border:1px solid #ffd591;color:#fa8c16}.payment-status-icon{font-size:48px;margin-bottom:16px}.payment-status-text{font-size:16px;font-weight:500;margin-bottom:16px}.retry-button{background:#1890ff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s}.retry-button:hover{background:#40a9ff}.retry-button:active{background:#096dd9}.plan-card.loading{opacity:.7;pointer-events:none}.plan-amount,.plan-label,.plan-minutes{position:relative;z-index:2}.plan-card:focus{outline:2px solid #1890ff;outline-offset:2px}.radio-option:focus{outline:2px solid #1890ff;outline-offset:1px}.recharge-card{line-height:1.5}.intro-text{line-height:1.6}.contact-section{background:#f8f9fa;border-radius:8px;gap:16px;margin-top:24px;padding:16px}.contact-qr,.contact-section{align-items:center;display:flex}.contact-qr{background:#f0f0f0;border:1px solid #e8e8e8;border-radius:4px;color:#999;font-size:12px;height:80px;justify-content:center;width:80px}.contact-info{flex:1 1}.contact-title{color:#333;font-size:14px;font-weight:500;margin-bottom:4px}.contact-desc{color:#666;font-size:12px}.my-videos-page{background:#fff;margin:0 auto;max-width:1200px;padding:0 24px}.batch-delete-btn{background:#ff4d4f;border:none;border-radius:2px;box-shadow:0 2px 0 #00000005;color:#fff;cursor:pointer;font-size:14px;height:32px;padding:4px 15px}.batch-delete-btn:hover{background:#ff7875}.video-card{background:#fff;border:1px solid #0000001a;border-radius:8px;cursor:pointer;height:292px;padding:0 16px;position:relative;transition:box-shadow .2s;width:266px}.video-card:hover{box-shadow:0 2px 8px #00000026}.video-thumb{background:#f5f5f5;height:160px;left:0;overflow:hidden;position:absolute;top:0;width:266px}.video-thumb,.video-thumb video{border-radius:8px 8px 0 0}.video-placeholder{align-items:center;background:#f5f5f5;display:flex;height:100%;justify-content:center;width:100%}.video-icon{color:#1890ff;font-size:48px}.video-status{border-radius:4px;color:#fff;font-size:12px;font-weight:500;padding:4px 8px;position:absolute;right:8px;top:8px;z-index:10}.status-success{background:#52c41a}.status-failed{background:#ff4d4f}.status-processing{background:#1890ff}.status-queued{background:#faad14}.status-unknown{background:#8c8c8c}.video-name{color:#000;font-size:14px;font-weight:500;top:172px}.video-info,.video-name{left:16px;overflow:hidden;position:absolute;text-overflow:ellipsis;white-space:nowrap;width:234px}.video-info{color:#0006;font-size:12px;letter-spacing:.033em;top:200px}.error-state,.loading-state{color:#00000073;font-size:14px;padding:60px 24px;text-align:center}.error-state{color:#ff4d4f}@media (max-width:600px){.my-videos-page{padding:0 16px}.cards-grid{gap:16px;grid-template-columns:1fr}.video-card{margin:0 auto;max-width:266px;width:100%}.video-thumb{width:100%}.page-header{align-items:flex-start;flex-direction:column;gap:16px}.toolbar{align-items:stretch;flex-direction:column;gap:12px}.search-box{max-width:264px;width:100%}}.generate-video-page{max-width:1200px}.workflow-content{padding:24px}.steps-container{gap:24px;margin-bottom:40px}.generate-section{border-top:1px solid #f0f0f0;display:flex;justify-content:flex-start;padding-top:24px}.generate-button{background:#1890ff;border-radius:2px;color:#fff;font-weight:400;height:40px;min-width:120px;padding:6.4px 15px;transition:all .3s}.generate-button:hover:not(.disabled){background:#40a9ff}.generate-button.disabled{background:#f5f5f5;color:#00000040}.production-content{padding:60px 24px;text-align:center}.coming-soon p{color:#00000073;font-size:14px}.step-container{background:#fafafa;border-radius:4px}.step-title{color:#000000d9;font-size:16px;font-weight:500;margin-bottom:16px}.radio-group{border:1px solid #d9d9d9;border-radius:4px;overflow:hidden}.radio-option{border:none;border-right:1px solid #d9d9d9;color:#000000d9;flex:1 1;padding:5px 16px;transition:all .3s}.radio-option:last-child{border-right:none}.radio-option.active{background:#1890ff0f;border-color:#1890ff;color:#1890ff}.radio-option:hover:not(.active){background:#f5f5f5}.form-input,.form-select,.form-textarea{border:1px solid #d9d9d9;border-radius:2px;padding:8px 12px;transition:border-color .3s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.info-text{color:#0006;font-size:12px;line-height:1.67;margin-bottom:8px}.upload-area{border:1px dashed #d9d9d9;border-radius:2px;padding:16px;transition:border-color .3s}.upload-area:hover{border-color:#1890ff}.upload-area.dragover{background:#1890ff0f;border-color:#1890ff}.upload-icon{color:#1890ff;height:48px;margin:0 auto 16px;width:48px}.upload-text{color:#000000d9;font-size:16px;margin-bottom:4px}.upload-hint{color:#00000073;line-height:1.5}.file-list{margin-top:16px}.file-error{color:#ff4d4f;font-size:12px;grid-column:1/-1;margin-top:4px}.url-list{flex-direction:column;margin-top:12px}.url-item,.url-list{display:flex;gap:8px}.url-item{align-items:center;background:#f5f5f5;border-radius:4px;padding:8px 12px}.url-text{color:#000000d9;flex:1 1;font-size:14px;word-break:break-all}.file-item{align-items:center;border-radius:2px;display:flex;padding:8px 4px;transition:background-color .3s}.file-item:hover{background:#fafafa}.file-item.error{color:#ff4d4f}.file-icon{color:#00000073;height:14px;margin-right:8px;width:14px}.file-name{color:#1890ff;flex:1 1}.file-item.error .file-name{color:#ff4d4f}.file-actions{align-items:center}.delete-button{background:none;border:none;border-radius:2px;color:#00000073;cursor:pointer;padding:3px 5px;transition:all .3s}.delete-button:hover{background:#f5f5f5;color:#000000d9}.music-grid{grid-gap:12px;border:1px solid #0000001a;border-radius:2px;display:grid;gap:12px;grid-template-columns:1fr;max-height:240px;overflow-y:auto;padding:12px}.music-grid::-webkit-scrollbar{width:6px}.music-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.music-grid::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.music-grid::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.music-item{align-items:center;border-radius:4px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:background-color .3s}.music-item:hover{background:#f6f6f6}.music-item.selected{background:#ebf9ff;border:1px solid #67a9ff}.music-play-button{align-items:center;background:#fff;border:1px solid #1890ff;border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;height:16px;justify-content:center;width:16px}.music-info{flex:1 1;min-width:0}.music-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.music-duration,.music-title{color:#000000b3;font-size:14px}.music-duration{flex-shrink:0;text-align:right}.loading-spinner{display:inline-block}.file-item.uploading{opacity:.7}.file-item.uploading .file-name{color:#00000073}.success-message{color:#52c41a;font-size:14px}.error-message,.success-message{align-items:center;display:flex;gap:8px;margin-top:8px}.status-section{background:#fafafa;border-top:1px solid #f0f0f0;padding:24px}.status-info{color:#000000a6;font-size:14px;margin-top:8px}.result-link{margin-top:12px}.result-link a{color:#1890ff;font-weight:500;text-decoration:none}.result-link a:hover{text-decoration:underline}.production-workflow .steps-container{display:flex;flex-direction:column;gap:32px;margin-bottom:40px}.production-workflow .generate-section{border-top:1px solid #f0f0f0;display:flex;justify-content:flex-start;padding-top:24px}@media (max-width:768px){.production-workflow,.workflow-content{padding:16px}.steps-container{gap:16px}.production-workflow .steps-container{gap:24px}.step-container{padding:16px}.radio-group{flex-direction:column}.radio-option{border-bottom:1px solid #d9d9d9;border-right:none}.radio-option:last-child{border-bottom:none}.music-grid{grid-template-columns:1fr}.status-section{padding:16px}}.sora-placeholder{background:#fafafa;padding:80px 24px;text-align:center}.placeholder-content h3{color:#333;font-size:20px;font-weight:500;margin-bottom:16px}.placeholder-content p{color:#666;font-size:16px;line-height:1.5}.tabs{background:#fff;border-bottom:1px solid #f0f0f0}.tab{font-weight:400;margin-right:40px;padding:16px 0;transition:all .2s}.tab:disabled{cursor:not-allowed;opacity:.6}.tab:not(:disabled):hover{color:#40a9ff}.tab.active{font-weight:500}@media (max-width:768px){.tabs{overflow-x:auto;padding:0 16px;white-space:nowrap}.tab{flex-shrink:0;margin-right:24px}.sora-placeholder{padding:60px 16px}}.production-workflow{padding:24px}.steps-container{display:flex;flex-direction:column;gap:32px;margin-bottom:32px}.step-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.step-title{color:#1f2937;font-size:18px;font-weight:600;margin-bottom:20px}.step-content{display:flex;flex-direction:column;gap:16px}.radio-group{display:flex;gap:12px;margin-bottom:16px}.radio-option{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;padding:12px 20px;transition:all .2s}.radio-option:hover{background:#f8f9ff;border-color:#4f46e5}.radio-option.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.form-group{display:flex;flex-direction:column;gap:8px}.form-input,.form-select,.form-textarea{border:1px solid #d1d5db;border-radius:8px;font-size:14px;padding:12px 16px;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.form-textarea{min-height:100px}.generate-section{background:#f9fafb;border-radius:12px;padding:32px;text-align:center}.generate-button{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;min-width:160px;padding:16px 48px;transition:all .2s}.generate-button.enabled{background:#10b981;color:#fff}.generate-button.enabled:hover{background:#059669;transform:translateY(-1px)}.generate-button.disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed}.selected-item{align-items:center;background:#f8f9fa;border:2px solid #10b981;border-radius:12px;display:flex;gap:16px;margin-bottom:16px;padding:16px}.selected-avatar,.selected-voice{align-items:center;background:#e5e7eb;border-radius:8px;display:flex;height:60px;justify-content:center;overflow:hidden;width:60px}.selected-avatar img,.selected-voice img{height:100%;object-fit:cover;width:100%}.voice-icon{font-size:24px}.selected-info{flex:1 1}.selected-name{color:#1f2937;font-weight:600;margin-bottom:4px}.selected-key{color:#6b7280;font-family:monospace;font-size:12px}.voice-preview{height:30px;margin-top:8px;width:200px}.change-btn{background:#6b7280;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s}.change-btn:hover{background:#4b5563}.no-selection{background:#f9fafb;border:2px dashed #d1d5db;border-radius:12px;margin-bottom:16px;padding:32px;text-align:center}.no-selection p{color:#6b7280;margin-bottom:16px}.select-btn{border-radius:8px;padding:12px 24px}.manual-input-section{border-top:1px solid #e5e7eb;margin-top:16px;padding-top:16px}.form-label{color:#374151}.sora-generation{background:#fff;padding:24px}.sora-section{border-bottom:1px solid #f0f0f0;margin-bottom:32px;padding-bottom:24px}.sora-section:last-child{border-bottom:none;margin-bottom:0}.section-title{align-items:center;color:#333;display:flex;font-size:16px;font-weight:500;gap:8px;margin-bottom:8px}.required{color:#ff4d4f;font-size:12px;font-weight:400}.section-desc{color:#666}.section-desc,.sora-tip{font-size:14px;line-height:1.5;margin-bottom:16px}.sora-tip{background:#f0f8ff;border-left:3px solid #1890ff;border-radius:4px;color:#1890ff;padding:12px}.upload-requirements{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-bottom:16px;padding:16px}.requirement-item{align-items:center;display:flex;font-size:14px;margin-bottom:8px}.requirement-item:last-of-type{margin-bottom:12px}.requirement-label{color:#666;font-weight:500;min-width:80px}.requirement-value{color:#333;font-weight:500}.requirement-warning{align-items:center;background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;display:flex;font-size:13px;gap:8px;padding:8px 12px}.warning-icon{font-size:16px}.warning-text{color:#856404;font-weight:500}.sora-upload-area{align-items:center;background:#fafafa;border:2px dashed #d9d9d9;border-radius:8px;cursor:pointer;display:flex;justify-content:center;margin-bottom:16px;margin-left:auto;margin-right:auto;min-height:60px;padding:8px 16px;text-align:center;transition:all .2s}.sora-upload-area.drag-active,.sora-upload-area:hover{background:#f0f8ff;border-color:#1890ff}.upload-content{align-items:center;display:flex;flex-direction:column;gap:2px;max-height:100px}.upload-icon{font-size:16px;opacity:.6}.upload-text{color:#333;font-size:13px;margin:0}.upload-hint{color:#666;font-size:11px}.uploaded-file{margin-top:16px}.file-preview{align-items:center;background:#fafafa;border:1px solid #e8e8e8;border-radius:6px;display:flex;gap:10px;padding:10px;position:relative}.preview-image{border:1px solid #e8e8e8;border-radius:4px;height:48px;object-fit:cover;width:48px}.file-info{flex:1 1}.file-name{font-size:14px}.delete-file-btn{align-items:center;background:#ff4d4f;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;height:20px;justify-content:center;position:absolute;right:8px;top:8px;transition:background-color .2s;width:20px}.delete-file-btn:hover{background:#ff7875}.upload-error{background:#fff2f0;border:1px solid #ffccc7;border-radius:4px;color:#ff4d4f;font-size:14px;margin-top:8px;padding:8px 12px}.description-input{position:relative}.description-textarea{border:1px solid #d9d9d9;border-radius:6px;font-family:inherit;font-size:14px;line-height:1.5;min-height:120px;padding:12px;resize:vertical;width:100%}.description-textarea:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff1a;outline:none}.char-count{color:#999;font-size:12px;margin-top:4px;text-align:right}.duration-options,.ratio-options{display:flex;flex-wrap:wrap;gap:24px}.duration-option,.ratio-option{align-items:center;cursor:pointer;display:flex;gap:8px}.duration-option input,.ratio-option input{height:16px;margin:0;width:16px}.duration-text,.ratio-text{color:#333;font-size:14px;-webkit-user-select:none;user-select:none}.sora-generate-section{padding-top:24px;text-align:center}.sora-generate-btn{background:#1890ff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;min-width:120px;padding:12px 32px;transition:background-color .2s}.sora-generate-btn:hover:not(.disabled){background:#40a9ff}.sora-generate-btn.disabled{background:#d9d9d9;color:#999;cursor:not-allowed}@media (max-width:768px){.sora-generation{padding:16px}.sora-section{margin-bottom:24px}.sora-upload-area{padding:16px 12px}.file-preview{flex-direction:column;padding:16px;text-align:center}.preview-image{height:80px;width:80px}.duration-options,.ratio-options{flex-direction:column;gap:12px}}.file-preview.uploading{opacity:.7;pointer-events:none}.upload-status{color:#1890ff;font-size:12px;margin-top:2px}.upload-success{color:#52c41a;font-size:12px;margin-top:2px}.upload-spinner{position:absolute;right:40px;top:50%;transform:translateY(-50%)}.spinner{animation:spin 1s linear infinite;border:2px solid #f3f3f3;border-radius:50%;border-top-color:#1890ff;height:16px;width:16px}.sora-upload-area.disabled{cursor:not-allowed;opacity:.6;pointer-events:none}.sora-upload-area.disabled:hover{background:#fafafa;border-color:#d9d9d9}@keyframes shimmer{0%{left:-100%}to{left:100%}}@keyframes progressSweep{0%{left:-100%}to{left:100%}}.loading-spinner.white{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff}.loading-spinner-sm{animation:spin 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;height:16px;width:16px}.progress-bar-enhanced{overflow:hidden;position:relative}.progress-bar-enhanced:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}.step-indicator{transition:all .3s cubic-bezier(.4,0,.2,1)}.step-indicator.active{box-shadow:0 4px 12px #1890ff4d;transform:scale(1.1)}.step-indicator.completed{background:linear-gradient(135deg,#10b981,#059669)}.status-badge{border-radius:12px;font-size:12px;font-weight:500;gap:4px;padding:4px 8px}.status-badge.uploading{background:#1890ff1a;color:#1890ff}.status-badge.processing{background:#ffa5001a;color:#fa8c16}.status-badge.completed{background:#10b9811a;color:#10b981}.file-info-enhanced{background:linear-gradient(135deg,#f8faff,#f0f8ff);border:1px solid #e6f7ff;border-radius:8px;padding:12px 16px}.file-info-enhanced .file-icon{color:#1890ff;font-size:20px}.cancel-upload-btn{background:#fff;border:1px solid #ff4d4f;color:#ff4d4f;transition:all .2s ease}.cancel-upload-btn:hover{background:#ff4d4f;box-shadow:0 2px 8px #ff4d4f33;color:#fff;transform:translateY(-1px)}.upload-progress-container{background:linear-gradient(135deg,#f0f8ff,#e6f7ff);border:2px solid #1890ff;border-radius:12px;overflow:hidden;position:relative}.upload-progress-container:before{animation:progressSweep 2s infinite;background:linear-gradient(90deg,#0000,#1890ff,#0000);content:"";height:2px;left:-100%;position:absolute;top:0;width:100%}.avatar-upload{margin:0 auto;max-width:800px;padding:24px}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:8px;font-size:14px;padding:12px 16px;transition:border-color .2s;width:100%}.remove-file{height:24px;width:24px}.loading-container{padding:64px}.empty-state{color:#666;padding:64px 32px}.empty-state p{font-size:16px;margin-bottom:24px}.create-btn{background:#4f46e5;border-radius:8px;padding:12px 24px;transition:background-color .2s}.create-btn:hover{background:#4338ca}.avatar-actions{display:flex;gap:8px;margin-top:12px}.select-btn{background:#4f46e5;border:none;border-radius:6px;color:#fff;flex:1 1;font-size:12px;padding:8px 16px;transition:background-color .2s}.select-btn:hover{background:#4338ca}.delete-btn{background:#ef4444;border-radius:6px;color:#fff;font-size:12px;padding:8px 12px;transition:background-color .2s}.delete-btn:hover{background:#dc2626}.my-avatars-page{background:#fff;margin:0 auto;max-width:1200px;padding:0 24px}.avatar-card{background:#fff;border:1px solid #0000001a;border-radius:8px;cursor:pointer;height:292px;padding:0 16px;position:relative;transition:box-shadow .2s;width:266px}.avatar-card:hover{box-shadow:0 2px 8px #00000026}.avatar-thumb{background:#d9d9d9;border-radius:8px 8px 0 0;height:160px;left:0;top:0;width:266px}.avatar-name,.avatar-thumb{overflow:hidden;position:absolute}.avatar-name{color:#000;font-size:14px;font-weight:500;left:16px;text-overflow:ellipsis;top:172px;white-space:nowrap;width:234px}.avatar-key{color:#0006;font-family:Courier New,monospace;font-size:12px;left:16px;letter-spacing:.033em;top:200px}.avatar-key,.delete-btn{position:absolute}.delete-btn:hover{background:#fff1f0;border-color:#ff7875}.upload-hint{height:210px}@media (max-width:600px){.my-avatars-page{padding:0 16px}.cards-grid{gap:16px;grid-template-columns:1fr}.avatar-card{margin:0 auto;max-width:266px;width:100%}.avatar-thumb{width:100%}.page-header{align-items:flex-start;flex-direction:column;gap:16px}.tabs{overflow-x:auto;white-space:nowrap}.search-box{max-width:264px;width:100%}}.upload-form{padding:24px}.form-group{margin-bottom:32px}.form-label{font-weight:400;line-height:1.57}.form-hint{color:#0006;font-size:12px;font-weight:400;letter-spacing:3.33%;line-height:2em;margin-left:8px}.form-input{border:1px solid #e0e0e0;border-radius:2px;color:#000000d9;height:33px;outline:none;padding:4px 12px;width:525px}.form-input::placeholder{color:#00000040}.file-upload-area{border:1px solid #e0e0e0;border-radius:2px;cursor:pointer;height:33px;max-width:1136px;position:relative;transition:all .3s;width:100%}.file-upload-area:hover{border-color:#1890ff}.file-upload-area.drag-active{background-color:#1890ff0d;border-color:#1890ff}.file-input{cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%}.file-upload-content{align-items:center;display:flex;height:100%;position:relative}.file-select-button{align-items:center;background:#f1f1f1;border:1px solid #e0e0e0;border-radius:2px;color:#000;cursor:pointer;display:flex;font-size:14px;height:33px;justify-content:center;transition:all .3s;-webkit-user-select:none;user-select:none;width:92px}.file-select-button:hover{background:#e6e6e6}.file-status{font-size:14px;line-height:1.57;margin-left:11px}.file-selected{color:#000}.file-placeholder{color:#0006}.form-actions{margin-top:40px}.btn{border:1px solid;border-radius:2px;cursor:pointer;font-size:16px;font-weight:400;line-height:1.5em;outline:none;padding:6.4px 15px;text-align:center;transition:all .3s;-webkit-user-select:none;user-select:none}.btn:hover{transform:translateY(-1px)}.btn-primary{background:#1890ff;border-color:#1890ff;color:#fff}.btn-primary:hover{background:#40a9ff;border-color:#40a9ff}.btn-primary:active{background:#096dd9;border-color:#096dd9}.btn-large{font-size:16px;min-width:112px;padding:6.4px 15px}@media (max-width:768px){.upload-form{padding:16px}.form-input{width:100%}.file-upload-area{max-width:100%}.file-upload-content{align-items:flex-start;flex-direction:column;height:auto;min-height:33px;padding:8px}.file-select-button{margin-bottom:8px}.file-status{margin-left:0}}.form-input.error{border-color:#ff4d4f}.form-input.error:focus{border-color:#ff4d4f;box-shadow:0 0 0 2px #ff4d4f33}.error-message{font-size:12px;margin-top:4px}.btn:disabled{cursor:not-allowed;opacity:.6}.btn:disabled,.btn:disabled:hover{transform:none}.voice-upload-page{max-width:1200px}.page-title{margin-bottom:24px}.content-card{background:#fff;border-radius:2px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.tabs{padding:0 24px}.tab{transition:color .3s}.empty-state{color:#00000073;padding:60px 24px}@media (max-width:768px){.tabs{flex-direction:column;padding:16px 24px}.tab{margin-bottom:8px;margin-right:0;padding:8px 0}.tab.active:after{display:none}}.voice-upload-form{margin:0 auto;max-width:800px;padding:24px}.upload-header{margin-bottom:32px;text-align:center}.upload-header h2{color:#1a1a1a;font-size:24px;font-weight:600;margin-bottom:8px}.upload-header p{color:#666;font-size:14px}.upload-form{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:32px}.form-group{margin-bottom:24px}.form-group label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{background:#fff;border:1px solid #ddd;border-radius:8px;font-size:14px;padding:12px 16px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.upload-area{background:#fafafa;border:2px dashed #ddd;border-radius:12px;cursor:pointer;padding:32px;text-align:center;transition:all .2s}.upload-area:hover{background:#f8f9ff;border-color:#4f46e5}.upload-area.has-file{background:#f0fdf4;border-color:#10b981}.upload-placeholder{align-items:center;display:flex;flex-direction:column;gap:16px}.upload-icon{font-size:48px;opacity:.5}.upload-text p{color:#666;margin:0}.upload-text p:first-child{color:#333;font-weight:500}.upload-hint{color:#999;font-size:12px}.file-info{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:16px;padding:16px}.file-icon{font-size:32px}.file-details{flex:1 1;text-align:left}.file-name{color:#333;font-weight:500;margin-bottom:4px}.file-size{color:#666;font-size:12px}.file-actions{display:flex;gap:8px}.play-btn{align-items:center;background:#10b981;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;height:32px;justify-content:center;transition:background-color .2s;width:32px}.play-btn:hover{background:#059669}.remove-file{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;height:32px;justify-content:center;transition:background-color .2s;width:32px}.remove-file:hover{background:#dc2626}.upload-progress{background:#f8f9fa;border-radius:8px;margin:16px 0;padding:16px}.progress-bar{background:#e5e7eb;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden;width:100%}.progress-fill{background:#4f46e5;height:100%;transition:width .3s ease}.progress-text{color:#4f46e5;font-size:14px;font-weight:500;text-align:center}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;margin:16px 0;padding:12px 16px}.form-actions{margin-top:32px;text-align:center}.submit-btn{background:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;min-width:120px;padding:12px 32px;transition:background-color .2s}.submit-btn:hover:not(:disabled){background:#4338ca}.submit-btn:disabled{background:#9ca3af;cursor:not-allowed}.upload-guidelines{background:#f8f9fa;border-radius:12px;margin-top:32px;padding:24px}.upload-guidelines h3{color:#333;font-size:16px;font-weight:600;margin-bottom:16px}.upload-guidelines ul{list-style:none;margin:0;padding:0}.upload-guidelines li{color:#666;font-size:14px;padding:8px 0 8px 20px;position:relative}.upload-guidelines li:before{color:#4f46e5;content:"•";font-weight:700;left:0;position:absolute}.my-voices-page{background:#fff;margin:0 auto;max-width:1200px;padding:0 24px}.container{width:100%}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-title{margin:0}.create-btn{border-radius:2px;box-shadow:0 2px 0 #00000005;height:32px;padding:4px 15px}.create-btn:hover{background:#40a9ff}.tabs{border-bottom:1px solid #0000000f;margin-bottom:16px}.tab{color:#000000d9;margin-right:32px;padding:12px 0;position:relative}.tab.active:after{background:#1890ff;bottom:0;content:"";height:2px;left:0;position:absolute;right:0}.toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin:16px 0}.search-box{border:1px solid #d9d9d9;border-radius:2px;font-size:14px;height:32px;padding:4px 12px;width:264px}.search-box:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33;outline:none}.total-count{color:#00000073;font-size:12px;margin-left:auto}.cards-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(4,266px)}.voice-card{background:#fff;border:1px solid #0000001a;border-radius:8px;cursor:pointer;height:292px;padding:0 16px;position:relative;transition:box-shadow .2s;width:266px}.voice-card:hover{box-shadow:0 2px 8px #00000026}.voice-thumb{align-items:center;background:#f0f8ff;border-radius:8px 8px 0 0;display:flex;height:160px;justify-content:center;left:0;overflow:hidden;position:absolute;top:0;width:266px}.voice-icon{color:#1890ff;font-size:48px}.voice-name{color:#000;font-size:14px;font-weight:500;top:172px}.voice-info,.voice-name{left:16px;overflow:hidden;position:absolute;text-overflow:ellipsis;white-space:nowrap;width:234px}.voice-info{color:#0006;font-family:Courier New,monospace;font-size:12px;letter-spacing:.033em;top:200px}.select-btn{background:#fff;border:1px solid #d9d9d9;border-radius:2px;box-shadow:0 2px 0 #00000005;color:#000000d9;cursor:pointer;font-size:14px;height:32px;left:16px;padding:4px 15px;position:absolute;top:244px}.select-btn:hover{border-color:#1890ff;color:#1890ff}.delete-btn{background:#fff;border:1px solid #ff4d4f;border-radius:2px;box-shadow:0 2px 0 #00000005;color:#ff4d4f;height:32px;padding:4px 15px;right:16px;top:244px}.delete-btn:hover{background:#ff4d4f;border-color:#ff4d4f;color:#fff}.upload-hint{background:#1890ff0f;border:1px dashed #1890ff66;border-radius:4px;color:#1890ff;font-size:14px;font-weight:500;height:100px;justify-content:center;margin:24px 0;width:100%}.pagination,.upload-hint{align-items:center;display:flex}.pagination{gap:8px;justify-content:flex-end;margin-top:24px}.page-btn,.page-num{align-items:center;background:#fff;border:1px solid #e3e3e3;border-radius:2px;color:#000000d9;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;min-width:32px;padding:10px}.page-btn:disabled{background:#f5f5f5;color:#00000040;cursor:not-allowed}.page-num.active{border-color:#1890ff;color:#1890ff;font-weight:500}.page-ellipsis{color:#61616180;letter-spacing:.14em}@media (max-width:1200px){.cards-grid{grid-template-columns:repeat(3,266px);justify-content:center}}@media (max-width:900px){.cards-grid{grid-template-columns:repeat(2,266px)}}@media (max-width:600px){.my-voices-page{padding:0 16px}.cards-grid{gap:16px;grid-template-columns:1fr}.voice-card{margin:0 auto;max-width:266px;width:100%}.voice-thumb{width:100%}.page-header{align-items:flex-start;flex-direction:column;gap:16px}.tabs{overflow-x:auto;white-space:nowrap}.search-box{max-width:264px;width:100%}}.apikeys-page{margin:0 auto;max-width:1200px;padding:0 24px}.page-title{margin-bottom:8px}.page-description{color:#000000a6;font-size:14px;line-height:1.5;margin-bottom:24px}.apikeys-card{background:#fff;border-radius:2px;overflow:hidden}.tabs-container{border-bottom:1px solid #f0f0f0}.tabs{display:flex}.tab{background:none;border:none;border-bottom:2px solid #0000;color:#000000a6;cursor:pointer;font-size:14px;padding:16px 24px;transition:all .3s}.tab.active,.tab:hover{color:#1890ff}.tab.active{border-bottom-color:#1890ff}.tab-content{padding:24px}.loading-container{align-items:center;color:#666;display:flex;font-size:14px;justify-content:center;padding:40px}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #f3f3f3;border-radius:50%;border-top-color:#1890ff;height:20px;margin-right:8px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.table-container{overflow-x:auto}.apikeys-table{border-collapse:collapse;font-size:14px;width:100%}.apikeys-table thead{background:#fafafa}.apikeys-table th{font-weight:500;text-align:left}.apikeys-table td,.apikeys-table th{border-bottom:1px solid #f0f0f0;color:#000000d9;padding:16px}.apikeys-table td{vertical-align:middle}.apikeys-table td:nth-child(2),.apikeys-table th:nth-child(2){max-width:480px;word-break:break-all}.apikeys-table td:last-child,.apikeys-table th:last-child{text-align:right;white-space:nowrap}.apikeys-table tbody tr:hover{background-color:#fafafa}.delete-btn{background:none;border:none;border-radius:4px;color:#1890ff;cursor:pointer;font-size:14px;padding:4px 8px;transition:all .3s}.delete-btn:hover{background-color:#e6f7ff}.form-container{max-width:600px}.form-group{margin-bottom:4px}.form-label{color:#000000d9;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-input{background:#fff;border:1px solid #d9d9d9;border-radius:4px;font-size:14px;padding:8px 12px;transition:border-color .3s;width:100%}.form-input:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33;outline:none}.form-input::placeholder{color:#bfbfbf}.form-textarea{background:#fff;border:1px solid #d9d9d9;border-radius:4px;font-family:inherit;font-size:14px;min-height:80px;padding:8px 12px;resize:vertical;transition:border-color .3s;width:100%}.form-textarea:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33;outline:none}.form-textarea::placeholder{color:#bfbfbf}.create-btn{background:#1890ff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .3s}.create-btn:hover:not(:disabled){background:#40a9ff}.create-btn:disabled{background:#f5f5f5;color:#bfbfbf;cursor:not-allowed}.empty-state{color:#999;font-size:14px;padding:40px 20px;text-align:center}@media (max-width:768px){.apikeys-page{padding:0 16px}.tab-content{padding:16px}.apikeys-table{font-size:12px}.apikeys-table td,.apikeys-table th{padding:12px 8px}}.api-keys-page{background-color:var(--color-background);min-height:100vh}.api-key-card{background:var(--color-surface);border:1px solid var(--color-border);transition:all var(--transition-base)}.api-key-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-md);transform:translateY(-2px)}.api-key-display{background:var(--color-neutral-100);border:1px solid var(--color-border);border-radius:var(--radius-base);color:var(--color-text-primary);font-family:var(--font-family-mono);font-size:var(--font-size-sm);padding:var(--spacing-3) var(--spacing-4);-webkit-user-select:all;user-select:all}.usage-progress{background-color:var(--color-neutral-200);border-radius:var(--radius-full);height:8px;overflow:hidden;width:100%}.usage-progress-fill{background:linear-gradient(90deg,var(--color-primary-500),var(--color-primary-600));border-radius:var(--radius-full);height:100%;transition:width var(--transition-base)}.usage-progress-fill.warning{background:linear-gradient(90deg,var(--color-warning-500),var(--color-warning-600))}.usage-progress-fill.danger{background:linear-gradient(90deg,var(--color-error-500),var(--color-error-600))}.status-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2)}.status-badge.active{background-color:var(--color-success-100);color:var(--color-success-800)}.status-badge.inactive{background-color:var(--color-neutral-100);color:var(--color-neutral-600)}.permission-badge{align-items:center;background-color:var(--color-primary-100);border-radius:var(--radius-sm);color:var(--color-primary-800);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--spacing-1) var(--spacing-2)}.modal-backdrop{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:var(--z-modal)}.modal-content{animation:scaleIn .2s ease-out;background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);margin:var(--spacing-4);max-width:28rem;padding:var(--spacing-6);width:100%}.copy-button{overflow:hidden;position:relative}.copy-button:after{background:var(--color-success-600);border-radius:var(--radius-sm);color:#fff;content:"已复制!";font-size:var(--font-size-xs);left:50%;opacity:0;padding:var(--spacing-1) var(--spacing-2);pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:opacity var(--transition-fast)}.copy-button.copied:after{opacity:1}@media (max-width:768px){.api-key-actions{flex-direction:column;gap:var(--spacing-2)}.api-key-stats{gap:var(--spacing-3);grid-template-columns:1fr}.modal-content{margin:var(--spacing-2);padding:var(--spacing-4)}}@media (prefers-color-scheme:dark){.api-key-display{background:var(--color-neutral-800);border-color:var(--color-neutral-700);color:var(--color-neutral-200)}.usage-progress{background-color:var(--color-neutral-700)}}.slide-in-up{animation:slideInUp .3s ease-out}.fade-in-stagger>*{animation:fadeIn .4s ease-out}.fade-in-stagger>:first-child{animation-delay:.1s}.fade-in-stagger>:nth-child(2){animation-delay:.2s}.fade-in-stagger>:nth-child(3){animation-delay:.3s}.fade-in-stagger>:nth-child(4){animation-delay:.4s}.fade-in-stagger>:nth-child(5){animation-delay:.5s}.loading-skeleton{animation:loading-skeleton 1.5s infinite;background:linear-gradient(90deg,var(--color-neutral-200) 25%,var(--color-neutral-100) 50%,var(--color-neutral-200) 75%);background-size:200% 100%;border-radius:var(--radius-base)}@keyframes loading-skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}.hover-scale{transition:transform var(--transition-base)}.hover-scale:hover{transform:scale(1.02)}.hover-glow{transition:box-shadow var(--transition-base)}.hover-glow:hover{box-shadow:0 0 20px #4f46e54d}.invite-page{max-width:1200px}.page-title{color:#000;font-size:22px;font-weight:400;line-height:1.27;margin-bottom:16px}.invite-card{background:#fff;border-radius:2px;min-height:360px;padding:24px;position:relative}.card-title{color:#795213;font-size:16px;font-weight:500;margin-bottom:8px}.card-description{color:#000000a6;font-size:14px;line-height:1.5;margin-bottom:20px;max-width:600px}.error-message{background:#fff2f0;border:1px solid #ffccc7;border-radius:4px;color:#ff4d4f;font-size:14px;margin-bottom:16px;padding:8px 12px}.invite-row{align-items:center;display:flex;gap:12px;margin-bottom:24px}.invite-input{background:#fff;border:1px solid #d9d9d9;border-radius:4px;color:#000000d9;font-size:14px;height:32px;padding:4px 12px;width:300px}.invite-input:focus{border-color:#40a9ff;box-shadow:0 0 0 2px #1890ff33;outline:none}.btn.primary{background:#1890ff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:400;height:32px;padding:0 16px;transition:background .3s ease}.btn.primary:hover:not(:disabled){background:#40a9ff}.btn.primary:disabled{background:#f5f5f5;color:#00000040;cursor:not-allowed}.activity-title{color:#000;font-size:16px;font-weight:500;margin-bottom:16px}.rules{margin-top:0;max-width:700px}.rule-item{align-items:flex-start;display:flex;gap:12px;margin-bottom:20px}.rule-number{align-items:center;background:#1890ff;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:500;height:24px;justify-content:center;margin-top:2px;width:24px}.rule-content{flex:1 1}.rule-title{color:#000000d9;font-size:14px;font-weight:500;margin-bottom:4px}.rule-description{color:#000000a6;font-size:14px;line-height:1.5}.link{color:#1890ff;cursor:pointer}.link:hover{text-decoration:underline}.rule,.rule .icon.square,.rule .text,.sub{display:none}.decor-left{background:#9b7334;border-radius:2px;height:16px;right:310px;width:16px}.decor-left,.decor-right{bottom:24px;display:none;position:absolute}.decor-right{background:#0000000d;border-radius:4px;height:326px;right:24px;width:301px}.workflow-results-page{padding:24px}.workflow-results-page .page-header{align-items:center;display:flex;justify-content:space-between;margin:16px 0 20px}.workflow-results-page .page-title{color:#111827;font-size:20px;font-weight:600}.workflow-empty,.workflow-error,.workflow-loading{align-items:center;color:#6b7280;display:flex;gap:12px;justify-content:center;padding:40px 0}.workflow-error{color:#b91c1c}.workflow-table{border-collapse:collapse;width:100%}.workflow-table td,.workflow-table th{border-bottom:1px solid #e5e7eb;color:#1f2937;font-size:14px;padding:14px 16px;text-align:left;vertical-align:top}.workflow-table th{background:#f9fafb;color:#4b5563;font-weight:600}.workflow-text{color:#374151;max-width:360px;word-break:break-word}.workflow-link{color:#2563eb;text-decoration:none}.workflow-link:hover{text-decoration:underline}.workflow-pagination{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-top:20px}.pagination-button{background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;min-width:88px;padding:8px 16px}.pagination-button:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#6b7280;font-size:14px}.workflow-results-page .content-card{padding:24px}@media (max-width:768px){.workflow-table td,.workflow-table th{font-size:13px;padding:12px}.workflow-pagination{align-items:flex-start;flex-direction:column}.pagination-button{width:100%}}
/*# sourceMappingURL=main.098e86a2.css.map*/