*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Segoe UI,system-ui,-apple-system,Noto Sans TC,Microsoft JhengHei,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:Cascadia Code,Fira Code,JetBrains Mono,Consolas,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);font-size:var(--fs-xl);font-weight:var(--fw-normal);line-height:1.6;background:radial-gradient(circle at top left,rgba(0,180,216,.1),transparent 26%),radial-gradient(circle at 88% 8%,rgba(224,122,95,.08),transparent 24%),linear-gradient(180deg,#f8fafc,#f3f7fb 38%,#edf2f7);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .3s ease,color .3s ease}.dark body{background:radial-gradient(circle at top left,rgba(0,180,216,.14),transparent 26%),radial-gradient(circle at 88% 8%,rgba(224,122,95,.1),transparent 24%),linear-gradient(180deg,#06060a,#0a0a12 38%,#111118)}#root{min-height:100vh;display:flex}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:none;box-shadow:var(--shadow-glow-accent)}::-moz-selection{background:#00b4d84d;color:var(--foreground)}::selection{background:#00b4d84d;color:var(--foreground)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}::-webkit-scrollbar-corner{background:transparent}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.pipeline-flow{display:flex;align-items:center;gap:0;margin-bottom:var(--space-lg);padding:8px 12px;background:linear-gradient(180deg,#141a26e0,#0e131dcc);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius-lg);font-size:.72rem;overflow-x:auto;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.pipeline-step{display:flex;align-items:center;gap:5px;padding:3px 9px;border-radius:var(--radius-sm);color:var(--text-dim);white-space:nowrap;text-decoration:none;transition:all var(--transition)}.pipeline-step:hover{color:var(--foreground);background:var(--sidebar-accent)}.pipeline-step.current{background:linear-gradient(135deg,#57c7ff2e,#57c7ff14);color:#def5ff;font-weight:var(--fw-bold);border:1px solid rgba(87,199,255,.24);box-shadow:inset 0 1px #ffffff14}.pipeline-step.done{color:var(--done)}.pipeline-arrow{color:var(--text-muted);margin:0 2px;font-size:.7rem;flex-shrink:0}.pipeline-step .step-num{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:50%;background:var(--sidebar-accent);color:var(--text-dim);font-size:.65rem;font-weight:var(--fw-bold)}.pipeline-step.current .step-num{background:var(--accent);color:#fff}.pipeline-step.done .step-num{background:var(--done);color:#fff}.toast-container{position:fixed;bottom:var(--space-xl, 1.5rem);left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:var(--space-xs, .5rem);pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px var(--space-lg, 1.25rem);border-radius:var(--radius, 10px);box-shadow:var(--shadow-lg);font-size:var(--fs-sm);font-weight:var(--fw-medium);pointer-events:auto;animation:toastIn .3s ease;max-width:480px;min-width:280px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.toast.success,.toast-success{background:var(--success-muted);color:var(--success);border:1px solid rgba(45,212,191,.3)}.toast.error,.toast-error{background:var(--danger-muted);color:var(--danger);border:1px solid rgba(239,68,68,.3)}.toast.\!error{background:var(--danger-muted)!important;color:var(--danger)!important;border:1px solid rgba(239,68,68,.3)!important}.toast.info,.toast-info{background:var(--info-muted);color:var(--info);border:1px solid rgba(99,102,241,.3)}.toast-close{margin-left:auto;cursor:pointer;opacity:.6;font-size:var(--fs-md);background:none;border:none;color:inherit;padding:0;line-height:1;transition:opacity var(--transition-fast)}.toast-close:hover{opacity:1}.toast.exiting{animation:toastOut .2s ease forwards}@keyframes toastIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;background:var(--overlay);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.modal{background:linear-gradient(180deg,#161c28f5,#0e131df0);border:1px solid rgba(255,255,255,.08);border-radius:22px;box-shadow:var(--shadow-lg);max-width:560px;width:90vw;max-height:85vh;overflow-y:auto;animation:modalIn .25s ease;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) var(--space-lg) 0}.modal-header h2,.modal-header h3{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--foreground);margin:0}.modal-body{padding:var(--space-lg);font-size:var(--fs-sm);color:var(--text);line-height:1.6;overflow-y:auto;flex:1}.modal-actions,.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:18px var(--space-lg) var(--space-lg);border-top:1px solid rgba(148,163,184,.12)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.file-upload-zone{border:2px dashed rgba(148,163,184,.2);border-radius:var(--radius);padding:32px;text-align:center;cursor:pointer;transition:border-color var(--transition),background var(--transition)}.file-upload-zone:hover{border-color:#94a3b85c;background:#0f172a99}.file-upload-zone--active{border-color:var(--accent);background:var(--accent-muted)}.file-upload-zone--uploading{opacity:.6;pointer-events:none}.file-upload-item{display:flex;align-items:center;gap:12px;padding:8px;background:#0f172a99;border:1px solid rgba(148,163,184,.14);border-radius:var(--radius-sm)}.file-upload-preview{width:40px;height:40px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.file-upload-progress{height:.375rem;width:100%;overflow:hidden;border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(26 26 42 / var(--tw-bg-opacity, 1))}.file-upload-progress-bar{height:100%;border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(0 180 216 / var(--tw-bg-opacity, 1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px var(--space-lg);color:var(--text-dim);min-height:200px;background:linear-gradient(180deg,#0f172ae0,#0f172ad1);border:1px dashed rgba(148,163,184,.2);border-radius:22px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 18px 38px #0f172a0d}.empty-state .icon,.empty-state .empty-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.55}.empty-state h3,.empty-state .desc{font-size:1.15rem;color:var(--foreground);margin-bottom:8px;letter-spacing:-.02em}.empty-state p,.empty-state .desc{font-size:.9rem;color:var(--text-dim);margin-bottom:20px;max-width:400px;line-height:1.65}table{width:100%;border-collapse:collapse;font-size:var(--fs-sm);color:var(--text)}thead{position:sticky;top:0;z-index:2}th{text-align:left;padding:9px 12px;color:var(--text-dim);font-weight:var(--fw-semibold);border-bottom:1px solid rgba(148,163,184,.14);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;background:#0f172af5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}td{padding:9px 12px;border-bottom:1px solid rgba(148,163,184,.1);color:var(--text)}tbody tr:hover td{background:#0f172af5}tbody tr.selected td,.shot-table tbody tr.selected td{background:var(--accent-muted)}.page-header{margin-bottom:14px}.page-header h1{font-size:2.15rem;font-weight:var(--fw-bold);color:var(--foreground);letter-spacing:-.03em}.page-header p{font-size:var(--fs-sm);color:var(--text-dim);margin-top:3px;max-width:720px}.progress{width:100%;height:8px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}.progress-fill.success{background:var(--success)}.progress-fill.warning{background:var(--warning)}.progress-fill.danger{background:var(--danger)}.progress-fill.done{background:var(--done)}.progress-fill.gold{background:var(--gold)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-medium);line-height:1.5;white-space:nowrap;vertical-align:middle}.badge-warning,.badge-pending,.badge-queued{background:var(--warning-muted);color:var(--warning)}.badge-neutral,.badge-draft{background:#6c6c7e1f;color:var(--text-dim)}.badge-sm{padding:1px 6px;font-size:.65rem}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media (max-width: 768px){.grid-2,.grid-3,.grid-4,.grid-auto{grid-template-columns:1fr}}.card{background:var(--card-bg);border:1px solid rgba(148,163,184,.18);border-radius:18px;padding:var(--space-lg);margin-bottom:var(--space-md);transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);box-shadow:0 16px 36px #0f172a0f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.card:hover{border-color:#94a3b847;box-shadow:0 18px 42px #0f172a17}.card-selected,.card.selected{border-color:var(--accent);box-shadow:var(--shadow-glow-accent)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm);gap:var(--space-xs)}.card-title{font-size:var(--fs-md);font-weight:var(--fw-semibold);color:var(--foreground)}.card-body{font-size:var(--fs-sm);color:var(--text);line-height:1.6}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-size:var(--fs-sm);color:var(--text-dim);margin-bottom:6px;font-weight:var(--fw-medium)}.form-group .form-hint{font-size:var(--fs-xs);color:var(--text-muted);margin-top:4px}.form-group .form-error{font-size:var(--fs-xs);color:var(--danger);margin-top:4px}.form-row{display:flex;gap:var(--space-sm)}.form-row .form-group{flex:1}.form-group input,.form-group select,.form-group textarea,.form-input,input[type=text],input[type=number],input[type=search],input[type=url],input[type=email],input[type=password],textarea,select{width:100%;min-height:42px;padding:10px 12px;background:#0f172ae0;color:var(--text);border:1px solid rgba(148,163,184,.18);border-radius:14px;font-size:var(--fs-sm);font-family:var(--font);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);line-height:1.5;box-shadow:0 8px 18px #0f172a0a,inset 0 1px #ffffff0a;-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur))}.form-group input:hover,.form-group select:hover,.form-group textarea:hover,.form-input:hover,input[type=text]:hover,input[type=number]:hover,input[type=search]:hover,textarea:hover,select:hover{border-color:#94a3b847}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.form-input:focus,input[type=text]:focus,input[type=number]:focus,input[type=search]:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a,0 10px 22px #2563eb14;background:#0f172af5}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled,input:disabled,textarea:disabled,select:disabled{opacity:.72;cursor:not-allowed;color:var(--text-muted);background:#0f172aa3;border-color:#94a3b824;box-shadow:none}.form-group textarea{min-height:108px;padding-top:11px;padding-bottom:11px;resize:vertical;line-height:1.6;font-family:inherit}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;cursor:pointer}input::-moz-placeholder,textarea::-moz-placeholder{color:var(--text-dim)}input::placeholder,textarea::placeholder{color:var(--text-dim)}input[type=checkbox],input[type=radio]{accent-color:var(--accent);width:16px;height:16px;margin-right:8px;cursor:pointer}.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;font-size:.62rem;font-weight:700;margin-right:2px;flex-shrink:0;line-height:1}.badge-num{background:#2563eb1a;color:var(--accent);border:1px solid rgba(37,99,235,.16)}.badge-alpha{background:#0ea5e91a;color:var(--accent2);border:1px solid rgba(14,165,233,.16)}.sidebar-nav-link:hover:not(.active){background:#0f172af5!important;color:var(--foreground)!important;border-left-color:var(--accent)!important;border-color:#94a3b829!important;transform:translate(1px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:1px solid rgba(148,163,184,.18);border-radius:12px;background:#0f172ae0;color:var(--text);font-size:var(--fs-sm);font-weight:var(--fw-semibold);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition),background var(--transition);text-decoration:none;white-space:nowrap;line-height:1.4;box-shadow:0 8px 18px #0f172a0f;-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur))}.btn:hover{background:#1e293bf5;border-color:#3b82f638;color:var(--foreground);transform:translateY(-1px);box-shadow:0 12px 24px #0f172a14}.btn:active{transform:scale(.98)}.btn:focus-visible{outline:none;box-shadow:var(--shadow-glow-accent)}.btn:disabled,.btn[aria-disabled=true]{opacity:.58;cursor:not-allowed;pointer-events:none;transform:none;box-shadow:none;filter:saturate(.5);border-color:#94a3b82e}.btn:disabled:active,.btn.loading:active{transform:none}.btn-primary{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#eff6ff;border-color:#2563eb6b;font-weight:var(--fw-semibold);box-shadow:0 14px 30px #2563eb38}.btn-primary:hover{background:linear-gradient(135deg,#1d4ed8,#2563eb);border-color:#2563eb85}.btn-primary:active{background:linear-gradient(135deg,#1e40af,#1d4ed8)}.btn-secondary{background:#0f172aeb;color:var(--foreground);border-color:#94a3b82e}.btn-secondary:hover{background:#1e293bf5;border-color:#94a3b847}.btn-secondary:active{background:var(--card-hover)}.btn-danger{color:var(--danger);border-color:#ef44442e;background:#0f172aeb}.btn-danger:hover{background:var(--danger-muted);border-color:var(--danger-hover)}.btn-danger:active{background:#ef444440}.btn-danger:focus-visible{box-shadow:var(--shadow-glow-danger)}.btn-text{background:transparent;border:none;color:var(--accent);padding:4px 8px}.btn-text:hover{background:var(--accent-muted);text-decoration:underline}.btn-text:active{background:#2563eb33}.btn-icon{width:34px;height:34px;padding:0;background:#0f172ae0;border:1px solid rgba(148,163,184,.16);border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--text-dim);box-shadow:0 8px 18px #0f172a0d}.btn-icon:hover{background:#1e293bf5;border-color:#3b82f638;color:var(--foreground)}.btn-icon:active{color:var(--accent)}.btn-gold{color:var(--gold);border-color:#f59e0b2e;background:#0f172aeb}.btn-gold:hover{background:var(--gold-muted)}.btn-mt{margin-top:6px}.btn-ml{margin-left:4px}.btn-sm{padding:4px 10px;font-size:var(--fs-xs)}.btn-lg{padding:12px 24px;font-size:var(--fs-md)}.btn.loading{position:relative;color:transparent!important;opacity:.7;cursor:wait;pointer-events:none}.btn.loading:after{content:"";position:absolute;width:16px;height:16px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-spin .6s linear infinite}.btn-primary.loading{background:var(--accent-active);border-color:var(--accent-active)}.btn.success{background:var(--success, #43a047);color:#fff;border-color:var(--success, #43a047);pointer-events:none}.btn.error{background:var(--danger, #e53935);color:#fff;border-color:var(--danger, #e53935);pointer-events:none}.btn.\!error{background:var(--danger, #e53935)!important;color:#fff!important;border-color:var(--danger, #e53935)!important;pointer-events:none!important}.btn.pending{background:var(--warning, #ff9800);color:#000;border-color:var(--warning, #ff9800);pointer-events:none}.btn.hidden{display:none!important}.spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:ui-spin .6s linear infinite;vertical-align:middle;margin-right:4px}.series-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:0;transition:all .15s;position:relative;overflow:hidden;display:flex;flex-direction:column}.series-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.series-card.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent),0 4px 16px #00b4d833;background:#00b4d808}.series-card .card-cover{width:100%;height:150px;background:var(--sidebar-accent);display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative;overflow:hidden;cursor:pointer}.series-card .card-cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.series-card .card-cover .cover-upload-hint{position:absolute;bottom:0;left:0;right:0;background:#000000a6;color:var(--text-dim);font-size:var(--fs-xs);text-align:center;padding:5px;opacity:0;transition:opacity .15s}.series-card:hover .card-cover .cover-upload-hint{opacity:1}.series-card .card-body{padding:16px 18px 14px;flex:1;display:flex;flex-direction:column}.series-card .card-body .title-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.series-card .card-body .title-row h3{font-size:var(--fs-sm);color:var(--foreground);margin:0;cursor:pointer;padding:2px 4px;border-radius:4px;transition:background .15s;flex:1}.series-card .card-body .title-row h3:hover{background:#00b4d814}.series-card .card-body .desc{font-size:var(--fs-xs);color:var(--text-dim);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.2em}.series-card .card-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.series-card .card-tags .tag{font-size:var(--fs-xs);padding:2px 8px;border-radius:4px;background:#00b4d81a;color:var(--accent);border:1px solid rgba(0,180,216,.2)}.series-card .card-tags .tag.genre-tag{background:#2a9d8f1a;color:var(--done);border-color:#2a9d8f33}.series-card .progress-wrap{margin-top:auto}.series-card .progress-wrap .progress-text{font-size:var(--fs-xs);color:var(--text-dim);margin-bottom:4px;display:flex;justify-content:space-between}.series-card .progress-wrap .progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.series-card .progress-wrap .progress-bar .fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.series-card .card-actions{position:absolute;top:10px;right:10px;display:flex;gap:4px;opacity:0;transition:opacity .15s;z-index:2}.series-card:hover .card-actions{opacity:1}.series-card .card-actions button{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:#0000008c;color:var(--text-dim);cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .15s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:0}.series-card .card-actions button:hover{background:var(--card-bg);color:var(--foreground);border-color:var(--border-light)}.series-card .card-actions .btn-delete:hover{color:var(--danger);border-color:var(--danger)}.series-card .active-badge{position:absolute;top:10px;left:10px;font-size:var(--fs-xs);padding:3px 10px;border-radius:4px;background:#2a9d8f33;color:var(--done);border:1px solid rgba(42,157,143,.35);font-weight:600;z-index:2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.series-card .quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;border-top:1px solid var(--border);padding:10px 18px;margin-top:0}.series-card .quick-actions button{padding:6px 0;border-radius:6px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-dim);cursor:pointer;font-size:.75rem;transition:all .15s;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:3px}.series-card .quick-actions button:hover{background:var(--card-hover);color:var(--foreground);border-color:var(--border-light)}.series-card .quick-actions .qa-workshop:hover{color:var(--accent);border-color:var(--accent)}.series-card .quick-actions .qa-script:hover{color:#e9c46a;border-color:#e9c46a}.series-card .quick-actions .qa-shot:hover{color:#f4a261;border-color:#f4a261}.series-card .quick-actions .qa-generate:hover{color:#e76f51;border-color:#e76f51}.series-card.dashed{border-style:dashed;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:360px;color:var(--text-dim);font-size:var(--fs-sm);cursor:pointer}.series-card.dashed:hover{color:var(--accent);border-color:var(--accent);background:#00b4d808}.series-card.dashed .plus-icon{font-size:3rem;margin-bottom:12px}.cascade-impact{background:#e76f510f;border:1px solid rgba(231,111,81,.2);border-radius:var(--radius-sm);padding:14px;margin:14px 0;font-size:var(--fs-xs);color:var(--text-dim)}.cascade-impact .ci-title{color:var(--danger);font-weight:600;margin-bottom:8px}.cascade-impact .ci-list{list-style:none;padding:0;margin:0}.cascade-impact .ci-list li{padding:4px 0;display:flex;align-items:center;gap:8px}.cascade-impact .ci-list li .ci-icon{color:var(--danger)}.cascade-impact .ci-list li .ci-count{color:var(--foreground);font-weight:600}.grid-2{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.series-toolbar{display:flex;gap:12px;margin-bottom:20px;align-items:center}.series-toolbar input{flex:1;padding:10px 14px;background:var(--card-bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-xs)}.series-toolbar input:focus{outline:none;border-color:var(--accent)}.series-toolbar select{padding:10px 12px;background:var(--card-bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-xs);cursor:pointer}.settings-container{max-width:900px;margin:0 auto}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.settings-header h1{font-size:var(--fs-md);color:var(--foreground);margin:0}.save-status{font-size:var(--fs-xs);color:var(--success);opacity:0;transition:opacity .3s}.save-status.show{opacity:1}.save-status.error{color:var(--danger)}.save-status.\!error{color:var(--danger)!important}.save-status.dirty{color:var(--warning);opacity:1}.settings-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;overflow:hidden}.settings-section-header{display:flex;align-items:center;gap:10px;padding:16px 20px;background:var(--sidebar-accent);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .15s}.settings-section-header:hover{background:#00b4d814}.settings-section-header .section-icon{font-size:1.3rem}.settings-section-header h2{font-size:var(--fs-sm);color:var(--foreground);margin:0;flex:1;font-weight:var(--fw-semibold)}.settings-section-header .collapse-icon{color:var(--text-dim);transition:transform .2s;font-size:.8rem}.settings-section-header.collapsed .collapse-icon{transform:rotate(-90deg)}.settings-section-body{padding:20px}.settings-section-body.collapsed{display:none}.setting-row{display:grid;grid-template-columns:180px 1fr;gap:16px;align-items:start;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04)}.setting-row:last-child{border-bottom:none}.setting-label{font-size:var(--fs-xs);color:var(--text);font-weight:var(--fw-medium);padding-top:8px}.setting-label .required{color:var(--danger);margin-left:2px}.setting-control{display:flex;flex-direction:column;gap:6px}.setting-control input[type=text],.setting-control input[type=password],.setting-control input[type=number],.setting-control input[type=url],.setting-control select{padding:8px 12px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-xs);font-family:Cascadia Code,Fira Code,Consolas,monospace;width:100%;transition:border-color .15s,box-shadow .15s}.setting-control input:focus,.setting-control select:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-glow-accent)}.setting-control input[type=password]{font-family:sans-serif}.setting-hint{font-size:.75rem;color:var(--text-dim)}.setting-hint a{color:var(--accent)}.api-key-row{display:flex;gap:8px;align-items:center}.api-key-row input{flex:1}.btn-test{padding:8px 14px;background:var(--accent-muted);color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;white-space:nowrap;transition:all .15s;font-weight:var(--fw-medium)}.btn-test:hover{background:var(--accent);color:var(--bg-card)}.btn-test:disabled{opacity:.5;cursor:not-allowed}.btn-test .spinner{display:inline-block;width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:ui-spin .6s linear infinite;margin-right:4px}.test-result{font-size:.75rem;padding:4px 8px;border-radius:var(--radius-sm);margin-top:4px}.test-result.success{color:var(--success);background:#00c8531a}.test-result.error{color:var(--danger);background:#ef44441a}.test-result.\!error{color:var(--danger)!important;background:#ef44441a!important}.toggle-row{display:flex;align-items:center;justify-content:space-between}.toggle-switch{position:relative;width:44px;height:24px;background:var(--border);border-radius:12px;cursor:pointer;transition:background .2s;flex-shrink:0}.toggle-switch.active{background:var(--accent)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s}.toggle-switch.active:after{transform:translate(20px)}.settings-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.btn-eye{padding:8px 10px;background:var(--surface);color:var(--text-dim);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-size:.85rem;line-height:1}.btn-eye:hover{background:var(--card-hover);color:var(--foreground);border-color:var(--border-light)}.stats-bar{margin-top:1rem;display:flex;gap:1rem;border-radius:14px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(30 30 46 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(17 17 24 / var(--tw-bg-opacity, 1));padding:.75rem 1rem}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-item .num{font-size:2.5rem;line-height:2.75rem;font-weight:700;--tw-text-opacity: 1;color:rgb(0 180 216 / var(--tw-text-opacity, 1))}.stat-item .label{margin-top:.25rem;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(108 108 126 / var(--tw-text-opacity, 1))}.char-layout{display:flex;gap:16px;height:calc(100vh - 180px);min-height:500px}.char-list-panel{width:360px;min-width:300px;flex-shrink:0;display:flex;flex-direction:column}.char-detail-panel{flex:1;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow-y:auto;padding:20px;min-width:0}.detail-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-dim);font-size:var(--fs-sm)}.char-search{margin-bottom:12px}.char-search input{width:100%;padding:8px 12px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--foreground);font-size:var(--fs-sm);box-sizing:border-box}.char-search input:focus{outline:none;border-color:var(--accent)}.char-search input::-moz-placeholder{color:var(--text-dim)}.char-search input::placeholder{color:var(--text-dim)}.char-grid-scroll{flex:1;overflow-y:auto;padding-right:4px}.char-grid-scroll::-webkit-scrollbar{width:4px}.char-grid-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.char-card-v2{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:8px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:10px}.char-card-v2:hover{border-color:var(--accent)}.char-card-v2.selected{border-color:var(--accent);background:#00b4d80f;box-shadow:0 0 0 1px var(--accent)}.char-card-v2 .cc-avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--sidebar-accent),#1a1a4e);display:flex;align-items:center;justify-content:center;font-size:1.2rem;background-size:cover;background-position:center}.char-card-v2 .cc-info{flex:1;min-width:0}.char-card-v2 .cc-name{font-size:var(--fs-sm);font-weight:600;color:var(--foreground);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.char-card-v2 .cc-meta{font-size:var(--fs-xs);color:var(--text-dim);margin-top:1px}.char-card-v2 .cc-badges{display:flex;gap:4px;flex-shrink:0}.char-card-v2 .cc-series-count{font-size:.6rem;padding:1px 5px;background:#00b4d81a;color:var(--accent);border-radius:8px;white-space:nowrap}.char-card-add{border-style:dashed;display:flex;align-items:center;justify-content:center;padding:16px;color:var(--text-dim);cursor:pointer;min-height:66px}.detail-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.detail-header .dh-avatar{width:64px;height:64px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--sidebar-accent),#1a1a4e);display:flex;align-items:center;justify-content:center;font-size:2rem;background-size:cover;background-position:center}.detail-header .dh-info{flex:1}.detail-header .dh-name{font-size:var(--fs-lg);font-weight:700;color:var(--foreground)}.detail-header .dh-desc{font-size:var(--fs-sm);color:var(--text-dim);margin-top:4px;line-height:1.4}.detail-header .dh-actions{display:flex;gap:8px;flex-shrink:0}.detail-section{margin-bottom:20px}.detail-section h4{font-size:var(--fs-sm);color:var(--foreground);font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:6px}.six-face-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.six-face-item{aspect-ratio:3/4;border-radius:var(--radius-sm);border:1px solid var(--border);position:relative;overflow:hidden;cursor:pointer;background:var(--sidebar-accent);transition:border-color .15s}.six-face-item:hover{border-color:var(--accent)}.six-face-item.has-image{border-color:var(--border)}.six-face-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.six-face-item .face-label{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;background:#0009;font-size:.6rem;color:#ffffffb3;text-align:center}.six-face-item .face-upload-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-dim);font-size:.65rem;text-align:center}.six-face-item .face-empty-icon{font-size:1.2rem;opacity:.3;display:block;margin-bottom:4px}.six-face-item .row-label-full{position:absolute;top:4px;left:4px;font-size:.55rem;padding:1px 4px;background:#00000080;color:#ffffff80;border-radius:2px}.six-face-item .row-label-head{position:absolute;top:4px;left:4px;font-size:.55rem;padding:1px 4px;background:#f4a26180;color:#000;border-radius:2px}.outfit-list{display:flex;gap:10px;flex-wrap:wrap}.outfit-item{width:100px;text-align:center}.outfit-item .outfit-thumb{width:100px;height:100px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--sidebar-accent);display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer;transition:border-color .15s;position:relative}.outfit-item .outfit-thumb:hover{border-color:var(--accent)}.outfit-item .outfit-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.outfit-item .outfit-thumb .outfit-empty{color:var(--text-dim);font-size:.6rem;text-align:center;padding:4px}.outfit-item .outfit-name{font-size:var(--fs-xs);color:var(--text-dim);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.outfit-item .outfit-delete{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:#ef4444cc;color:#fff;border:none;font-size:.5rem;cursor:pointer;display:none;line-height:16px;text-align:center}.outfit-item .outfit-thumb:hover .outfit-delete{display:block}.outfit-add{width:100px;height:100px;border:1px dashed var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-dim);font-size:1.5rem;transition:all .15s}.outfit-add:hover{border-color:var(--accent);color:var(--accent);background:#00b4d80d}.linked-tags{display:flex;gap:6px;flex-wrap:wrap}.linked-tag{font-size:var(--fs-xs);padding:3px 10px;border-radius:12px;background:#6366f11f;color:var(--accent);border:1px solid rgba(99,102,241,.2)}.linked-tag.none{background:transparent;color:var(--text-dim);border:1px dashed var(--border)}.created-from{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-xs);padding:2px 8px;border-radius:10px}.created-from.manual{background:#00b4d81a;color:var(--accent)}.created-from.auto{background:#f4a2611a;color:var(--gold)}.ref-warning{padding:10px 14px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);margin-bottom:12px}.ref-warning .ref-warn-title{color:var(--danger);font-weight:600;font-size:var(--fs-sm);margin-bottom:4px}.ref-warning .ref-warn-list{font-size:var(--fs-xs);color:var(--text-dim);font-family:var(--font-mono);max-height:80px;overflow-y:auto}.pending-tip{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:var(--fs-xs);color:var(--text-dim)}.pending-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);border:1px solid var(--border);background:#6c6c7e1f;color:var(--foreground);cursor:pointer;transition:all .15s}.pending-chip:hover{border-color:var(--accent);background:#00b4d81a}@media (max-width: 900px){.char-layout{flex-direction:column}.char-list-panel{width:100%;max-height:40vh}.char-detail-panel{flex:1}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.bottom-0{bottom:0}.left-0{left:0}.left-1\/2{left:50%}.right-0{right:0}.right-2{right:.5rem}.top-0{top:0}.top-2{top:.5rem}.top-full{top:100%}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-14{margin-bottom:3.5rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1 / 1}.h-12{height:3rem}.h-16{height:4rem}.h-24{height:6rem}.h-44{height:11rem}.h-48{height:12rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-\[600px\]{height:600px}.max-h-44{max-height:11rem}.max-h-\[180px\]{max-height:180px}.min-h-\[220px\]{min-height:220px}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-24{width:6rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-\[800px\]{width:800px}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[200px\]{min-width:200px}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize{resize:both}.list-none{list-style-type:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:10px}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:14px}.rounded-md{border-radius:.375rem}.rounded-sm{border-radius:6px}.rounded-xl{border-radius:20px}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-l-\[3px\]{border-left-width:3px}.border-t{border-top-width:1px}.border-accent{--tw-border-opacity: 1;border-color:rgb(0 180 216 / var(--tw-border-opacity, 1))}.border-accent\/20{border-color:#00b4d833}.border-black\/10{border-color:#0000001a}.border-black\/5{border-color:#0000000d}.border-blue-700\/50{border-color:#1d4ed880}.border-neutral-7{--tw-border-opacity: 1;border-color:rgb(30 30 46 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-white\/10{border-color:#ffffff1a}.border-white\/5{border-color:#ffffff0d}.bg-\[var\(--neutral-0\)\]{background-color:var(--neutral-0)}.bg-accent{--tw-bg-opacity: 1;background-color:rgb(0 180 216 / var(--tw-bg-opacity, 1))}.bg-accent-muted{background-color:#00b4d81f}.bg-accent\/10{background-color:#00b4d81a}.bg-black\/35{background-color:#00000059}.bg-blue-900\/40{background-color:#1e3a8a66}.bg-cyan-500\/10{background-color:#06b6d41a}.bg-indigo-500\/10{background-color:#6366f11a}.bg-neutral-0{--tw-bg-opacity: 1;background-color:rgb(6 6 10 / var(--tw-bg-opacity, 1))}.bg-neutral-0\/80{background-color:#06060acc}.bg-neutral-1\/50{background-color:#0a0a0f80}.bg-neutral-2{--tw-bg-opacity: 1;background-color:rgb(14 14 22 / var(--tw-bg-opacity, 1))}.bg-neutral-2\/50{background-color:#0e0e1680}.bg-neutral-3\/60{background-color:#11111899}.bg-neutral-4{--tw-bg-opacity: 1;background-color:rgb(22 22 34 / var(--tw-bg-opacity, 1))}.bg-neutral-5{--tw-bg-opacity: 1;background-color:rgb(24 24 37 / var(--tw-bg-opacity, 1))}.bg-teal-500\/10{background-color:#14b8a61a}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/5{background-color:#ffffff0d}.bg-white\/80{background-color:#fffc}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-\[\#00b4d8\]\/20{--tw-gradient-from: rgb(0 180 216 / .2) var(--tw-gradient-from-position);--tw-gradient-to: rgb(0 180 216 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-\[\#6366f1\]\/20{--tw-gradient-from: rgb(99 102 241 / .2) var(--tw-gradient-from-position);--tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-\[\#e07a5f\]\/20{--tw-gradient-from: rgb(224 122 95 / .2) var(--tw-gradient-from-position);--tw-gradient-to: rgb(224 122 95 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-\[\#f4a261\]\/20{--tw-gradient-from: rgb(244 162 97 / .2) var(--tw-gradient-from-position);--tw-gradient-to: rgb(244 162 97 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-accent{--tw-gradient-from: #00b4d8 var(--tw-gradient-from-position);--tw-gradient-to: rgb(0 180 216 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-\[\#4895ef\]{--tw-gradient-to: rgb(72 149 239 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #4895ef var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-\[\#00b4d8\]\/5{--tw-gradient-to: rgb(0 180 216 / .05) var(--tw-gradient-to-position)}.to-\[\#6366f1\]\/5{--tw-gradient-to: rgb(99 102 241 / .05) var(--tw-gradient-to-position)}.to-\[\#7209b7\]{--tw-gradient-to: #7209b7 var(--tw-gradient-to-position)}.to-\[\#e07a5f\]\/5{--tw-gradient-to: rgb(224 122 95 / .05) var(--tw-gradient-to-position)}.to-\[\#f4a261\]\/5{--tw-gradient-to: rgb(244 162 97 / .05) var(--tw-gradient-to-position)}.bg-cover{background-size:cover}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.bg-center{background-position:center}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-20{padding-bottom:5rem}.pt-32{padding-top:8rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:Cascadia Code,Fira Code,JetBrains Mono,Consolas,monospace}.font-sans{font-family:Segoe UI,system-ui,-apple-system,Noto Sans TC,Microsoft JhengHei,sans-serif}.text-2xl{font-size:2.5rem;line-height:2.75rem}.text-3xl{font-size:3rem;line-height:1}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-base{font-size:1.125rem;line-height:1.75rem}.text-lg{font-size:2rem;line-height:2.25rem}.text-sm{font-size:1rem;line-height:1.5rem}.text-xs{font-size:.875rem;line-height:1.25rem}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.text-\[var\(--neutral-10\)\]{color:var(--neutral-10)}.text-\[var\(--neutral-11\)\]{color:var(--neutral-11)}.text-\[var\(--neutral-8\)\]{color:var(--neutral-8)}.text-\[var\(--neutral-9\)\]{color:var(--neutral-9)}.text-accent{--tw-text-opacity: 1;color:rgb(0 180 216 / var(--tw-text-opacity, 1))}.text-black{--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.text-blue-300{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity, 1))}.text-cyan-400{--tw-text-opacity: 1;color:rgb(34 211 238 / var(--tw-text-opacity, 1))}.text-danger{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-indigo-400{--tw-text-opacity: 1;color:rgb(129 140 248 / var(--tw-text-opacity, 1))}.text-neutral-10{--tw-text-opacity: 1;color:rgb(200 200 212 / var(--tw-text-opacity, 1))}.text-neutral-11{--tw-text-opacity: 1;color:rgb(228 228 236 / var(--tw-text-opacity, 1))}.text-neutral-8{--tw-text-opacity: 1;color:rgb(42 42 62 / var(--tw-text-opacity, 1))}.text-neutral-9{--tw-text-opacity: 1;color:rgb(108 108 126 / var(--tw-text-opacity, 1))}.text-neutral-9\/70{color:#6c6c7eb3}.text-teal-400{--tw-text-opacity: 1;color:rgb(45 212 191 / var(--tw-text-opacity, 1))}.text-transparent{color:transparent}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.no-underline{text-decoration-line:none}.accent-\[var\(--accent\)\]{accent-color:var(--accent)}.opacity-0{opacity:0}.opacity-20{opacity:.2}.opacity-50{opacity:.5}.shadow-lg{--tw-shadow: 0 8px 40px rgba(0,0,0,.4);--tw-shadow-colored: 0 8px 40px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-accent\/25{--tw-shadow-color: rgb(0 180 216 / .25);--tw-shadow: var(--tw-shadow-colored)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-xl{--tw-backdrop-blur: blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}@keyframes fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes btn-spin{to{transform:rotate(360deg)}}@keyframes ui-spin{to{transform:rotate(360deg)}}.animate-fade-in-up{animation:fade-in-up .25s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-center{display:flex;align-items:center;justify-content:center}:root{--neutral-0: #f8fafc;--neutral-1: #f1f5f9;--neutral-2: #eef2f7;--neutral-3: #ffffff;--neutral-4: #f8fbff;--neutral-5: #eef4fb;--neutral-6: #e2e8f0;--neutral-7: #cbd5e1;--neutral-8: #94a3b8;--neutral-9: #64748b;--neutral-10: #334155;--neutral-11: #0f172a;--bg: var(--neutral-0);--sidebar-bg: rgba(255,255,255,.92);--card-bg: rgba(255,255,255,.86);--surface: var(--neutral-3);--sidebar-accent: #f8fafc;--card-hover: #f8fbff;--border: rgba(148,163,184,.24);--border-light: rgba(148,163,184,.36);--text-dim: #475569;--text: var(--neutral-10);--foreground: var(--neutral-11);--text-muted: #64748b;--text-secondary: #475569;--accent: #00b4d8;--accent-hover: #00c8f0;--accent-active: #0096b4;--accent-muted: rgba(0,180,216,.12);--accent-glow: rgba(0,180,216,.25);--accent2: #e07a5f;--primary-foreground: #ffffff;--gold: #f4a261;--gold-hover: #f6b87d;--gold-muted: rgba(244,162,97,.12);--success: #2dd4bf;--success-hover: #5ee0d1;--success-muted: rgba(45,212,191,.15);--danger: #ef4444;--danger-hover: #f87171;--danger-muted: rgba(239,68,68,.15);--failed: var(--danger);--warning: #f59e0b;--warning-hover: #fbbf24;--warning-muted: rgba(245,158,11,.15);--info: #6366f1;--info-hover: #818cf8;--info-muted: rgba(99,102,241,.15);--done: #2a9d8f;--running: #00b4d8;--pending: #e9c46a;--font: "Segoe UI", system-ui, -apple-system, "Noto Sans TC", "Microsoft JhengHei", sans-serif;--font-mono: "Cascadia Code", "Fira Code", "JetBrains Mono", "Consolas", monospace;--fs-xs: .875rem;--fs-sm: 1rem;--fs-base: 1.125rem;--fs-md: 1.5rem;--fs-lg: 2rem;--fs-xl: 2.125rem;--fs-2xl: 2.5rem;--fs-3xl: 3rem;--fw-normal: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--space-2xs: .25rem;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.25rem;--space-xl: 1.5rem;--space-2xl: 2rem;--space-3xl: 2.5rem;--sidebar-width: 288px;--global-topbar-height: 64px;--max-width: 1400px;--content-max-width: 1200px;--radius-xs: 4px;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--glass-blur: 18px;--shadow-xs: 0 6px 14px rgba(0,0,0,.16);--shadow-sm: 0 10px 24px rgba(0,0,0,.2);--shadow: 0 18px 44px rgba(0,0,0,.26);--shadow-lg: 0 26px 64px rgba(0,0,0,.34);--shadow-xl: 0 40px 96px rgba(0,0,0,.42);--shadow-glow-accent: 0 0 0 1px rgba(0,180,216,.48), 0 0 0 4px rgba(0,180,216,.12);--shadow-glow-danger: 0 0 0 1px rgba(239,68,68,.42), 0 0 0 4px rgba(239,68,68,.12);--overlay: rgba(4,6,12,.76);--transition-fast: .1s ease;--transition: .15s ease;--transition-slow: .3s ease}.dark{--neutral-0: #06060a;--neutral-1: #0a0a0f;--neutral-2: #0e0e16;--neutral-3: #111118;--neutral-4: #161622;--neutral-5: #181825;--neutral-6: #1a1a2a;--neutral-7: #1e1e2e;--neutral-8: #2a2a3e;--neutral-9: #6c6c7e;--neutral-10: #c8c8d4;--neutral-11: #e4e4ec;--bg: #06060a;--sidebar-bg: rgba(17,17,24,.94);--card-bg: rgba(17,17,24,.88);--surface: #111118;--sidebar-accent: rgba(26,26,42,.92);--card-hover: rgba(26,26,42,.96);--border: rgba(108,108,126,.2);--border-light: rgba(108,108,126,.28);--text-dim: #6c6c7e;--text: #c8c8d4;--foreground: #e4e4ec;--text-muted: #6c6c7e;--text-secondary: #6c6c7e;--accent-muted: rgba(0,180,216,.18);--gold-muted: rgba(244,162,97,.16);--success-muted: rgba(45,212,191,.18);--danger-muted: rgba(239,68,68,.18);--warning-muted: rgba(245,158,11,.18);--info-muted: rgba(99,102,241,.18);--shadow-xs: 0 8px 18px rgba(0,0,0,.34);--shadow-sm: 0 12px 28px rgba(0,0,0,.38);--shadow: 0 18px 44px rgba(0,0,0,.44);--shadow-lg: 0 26px 64px rgba(0,0,0,.52);--shadow-xl: 0 40px 96px rgba(0,0,0,.6)}.ref-masonry{-moz-columns:4;columns:4;-moz-column-gap:12px;column-gap:12px}@media (max-width: 1400px){.ref-masonry{-moz-columns:3;columns:3}}@media (max-width: 1000px){.ref-masonry{-moz-columns:2;columns:2}}@media (max-width: 640px){.ref-masonry{-moz-columns:1;columns:1}}.ref-item{-moz-column-break-inside:avoid;break-inside:avoid;margin-bottom:12px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .2s;cursor:pointer;display:inline-block;width:100%;position:relative}.ref-item:hover{border-color:var(--accent)}.ref-item.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.ref-img{width:100%;min-height:120px;background:linear-gradient(135deg,var(--sidebar-accent),#1a1a4e);display:flex;align-items:center;justify-content:center;color:var(--text-muted, var(--text-dim));font-size:var(--fs-xs);position:relative;overflow:hidden}.ref-img.has-image{background-size:cover;background-position:center}.ref-img .upload-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;opacity:0;transition:opacity .15s;color:#fff;font-size:var(--fs-xs)}.ref-item:hover .ref-img .upload-hint{opacity:1}.ref-body{padding:10px 12px}.ref-body .ref-title{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--foreground)}.ref-body .ref-source{font-size:.75rem;color:var(--text-dim);margin-top:2px}.category-filter-bar{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.category-pill{padding:6px 16px;border-radius:20px;border:1px solid var(--border);font-size:var(--fs-xs);color:var(--text-dim);cursor:pointer;transition:all .15s;background:transparent;white-space:nowrap;display:flex;align-items:center;gap:4px}.category-pill:hover{border-color:var(--border-light);color:var(--foreground)}.category-pill.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:var(--fw-semibold)}.category-pill .cat-count{font-size:.7rem;opacity:.7}.ref-category-badge{position:absolute;top:6px;left:6px;z-index:2;padding:2px 8px;border-radius:4px;font-size:.65rem;font-weight:var(--fw-semibold);background:#00b4d826;color:var(--accent);border:1px solid rgba(0,180,216,.3)}.ref-item .ref-actions{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:opacity .15s;z-index:2}.ref-item:hover .ref-actions{opacity:1}.ref-actions button{width:24px;height:24px;border-radius:4px;border:1px solid var(--border);background:#0009;color:var(--text-dim);cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0}.ref-actions button:hover{color:var(--foreground);border-color:var(--border-light)}.ref-actions .btn-del:hover{color:var(--danger);border-color:var(--danger)}.ref-bind-btn{display:block;width:100%;margin-top:8px;padding:4px 0;border-radius:4px;border:1px dashed var(--border);background:transparent;color:var(--text-dim);font-size:.75rem;cursor:pointer;transition:all .15s;text-align:center}.ref-bind-btn:hover{border-color:var(--accent);color:var(--accent);background:#00b4d80d}.ref-bind-btn.bound{border-style:solid;border-color:var(--accent);color:var(--accent);background:#00b4d814}.ref-item.add-tile{border-style:dashed}.ref-item.add-tile .ref-img{cursor:pointer;flex-direction:column;gap:4px}.ref-item.add-tile:hover{border-color:var(--accent)}.ref-item .ref-checkbox{position:absolute;bottom:6px;right:6px;z-index:2;width:18px;height:18px;cursor:pointer;accent-color:var(--accent)}.ref-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000e6;display:flex;align-items:center;justify-content:center;cursor:pointer}.ref-lightbox img{max-width:90vw;max-height:85vh;border-radius:var(--radius);box-shadow:0 0 40px #00000080}.ref-lightbox-close{position:absolute;top:20px;right:30px;font-size:2rem;color:#fff;cursor:pointer;z-index:1;background:none;border:none}.knowledge-page{height:100%;display:flex;flex-direction:column}.knowledge-page .page-header{margin-bottom:12px}.knowledge-page .page-header h1{font-size:var(--fs-md);color:var(--foreground);margin:0}.knowledge-page .page-header p{font-size:var(--fs-xs);color:var(--text-dim);margin:2px 0 0}.kl-stats-bar{display:flex;align-items:center;gap:20px;padding:12px 20px;margin-bottom:16px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--fs-xs);flex-wrap:wrap}.kl-stat-item{color:var(--text-dim)}.kl-stat-item strong{color:var(--foreground);margin:0 2px}.kl-scope-label{color:var(--text-muted, var(--text-dim));font-size:.65rem;margin-right:2px}.kl-scope-tags{display:flex;gap:4px;flex-wrap:wrap;align-items:center;margin-left:8px}.kl-scope-tag{font-size:.65rem;padding:2px 7px;border-radius:10px;background:#00b4d814;color:var(--accent);border:1px solid rgba(0,180,216,.15);white-space:nowrap}.kl-scope-tag.inactive{background:#6c6c7e0f;color:var(--text-muted, var(--text-dim));border-color:transparent}.kl-layout{display:flex;gap:0;height:calc(100vh - 230px);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--card-bg)}.kl-panel-header{padding:12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:6px}.kl-panel-title{font-size:var(--fs-xs);color:var(--foreground);font-weight:600;white-space:nowrap}.kl-files-panel{width:220px;min-width:180px;border-right:1px solid var(--border);display:flex;flex-direction:column;background:#0000001a}.kl-file-list{flex:1;overflow-y:auto;padding:4px 6px}.kl-file-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:6px;cursor:default;font-size:var(--fs-xs);color:var(--text-dim);margin-bottom:2px;transition:all .12s;gap:4px}.kl-file-item:hover{background:var(--card-hover);color:var(--text)}.kl-file-icon{font-size:.8rem;flex-shrink:0}.kl-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.kl-file-del{opacity:0;background:none;border:none;color:var(--danger);cursor:pointer;font-size:.7rem;padding:2px 4px;border-radius:3px;transition:opacity .12s;flex-shrink:0}.kl-file-item:hover .kl-file-del{opacity:.6}.kl-file-del:hover{opacity:1!important;background:var(--danger-muted)}.kl-file-empty{text-align:center;padding:24px 12px;color:var(--text-dim);font-size:var(--fs-xs);line-height:1.5}.kl-file-empty-icon{font-size:1.6rem;margin-bottom:6px;opacity:.5}.kl-chat-panel{flex:1;display:flex;flex-direction:column;min-width:0}.kl-chat-ribbon{display:flex;align-items:center;gap:6px;padding:6px 12px;border-bottom:1px solid var(--border);background:#0000000f;overflow-x:auto;flex-shrink:0}.kl-hist-btn{padding:5px 12px;border-radius:14px;font-size:var(--fs-xs);color:var(--text-dim);cursor:pointer;white-space:nowrap;background:transparent;border:1px solid transparent;transition:all .12s;max-width:140px;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;font-family:inherit}.kl-hist-btn:hover{color:var(--text);background:var(--card-hover)}.kl-hist-btn.active{color:var(--accent);background:var(--accent-muted);border-color:#00b4d833}.kl-hist-btn-new{color:var(--accent);font-weight:600;border:1px dashed rgba(0,180,216,.3);flex-shrink:0}.kl-hist-btn-new:hover{background:var(--accent-muted)}.kl-messages-area{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:4px}.kl-msg-row{display:flex;margin-bottom:8px}.kl-msg-row.user{justify-content:flex-end}.kl-msg-row.assistant{justify-content:flex-start}.kl-msg-bubble{max-width:75%;padding:10px 16px;border-radius:12px;font-size:var(--fs-xs);line-height:1.65;position:relative}.kl-msg-row.user .kl-msg-bubble{background:#00b4d826;color:var(--foreground);border-bottom-right-radius:4px}.kl-msg-row.assistant .kl-msg-bubble{background:var(--bg);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}.kl-msg-meta{font-size:.7rem;color:var(--text-dim);margin-bottom:4px;display:flex;gap:8px;align-items:center}.kl-msg-row.user .kl-msg-meta{justify-content:flex-end}.kl-msg-content{word-break:break-word}.kl-msg-sources{margin-top:10px;padding-top:8px;border-top:1px solid var(--border);font-size:var(--fs-xs)}.kl-src-label{color:var(--text-dim);font-weight:600;margin-bottom:4px}.kl-src-item{display:block;padding:4px 8px;margin:2px 0;background:#00b4d80d;border-radius:4px;font-size:var(--fs-xs);color:var(--accent);text-decoration:none;transition:background .12s}.kl-src-item:hover{background:#00b4d81f}.kl-src-excerpt{color:var(--text-dim);font-size:.75rem;margin-top:2px;font-style:italic;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.kl-typing-cursor:after{content:"▌";animation:kl-blink .8s infinite;color:var(--accent)}@keyframes kl-blink{0%,50%{opacity:1}51%,to{opacity:0}}.kl-loading-dots{display:flex;gap:4px;padding:8px 0}.kl-loading-dots span{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:kl-bounce 1.2s infinite}.kl-loading-dots span:nth-child(2){animation-delay:.2s}.kl-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes kl-bounce{0%,80%,to{transform:scale(.6);opacity:.3}40%{transform:scale(1);opacity:1}}.md-content h1,.md-content h2,.md-content h3{color:var(--foreground);margin:12px 0 6px;font-weight:600}.md-content h1{font-size:1.25rem}.md-content h2{font-size:1.1rem}.md-content h3{font-size:var(--fs-xs)}.md-content p{margin:6px 0}.md-content ul,.md-content ol{margin:6px 0;padding-left:20px}.md-content li{margin:2px 0}.md-content strong{color:var(--foreground)}.md-content code{background:#ffffff0f;padding:2px 6px;border-radius:4px;font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:.85em}.md-content pre{background:var(--neutral-5);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;overflow-x:auto;margin:8px 0;font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:.85em;line-height:1.5}.md-content pre code{background:none;padding:0}.kl-input-bar{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);align-items:flex-end}.kl-input-bar textarea{flex:1;padding:10px 14px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-xs);font-family:inherit;resize:none;min-height:44px;max-height:150px;outline:none;transition:border-color .15s}.kl-input-bar textarea:focus{border-color:var(--accent)}.kl-input-bar textarea:disabled{opacity:.5;cursor:not-allowed}.kl-suggest-panel{width:280px;min-width:240px;border-left:1px solid var(--border);display:flex;flex-direction:column;background:#0000000f}.kl-suggest-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.kl-suggest-tab{flex:1;padding:8px 4px;text-align:center;font-size:var(--fs-xs);color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent;transition:all .12s;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit}.kl-suggest-tab:hover{color:var(--text)}.kl-suggest-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.kl-suggest-content{flex:1;overflow-y:auto;padding:14px;font-size:var(--fs-xs);line-height:1.65;color:var(--text-dim)}.kl-suggest-empty{text-align:center;padding:32px 8px;color:var(--text-dim)}.kl-suggest-item{margin-bottom:14px}.kl-suggest-item h4{color:var(--foreground);font-size:var(--fs-xs);margin-bottom:4px}.kl-suggest-loading{text-align:center;padding:20px;color:var(--text-dim)}.kl-suggest-footer{padding:8px 12px;border-top:1px solid var(--border);flex-shrink:0}.kl-suggest-footer button{width:100%;font-size:.75rem}.kl-empty-state{text-align:center;padding:80px 20px;color:var(--text-dim)}.kl-empty-icon{font-size:3.5rem;margin-bottom:16px}.kl-empty-state h3{color:var(--foreground);font-size:var(--fs-md);margin-bottom:8px}.kl-empty-state p{font-size:var(--fs-xs);margin-bottom:24px;max-width:460px;margin-left:auto;margin-right:auto;line-height:1.6}.kl-suggestion-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.kl-suggestion-chip{padding:8px 16px;background:var(--card-bg);border:1px solid var(--border);border-radius:20px;font-size:var(--fs-xs);color:var(--text);cursor:pointer;transition:all .12s;white-space:nowrap}.kl-suggestion-chip:hover{border-color:var(--accent);color:var(--accent);background:#00b4d80f}.kl-manage-file-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid rgba(30,30,46,.5);font-size:var(--fs-xs)}.kl-manage-file-name{color:var(--foreground);flex:1}.kl-manage-file-meta{color:var(--text-dim);font-size:var(--fs-xs);margin-right:12px}.kl-manage-file-del{color:var(--danger);cursor:pointer;background:none;border:none;font-size:var(--fs-xs);padding:4px 8px;border-radius:4px}.kl-manage-file-del:hover{background:#ef44441a}@media (max-width: 1024px){.kl-layout{flex-wrap:wrap;height:auto}.kl-files-panel{width:100%;min-width:unset;max-height:160px;border-right:none;border-bottom:1px solid var(--border)}.kl-chat-panel{min-height:400px}.kl-suggest-panel{width:100%;min-width:unset;max-height:240px;border-left:none;border-top:1px solid var(--border)}}@media (max-width: 768px){.kl-layout{flex-direction:column;height:auto}.kl-files-panel{width:100%;min-width:unset;max-height:120px;border-right:none;border-bottom:1px solid var(--border)}.kl-chat-panel{min-height:350px}.kl-suggest-panel{width:100%;min-width:unset;max-height:200px;border-left:none;border-top:1px solid var(--border)}}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9500;background:#000000b3;display:flex;align-items:center;justify-content:center}.confirm-dialog{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:24px;width:400px;max-width:90vw;text-align:center}.confirm-dialog .confirm-msg{font-size:var(--fs-sm);color:var(--foreground);margin-bottom:8px}.confirm-dialog .confirm-sub{font-size:var(--fs-xs);color:var(--text-dim);margin-bottom:20px}.confirm-dialog .confirm-actions{display:flex;justify-content:center;gap:12px}.ep-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-bottom:16px}.ep-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;transition:all .2s;position:relative}.ep-card:hover{border-color:var(--accent);background:var(--card-hover)}.ep-card.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 12px var(--accent-glow);background:var(--accent-muted)}.ep-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.ep-card-num{font-weight:700;font-size:1.1rem;color:var(--foreground)}.ep-card-num input{width:80px;background:transparent;border:none;border-bottom:1px dashed var(--border);color:var(--foreground);font-weight:700;font-size:1.1rem;padding:2px 4px}.ep-card-num input:focus{border-bottom-color:var(--accent);outline:none}.ep-card-title{font-size:var(--fs-sm);color:var(--text-dim);margin-bottom:6px}.ep-card-title input{width:100%;background:transparent;border:none;border-bottom:1px dashed var(--border);color:var(--text-dim);font-size:var(--fs-sm);padding:2px 4px}.ep-card-title input:focus{border-bottom-color:var(--accent);outline:none;color:var(--foreground)}.ep-card-meta{display:flex;align-items:center;gap:8px;font-size:var(--fs-xs);color:var(--text-muted);flex-wrap:wrap}.ep-card-meta select{background:var(--sidebar-accent);color:var(--foreground);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px 6px;font-size:var(--fs-xs);cursor:pointer}.ep-card-badge{font-size:.65rem;padding:2px 8px;border-radius:8px;white-space:nowrap}.ep-card-badge.draft{background:#6c6c7e26;color:var(--text-dim)}.ep-card-badge.generating{background:#e9c46a26;color:var(--warning)}.ep-card-badge.done{background:#2a9d8f26;color:var(--done)}.ep-card-badge.review{background:#6366f126;color:var(--info)}.ep-card-del{position:absolute;top:8px;right:10px;font-size:.7rem;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity .15s;z-index:2}.ep-card:hover .ep-card-del{opacity:.7}.ep-card-del:hover{color:var(--danger);opacity:1}.ep-status-badge{font-size:var(--fs-xs);padding:3px 10px;border-radius:10px;margin-left:8px}.ep-status-badge.draft{background:#6c6c7e26;color:var(--text-dim)}.ep-status-badge.generating{background:#e9c46a26;color:var(--warning)}.ep-status-badge.done{background:#2a9d8f26;color:var(--done)}.ep-status-badge.review{background:#6366f126;color:var(--accent)}.ep-version-panel{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:10px 16px;background:var(--sidebar-accent);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px}.ep-version-radio{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);color:var(--text-dim);cursor:pointer;padding:4px 12px;border-radius:var(--radius-sm);border:1px solid transparent;transition:all .15s}.ep-version-radio:hover{border-color:var(--border)}.ep-version-radio.active{border-color:var(--accent);color:var(--accent);background:#00b4d814}.ep-version-radio input[type=radio]{display:none}.ep-version-count{font-size:var(--fs-xs);color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:12px;opacity:.6}.empty-state-title{font-size:var(--fs-lg);color:var(--foreground);margin-bottom:6px}.empty-state-desc{font-size:var(--fs-sm);color:var(--text-dim);margin-bottom:16px;max-width:400px}.script-editor{width:100%;min-height:300px;background:var(--sidebar-accent);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;font-size:var(--fs-sm);line-height:1.6;color:var(--text-dim);resize:vertical;font-family:inherit}.script-editor:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-glow-accent)}.script-preview{min-height:300px;background:var(--sidebar-accent);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;font-size:var(--fs-sm);line-height:1.6;color:var(--text-dim);white-space:pre-wrap;overflow:auto}.readonly-input{width:100%;padding:6px;background:var(--sidebar-accent);border:1px solid var(--border);border-radius:4px;color:var(--text-dim);cursor:not-allowed}.version-info-bar{padding:6px 12px;background:#00b4d80f;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-xs);color:var(--text-dim)}.saved-param-chip{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;padding:3px 12px;border-radius:12px;border:1px solid var(--border);cursor:pointer;background:var(--sidebar-accent);color:var(--text-dim);transition:all .15s;white-space:nowrap}.saved-param-chip:hover{border-color:var(--accent);color:var(--accent);background:#00b4d80d}.cascade-items{background:var(--sidebar-accent);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:var(--fs-xs);max-height:150px;overflow-y:auto;margin:8px 0}.cascade-item{padding:3px 0;color:var(--text-dim);display:flex;align-items:center;gap:6px}.cascade-item .danger-icon{color:var(--danger)}.push-btn{background:linear-gradient(135deg,var(--accent),#0077b6);color:#fff;border:none;font-weight:600}.push-btn:hover{filter:brightness(1.15)}.gen-episode-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--fs-sm)}.gen-series-name{color:var(--foreground);font-weight:var(--fw-semibold)}.gen-sep{color:var(--text-dim)}.gen-episode-select{padding:4px 10px;background:var(--sidebar-accent);color:var(--foreground);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-sm);cursor:pointer}.gen-episode-select:focus{outline:none;border-color:var(--accent)}.gen-episode-select:disabled{opacity:.5;cursor:not-allowed}.gen-engine-badge{font-size:.75rem;padding:2px 8px;border-radius:4px}.gen-engine-badge[data-engine=seedream]{background:#7209b71a;color:var(--accent);border:1px solid rgba(114,9,183,.3)}.gen-engine-badge[data-engine=comfy]{background:#2a9d8f1a;color:#2a9d8f;border:1px solid rgba(42,157,143,.3)}.gen-engine-badge[data-engine=other]{background:#e9c46a1a;color:var(--warning);border:1px solid rgba(233,196,106,.3)}.gen-engine-badge-sm{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:10px;font-size:.65rem;font-weight:600}.gen-engine-badge-sm[data-engine=seedream]{background:#7209b71a;color:var(--accent);border:1px solid rgba(114,9,183,.3)}.gen-engine-badge-sm[data-engine=comfy]{background:#2a9d8f1a;color:#2a9d8f;border:1px solid rgba(42,157,143,.3)}.gen-engine-badge-sm[data-engine=other]{background:#e9c46a1a;color:var(--warning);border:1px solid rgba(233,196,106,.3)}.gen-warning-banner{background:#eab30826;color:#eab308;padding:12px 16px;text-align:center;border-radius:var(--radius-sm);margin:8px 0;font-size:var(--fs-sm);border:1px solid rgba(234,179,8,.3)}.gen-health-status{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius-sm);font-size:var(--fs-sm)}.gen-health-status.online{background:#2a9d8f1a;color:var(--done)}.gen-health-status.offline{background:#e639461a;color:var(--danger)}.gen-pipeline-monitor{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;display:flex;flex-wrap:wrap;align-items:center;gap:18px;font-size:var(--fs-sm)}.gen-mon-item{display:flex;align-items:center;gap:4px;color:var(--text-dim)}.gen-mon-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.gen-mon-dot.green{background:var(--done)}.gen-mon-dot.red{background:var(--danger)}.gen-mon-sep{width:1px;height:24px;background:var(--border)}.gen-mon-progress-wrap{flex:1;min-width:200px}.gen-mon-progress-label{font-size:var(--fs-xs);color:var(--text-dim);margin-bottom:4px}.gen-mon-progress-bar{width:100%;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.gen-mon-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--done));border-radius:4px;transition:width .5s ease}.gen-pipeline-stages{display:flex;justify-content:space-between;align-items:center;padding:12px 0;font-size:var(--fs-sm);flex-wrap:wrap;gap:8px}.gen-pipeline-stage-row{display:inline-flex;align-items:center;gap:4px}.gen-stage-label{font-size:var(--fs-sm)}.gen-stage-label.done{color:var(--done);font-weight:600}.gen-stage-label.active{color:var(--accent);font-weight:600}.gen-stage-label.pending{color:var(--text-dim)}.gen-stage-icon{font-size:.8rem}.gen-stage-arrow{color:var(--text-dim);margin:0 4px}.gen-queue-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 0}.gen-table-wrap{overflow-x:auto}.gen-queue-table{width:100%;border-collapse:collapse;font-size:var(--fs-xs)}.gen-queue-table th{padding:8px 10px;text-align:left;border-bottom:1px solid var(--border);color:var(--text-dim);font-weight:var(--fw-semibold);white-space:nowrap}.gen-queue-table td{padding:6px 10px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.gen-queue-table tr:hover td{background:var(--card-hover)}.gen-seq-num{text-align:center;font-weight:700;color:var(--accent)}.gen-mono{font-family:Cascadia Code,Fira Code,Consolas,monospace;font-weight:600;color:var(--foreground)}.gen-type-select{padding:2px 4px;font-size:.7rem;background:var(--sidebar-accent);color:var(--foreground);border:1px solid var(--border);border-radius:3px}.gen-type-select:focus{outline:none;border-color:var(--accent)}.gen-shot-thumb{width:60px;aspect-ratio:16 / 9;background:var(--sidebar-accent);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:.6rem;color:var(--text-dim);flex-shrink:0;overflow:hidden}.gen-shot-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.gen-prompt-textarea{width:100%;font-size:.65rem;background:var(--sidebar-accent);color:var(--foreground);border:1px solid var(--border);border-radius:3px;padding:4px;resize:vertical;font-family:Cascadia Code,Fira Code,Consolas,monospace;min-height:40px}.gen-prompt-textarea:focus{outline:none;border-color:var(--accent)}.gen-stage-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600}.gen-stage-badge.stage-new{background:#6c6c7e26;color:var(--text-dim)}.gen-stage-badge.stage-submitted{background:#e9c46a26;color:var(--warning)}.gen-stage-badge.stage-polling{background:#00b4d826;color:var(--accent)}.gen-stage-badge.stage-done{background:#2a9d8f26;color:var(--done)}.gen-stage-badge.stage-failed{background:#e6394626;color:var(--danger)}.gen-progress-bar{width:120px;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.gen-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s ease}.gen-action-cell{white-space:nowrap}.gen-empty-queue{text-align:center;padding:40px;color:var(--text-dim)}.gen-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;padding:0 4px 4px}.gen-gallery-item{position:relative;background:var(--sidebar-accent);border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:var(--fs-xs);cursor:pointer;transition:all .2s;border:2px solid transparent}.gen-gallery-item:hover{transform:scale(1.03);border-color:var(--accent)}.gen-gallery-item .gen-gallery-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#ffffff80;z-index:1;background:#0003;transition:all .2s}.gen-gallery-item:hover .gen-gallery-play-overlay{color:#fffc;background:#00000059}.gen-gallery-item .gen-gallery-overlay{position:absolute;bottom:0;left:0;right:0;padding:6px 10px;background:#000000b3;font-size:var(--fs-xs);display:flex;justify-content:space-between}.gen-gallery-item.done{border-color:var(--done)}.gen-gallery-item.running{border:1px dashed var(--accent)}.gen-gallery-item.running .gen-gallery-progress{position:absolute;bottom:0;left:0;height:3px;background:var(--accent);transition:width .4s ease}.gen-gallery-item.failed{border:1px dashed var(--danger);color:var(--danger)}.gen-gallery-empty{grid-column:1 / -1;text-align:center;padding:40px 0;color:var(--text-dim)}.gen-gallery-filter-bar{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap;padding:0 16px}.gen-filter-btn{padding:4px 14px;border-radius:14px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:var(--fs-xs);cursor:pointer;transition:all .15s}.gen-filter-btn:hover{border-color:var(--accent);color:var(--foreground)}.gen-filter-btn.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.gen-status-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;margin-top:16px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--fs-sm);color:var(--text-dim);flex-wrap:wrap;gap:8px}.gen-status-counts{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.gen-video-modal-content{display:flex;flex-direction:column;gap:12px}.gen-video-player-container{width:100%;aspect-ratio:16 / 9;background:linear-gradient(135deg,#1a1a4e,#0d2137);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:4rem;color:#ffffff4d;overflow:hidden}.gen-video-player{width:100%;max-height:400px;border-radius:var(--radius-sm);background:#000}.gen-video-polling{text-align:center;padding:40px;color:var(--foreground)}.gen-video-info-row{display:flex;gap:12px;font-size:var(--fs-xs);color:var(--text-dim)}.gen-info-label{color:var(--text-dim);font-weight:600}.gen-video-frames{display:grid;grid-template-columns:1fr 1fr;gap:10px}.gen-video-frame-thumb{aspect-ratio:16 / 9;background:var(--sidebar-accent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:var(--fs-xs);color:var(--text-dim);overflow:hidden}.gen-video-frame-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.gen-video-prompt-box{background:var(--sidebar-accent);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;font-size:var(--fs-xs);color:var(--text-dim);line-height:1.5;max-height:80px;overflow-y:auto}.gen-logs-content{max-height:60vh;overflow-y:auto}.gen-logs-pre{font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:.75rem;color:var(--text-dim);white-space:pre-wrap;word-break:break-all;background:var(--sidebar-accent);padding:12px;border-radius:var(--radius-sm);border:1px solid var(--border)}.gen-submit-shot-list{max-height:300px;overflow-y:auto;margin-bottom:16px}.gen-submit-shot-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:6px;cursor:pointer;transition:background .15s}.gen-submit-shot-item:hover{background:var(--card-hover)}.gen-shot-info{flex:1;font-size:var(--fs-sm)}.gen-shot-id-label{font-family:Cascadia Code,Fira Code,Consolas,monospace;font-weight:600;color:var(--foreground)}.gen-shot-meta-label{font-size:var(--fs-xs);color:var(--text-dim);display:block}.gen-submit-manual-row{display:flex;gap:8px;margin-top:12px;align-items:flex-end}.gen-submit-manual-row input,.gen-submit-manual-row select{background:var(--sidebar-accent);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--foreground);font-size:var(--fs-sm);padding:6px 10px}.gen-submit-manual-row input{flex:1}.gen-submit-manual-row input:focus,.gen-submit-manual-row select:focus{outline:none;border-color:var(--accent)}.settings-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media (max-width: 900px){.settings-grid{grid-template-columns:repeat(2,1fr)}}.settings-grid .form-group{margin-bottom:0}.settings-grid label{display:block;font-size:var(--fs-xs);color:var(--text-dim);margin-bottom:4px}.settings-grid select,.settings-grid input{width:100%;padding:8px 10px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-sm)}.settings-grid select:focus,.settings-grid input:focus{outline:none;border-color:var(--accent)}.action-bar{display:flex;justify-content:space-between;align-items:center;margin-top:16px;gap:12px;flex-wrap:wrap}.action-bar .btn{white-space:nowrap}.preview-content{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;max-height:360px;overflow-y:auto;font-family:var(--font-mono);font-size:var(--fs-sm);line-height:1.7;white-space:pre-wrap;color:var(--text)}.preview-content h1,.preview-content h2,.preview-content h3{color:var(--foreground);margin:12px 0 6px}.preview-content h1{font-size:var(--fs-xl)}.preview-content h2{font-size:var(--fs-lg)}.preview-content h3{font-size:var(--fs-md)}.preview-content strong{color:var(--foreground)}.preview-content code{background:var(--neutral-6);padding:1px 4px;border-radius:3px;font-size:var(--fs-xs)}.preview-content hr{border:none;border-top:1px solid var(--border);margin:12px 0}.series-ep-list .ep-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:8px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .15s}.series-ep-list .ep-card:hover{border-color:var(--accent);background:#00b4d808}.series-ep-list .ep-card .ep-num{font-size:var(--fs-md);font-weight:700;color:var(--accent);min-width:50px}.series-ep-list .ep-card .ep-info{flex:1;min-width:0}.series-ep-list .ep-card .ep-title{font-size:var(--fs-md);color:var(--foreground);font-weight:600}.series-ep-list .ep-card .ep-synopsis{font-size:var(--fs-xs);color:var(--text-dim);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.series-ep-list .ep-card .ep-meta{display:flex;align-items:center;gap:10px;margin-top:4px;font-size:var(--fs-xs);color:var(--text-dim)}.series-ep-list .ep-card .ep-actions{display:flex;gap:4px;flex-shrink:0}.series-ep-list .ep-card .ep-actions button{width:28px;height:28px;border-radius:4px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-dim);cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:all .15s}.series-ep-list .ep-card .ep-actions button:hover{background:var(--card-hover);color:var(--foreground)}.series-ep-list .ep-card .ep-actions .btn-del:hover{color:var(--failed);border-color:var(--failed)}.badge{font-size:var(--fs-xs);padding:2px 8px;border-radius:var(--radius-sm);font-weight:500}.badge-draft{background:#6c6c7e26;color:var(--text-dim)}.badge-generating{background:#e9c46a26;color:var(--gold)}.badge-done{background:#22c55e26;color:#22c55e}.badge-review{background:#a855f726;color:#a855f7}textarea.series-textarea{width:100%;padding:10px 12px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-sm);font-family:var(--font);resize:vertical;min-height:60px}textarea.series-textarea:focus{outline:none;border-color:var(--accent)}.prompt-error{border-color:var(--failed)!important;box-shadow:0 0 0 2px #e76f5140;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.char-count{font-size:var(--fs-xs);color:var(--text-dim);margin-top:2px}.char-count.error{color:var(--failed)}.version-panel{margin-top:16px}.version-radio-group{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.version-radio{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--fs-sm);color:var(--text-dim);background:var(--bg);transition:all .15s}.version-radio:hover{border-color:var(--accent);color:var(--foreground)}.version-radio.active{border-color:var(--accent);background:#00b4d814;color:var(--accent);font-weight:600}.generating-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1500}.generating-overlay .gen-box{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:32px 40px;text-align:center;box-shadow:var(--shadow)}.generating-overlay .gen-box h3{color:var(--foreground);margin-bottom:8px}.generating-overlay .gen-box p{color:var(--text-dim);font-size:var(--fs-sm)}.btn-gold{background:var(--gold);color:#000;border-color:var(--gold)}.btn-gold:hover{background:var(--gold-hover);border-color:var(--gold-hover)}.episode-context-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--fs-sm)}.episode-context-bar .series-name{color:var(--foreground);font-weight:600}.episode-context-bar .sep{color:var(--text-dim)}.episode-context-bar select{padding:4px 10px;background:var(--sidebar-accent);color:var(--foreground);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-sm);cursor:pointer}.episode-context-bar select:focus{outline:none;border-color:var(--accent)}.episode-context-bar select:disabled{opacity:.5;cursor:not-allowed}.global-style-panel{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}.global-style-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-bottom:1px solid transparent;transition:border-color .2s}.global-style-header:hover{background:#ffffff03}.global-style-panel.expanded .global-style-header{border-bottom-color:var(--border)}.global-style-header .title{font-weight:600;font-size:.9rem;color:var(--foreground);display:flex;align-items:center;gap:8px}.global-style-header .toggle-icon{transition:transform .2s;font-size:.7rem;color:var(--text-dim)}.global-style-panel.expanded .toggle-icon{transform:rotate(180deg)}.global-style-body{display:none;padding:12px 16px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.global-style-panel.expanded .global-style-body{display:grid}.global-style-body .form-group{margin-bottom:0}.global-style-body .form-group label{display:block;font-size:.7rem;color:var(--text-dim);margin-bottom:4px;font-weight:500}.global-style-body .form-group select,.global-style-body .form-group input{width:100%;padding:7px 10px;background:var(--sidebar-accent);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:.85rem}.global-style-body .form-group select:focus,.global-style-body .form-group input:focus{outline:none;border-color:var(--accent)}.studio-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:16px;padding:10px 14px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius)}.studio-toolbar .spacer{flex:1}.studio-toolbar .group{display:flex;gap:6px;align-items:center}.studio-toolbar .sep{width:1px;height:22px;background:var(--border);margin:0 6px}.toolbar-select{padding:4px 8px;background:var(--sidebar-accent);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:.8rem}.toolbar-select:focus{outline:none;border-color:var(--accent)}.shot-studio-table{width:100%;min-width:1100px;border-collapse:collapse;font-size:.8rem}.shot-studio-table thead{position:sticky;top:0;z-index:2}.shot-studio-table th{background:var(--sidebar-accent);padding:8px 6px;text-align:center;font-weight:600;font-size:.7rem;color:var(--text-dim);border-bottom:2px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}.shot-studio-table th.col-num{width:50px}.shot-studio-table th.col-node{width:60px}.shot-studio-table th.col-dur{width:55px}.shot-studio-table th.col-scene,.shot-studio-table th.col-camera{width:80px}.shot-studio-table th.col-summary{width:260px}.shot-studio-table th.col-frame,.shot-studio-table th.col-lastframe{width:140px}.shot-studio-table th.col-emotion{width:90px}.shot-studio-table th.col-status{width:70px}.shot-studio-table th.col-actions{width:130px}.shot-studio-table td{padding:5px 4px;border-bottom:1px solid rgba(30,30,46,.5);vertical-align:top}.shot-studio-table tbody tr{transition:background .2s}.shot-studio-table tbody tr:hover td{background:#ffffff04}.shot-studio-table tbody tr.selected td{background:var(--accent-muted)}.shot-studio-table tbody tr.locked td{background:#2a9d8f0a}.shot-studio-table td input,.shot-studio-table td textarea,.shot-studio-table td select{width:100%;padding:4px 6px;background:transparent;color:var(--text);border:1px solid transparent;border-radius:3px;font-size:.78rem;font-family:inherit;transition:border-color .15s}.shot-studio-table td input:hover,.shot-studio-table td textarea:hover,.shot-studio-table td select:hover{border-color:var(--border)}.shot-studio-table td input:focus,.shot-studio-table td textarea:focus,.shot-studio-table td select:focus{outline:none;border-color:var(--accent);background:var(--bg)}.shot-studio-table td textarea{resize:vertical;min-height:34px;height:34px}.shot-studio-table td textarea:focus{height:auto;min-height:60px}.shot-cards{display:flex;flex-direction:column;gap:10px}.shot-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}.shot-card.locked{background:#2a9d8f0a}.shot-card.engine-override{border-left:3px solid var(--gold)}.shot-card-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.shot-card-header .spacer{flex:1}.shot-card-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:10px}.shot-card-meta label{font-size:.7rem;color:var(--text-dim)}.shot-card-meta select,.shot-card-meta input{background:var(--sidebar-accent);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-size:.82rem}.shot-card-meta select:focus,.shot-card-meta input:focus{outline:none;border-color:var(--accent)}.dur-input{width:55px!important;text-align:center}.scene-select{min-width:70px}.shot-card-body{margin-top:10px;display:grid;gap:10px}.shot-card-body textarea{width:100%;background:var(--sidebar-accent);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:10px;font-size:.84rem;line-height:1.5;resize:vertical;font-family:inherit}.shot-card-body textarea:focus{outline:none;border-color:var(--accent)}.summary-input{min-height:60px}.shot-card-two{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media (max-width: 900px){.shot-card-two{grid-template-columns:1fr}}.shot-error-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;background:#e6394614;border:1px solid rgba(230,57,70,.2);border-radius:6px;color:var(--failed);font-size:.82rem}.frame-block{display:grid;gap:8px}.frame-cell{display:flex;align-items:center;justify-content:center;min-height:40px}.frame-thumb{width:64px;height:40px;border-radius:4px;overflow:hidden;border:1px solid var(--border);cursor:pointer}.frame-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.frame-placeholder{color:var(--text-dim);font-size:.75rem}.gen-inline{background:#ffffff05;border:1px solid var(--border);border-radius:8px;padding:10px}.gen-inline-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.gen-mode-buttons{display:flex;gap:6px;flex-wrap:wrap}.gen-mode-btn{padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:.78rem;cursor:pointer;transition:all .15s}.gen-mode-btn:hover{color:var(--text)}.gen-mode-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.gen-tab-body{display:grid;gap:8px}.prompt-inline{width:100%;background:var(--sidebar-accent);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:.82rem;line-height:1.5;resize:vertical;font-family:inherit}.prompt-inline:focus{outline:none;border-color:var(--accent)}.prompt-inline.frame-invalid{border-color:var(--danger)!important;background:#ef44440d!important}.prompt-inline.frame-invalid:focus{border-color:var(--danger)!important}.gen-upload{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.gen-upload-thumbs{display:flex;gap:6px;flex-wrap:wrap}.gen-upload-thumb{width:44px;height:44px;-o-object-fit:cover;object-fit:cover;border-radius:6px;border:1px solid var(--border);cursor:pointer;opacity:.95}.gen-upload-thumb:hover{border-color:var(--accent);opacity:1}.gen-inline-preview{margin-top:8px;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--sidebar-accent)}.gen-inline-preview img{width:100%;display:block}.gen-inline-placeholder{padding:14px;text-align:center;color:var(--text-dim);font-size:.8rem}.gen-inline-seq{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.gen-inline-seq img{width:64px;height:64px;-o-object-fit:cover;object-fit:cover;border-radius:6px;border:1px solid var(--border);cursor:pointer;opacity:.9}.gen-inline-seq img.active{border-color:var(--accent);opacity:1}.seq-wrap{position:relative;display:inline-block}.seq-wrap img{width:64px;height:64px;-o-object-fit:cover;object-fit:cover;border-radius:6px;border:1px solid var(--border);cursor:pointer}.seq-wrap img.active{border-color:var(--accent)}.img-delete-btn{position:absolute;top:-4px;right:-4px;background:var(--card-bg);border:1px solid var(--border);border-radius:50%;width:18px;height:18px;font-size:.55rem;line-height:1;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2}.img-delete-btn:hover{border-color:var(--failed)}.gen-inline-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:6px}.gen-ref-bind{margin-top:8px;display:grid;gap:6px}.gen-ref-buttons{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.gen-ref-label{font-size:.7rem;color:var(--text-dim)}.gen-ref-thumbs{display:flex;gap:8px;flex-wrap:wrap}.ref-thumb-wrap{position:relative;display:inline-block}.ref-thumb-remove{position:absolute;top:-5px;right:-5px;font-size:.6rem;cursor:pointer;opacity:.8}.ref-thumb-remove:hover{opacity:1}.status-badge{display:inline-block;font-size:.6rem;font-weight:600;padding:2px 7px;border-radius:3px}.status-draft{background:#6c6c7e26;color:var(--text-dim)}.status-generated{background:#00b4d81f;color:var(--accent)}.status-locked{background:#2a9d8f1f;color:var(--done)}.status-failed{background:#e639461f;color:var(--failed)}.node-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.65rem;font-weight:700;text-align:center}.node-kf2v{background:#7209b733;color:#b388ff}.node-i2v{background:#4895ef33;color:#82b1ff}.row-actions{display:flex;gap:4px;justify-content:center;flex-wrap:wrap}.row-actions button{width:26px;height:26px;padding:0;border-radius:4px;font-size:.7rem;cursor:pointer;border:1px solid var(--border);background:var(--card-bg);color:var(--text);display:flex;align-items:center;justify-content:center;transition:all .15s}.row-actions button:hover{border-color:var(--accent)}.row-actions button:disabled{opacity:.4;cursor:not-allowed}.row-actions .btn-ai:hover{background:#6366f126;color:var(--info)}.row-actions .btn-material:hover{background:#f59e0b26;color:var(--gold)}.row-actions .btn-gen:hover{background:#00b4d826;color:var(--accent)}.row-actions .btn-delete:hover{background:#e6394626;color:var(--failed)}.shot-num-cell{font-weight:700;color:var(--accent);text-align:center;font-size:.9rem;white-space:nowrap}.drag-handle-cell{cursor:grab;text-align:center;color:var(--text-muted);-webkit-user-select:none;-moz-user-select:none;user-select:none}.drag-handle-cell:active{cursor:grabbing}td.saved-flash{animation:saveFlash .5s ease}@keyframes saveFlash{0%{background:#2dd4bf26}to{background:transparent}}.engine-selector-group{display:flex;align-items:center;gap:6px}.engine-select{padding:4px 8px;background:var(--sidebar-accent);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:.8rem}.engine-select:focus{outline:none;border-color:var(--accent)}.per-shot-engine{display:flex;align-items:center;gap:4px}.engine-override-badge{font-size:.7rem;color:var(--gold)}.material-tabs{display:flex;border-bottom:1px solid var(--border)}.material-tab{flex:1;padding:10px;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--text-dim);font-size:.85rem;cursor:pointer;transition:all .15s}.material-tab:hover{color:var(--text)}.material-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.material-modal-body{padding:16px;overflow-y:auto;flex:1;min-height:200px}.material-search{margin-bottom:12px;display:flex;gap:8px}.material-search input{flex:1;padding:7px 10px;background:var(--sidebar-accent);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:.85rem}.material-search input:focus{outline:none;border-color:var(--accent)}.material-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.material-card{background:var(--sidebar-accent);border:1px solid var(--border);border-radius:var(--radius-xs);padding:8px;cursor:pointer;text-align:center;transition:all .15s}.material-card:hover{border-color:var(--accent);background:var(--card-hover)}.material-card .thumb{width:100%;aspect-ratio:1/1;border-radius:4px;margin-bottom:6px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--text-dim);overflow:hidden}.material-card .thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.material-card .name{font-size:.72rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.material-card .tag{font-size:.6rem;color:var(--text-muted);margin-top:2px}.btn-lock-push{background:linear-gradient(135deg,var(--gold),#d97706);color:#000;border:none;font-weight:700}.btn-lock-push:hover{filter:brightness(1.15)}.frame-invalid{border-color:var(--danger)!important;background:#ef44440d!important}.frame-invalid:focus{border-color:var(--danger)!important}.reverse-prompt-btn{position:absolute;bottom:4px;right:4px;font-size:.7rem;padding:2px 6px;background:var(--accent);color:#fff;border-radius:4px;cursor:pointer;opacity:.9;transition:opacity .2s}.reverse-prompt-btn:hover{opacity:1}.reverse-prompt-btn:disabled{opacity:.5;cursor:not-allowed}.visual-spec-tab{display:flex;flex-direction:column;gap:1rem;padding:1rem 0}.visual-spec-tab label{font-size:.85rem;font-weight:600;margin-bottom:.25rem;display:block}.visual-spec-tab textarea{width:100%;min-height:80px;resize:vertical}.material-select-modal{padding:0}.material-select-modal .modal-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1rem}.material-select-modal .modal-tabs button{flex:1;padding:.75rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:.9rem;color:var(--text-dim);transition:all .15s}.material-select-modal .modal-tabs button:hover{color:var(--text-primary)}.material-select-modal .modal-tabs button.active{border-bottom-color:var(--accent);color:var(--accent);font-weight:600}.material-select-modal .search-bar{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;margin-bottom:1rem;background:var(--sidebar-accent, var(--bg-secondary));color:var(--text-primary, var(--text));font-size:.85rem}.material-select-modal .search-bar:focus{outline:none;border-color:var(--accent)}.material-select-modal .material-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;max-height:350px;overflow-y:auto;padding:.5rem}.material-select-modal .material-card{position:relative;border:2px solid var(--border);border-radius:8px;padding:.5rem;cursor:pointer;transition:border-color .2s,background .2s;text-align:center}.material-select-modal .material-card:hover{border-color:var(--text-secondary)}.material-select-modal .material-card.selected{border-color:var(--accent);background:#6366f114}.material-select-modal .material-card .check-badge{position:absolute;top:4px;right:4px;width:20px;height:20px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem}.material-select-modal .material-card img{width:100%;height:80px;-o-object-fit:cover;object-fit:cover;border-radius:4px}.material-select-modal .material-card .card-name{font-size:.75rem;margin-top:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-select-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border);margin-top:1rem}.ref-materials-list{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.75rem}.ref-panel-item{position:relative;width:100px;border:1px solid var(--border);border-radius:6px;padding:.5rem;text-align:center}.ref-panel-item img{width:100%;height:60px;-o-object-fit:cover;object-fit:cover;border-radius:4px}.ref-panel-item .item-name{font-size:.7rem;margin-top:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ref-panel-item .remove-btn{position:absolute;top:2px;right:2px;width:16px;height:16px;background:var(--danger);border:none;border-radius:50%;color:#fff;font-size:.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.ref-panel-item .weight-input{width:100%;margin-top:.25rem;accent-color:var(--accent)}.ref-panel-item .weight-label{font-size:.65rem;color:var(--text-secondary, var(--text-dim))}.billing-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:9999px;white-space:nowrap;line-height:1.4;vertical-align:middle}.billing-badge-ok{background:#22c55e26;color:#16a34a;border:1px solid rgba(34,197,94,.3)}.billing-badge-info{background:#3b82f61f;color:#2563eb;border:1px solid rgba(59,130,246,.25)}.billing-badge-neutral{background:#6b72801f;color:#6b7280;border:1px solid rgba(107,114,128,.25)}.billing-badge-warn{background:#f59e0b26;color:#d97706;border:1px solid rgba(245,158,11,.3)}.billing-badge-error{background:#ef444426;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.billing-cost-line{display:block;font-size:.7rem;color:var(--text-dim, #888);margin-top:.15rem;font-variant-numeric:tabular-nums}.gen-billing-cell{min-width:100px;white-space:nowrap;vertical-align:middle}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:-translate-y-1:hover{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-accent:hover{--tw-border-opacity: 1;border-color:rgb(0 180 216 / var(--tw-border-opacity, 1))}.hover\:border-accent\/30:hover{border-color:#00b4d84d}.hover\:border-black\/20:hover{border-color:#0003}.hover\:border-neutral-8:hover{--tw-border-opacity: 1;border-color:rgb(42 42 62 / var(--tw-border-opacity, 1))}.hover\:border-white\/20:hover{border-color:#fff3}.hover\:bg-accent-hover:hover{--tw-bg-opacity: 1;background-color:rgb(0 200 240 / var(--tw-bg-opacity, 1))}.hover\:bg-black\/5:hover{background-color:#0000000d}.hover\:bg-neutral-3\/50:hover{background-color:#11111880}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-white\/5:hover{background-color:#ffffff0d}.hover\:text-\[var\(--neutral-11\)\]:hover{color:var(--neutral-11)}.hover\:text-accent:hover{--tw-text-opacity: 1;color:rgb(0 180 216 / var(--tw-text-opacity, 1))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-lg:hover{--tw-shadow: 0 8px 40px rgba(0,0,0,.4);--tw-shadow-colored: 0 8px 40px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-accent\/40:hover{--tw-shadow-color: rgb(0 180 216 / .4);--tw-shadow: var(--tw-shadow-colored)}.focus\:border-accent:focus{--tw-border-opacity: 1;border-color:rgb(0 180 216 / var(--tw-border-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.group:hover .group-hover\:opacity-100{opacity:1}@media (min-width: 640px){.sm\:inline-flex{display:inline-flex}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:gap-4{gap:1rem}.sm\:text-3xl,.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-xl{font-size:2.125rem;line-height:2.5rem}}@media (min-width: 768px){.md\:flex{display:flex}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:text-2xl{font-size:2.5rem;line-height:2.75rem}.md\:text-6xl{font-size:3.75rem;line-height:1}}@media (min-width: 1024px){.lg\:inline-flex{display:inline-flex}}@media (min-width: 1280px){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
