@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-content:"";--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-lg:32rem;--container-3xl:48rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wide:.025em;--tracking-wider:.05em;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-2xl:28px;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 28px #0000001f;--shadow-xl:0 16px 48px #00000029;--ease-out:cubic-bezier(0, 0, .2, 1);--animate-spin:spin 1s linear infinite;--blur-sm:8px;--aspect-video:16 / 9;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-bg:#fff;--color-bg-secondary:#f5f5f7;--color-bg-tertiary:#fbfbfd;--color-surface:#fff;--color-surface-elevated:#fff;--color-text-primary:#1d1d1f;--color-text-secondary:#86868b;--color-text-tertiary:#a1a1a6;--color-accent:#0071e3;--color-accent-hover:#0077ed;--color-accent-active:#006edb;--color-success:#34c759;--color-warning:#ff9500;--color-error:#ff3b30;--color-border:#00000014;--color-border-strong:#0000001f;--color-divider:#0000000f;--radius-full:9999px}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.-top-2{top:calc(var(--spacing) * -2)}.top-0{top:calc(var(--spacing) * 0)}.top-1{top:calc(var(--spacing) * 1)}.top-1\.5{top:calc(var(--spacing) * 1.5)}.top-1\/2{top:50%}.top-2{top:calc(var(--spacing) * 2)}.top-3{top:calc(var(--spacing) * 3)}.top-4{top:calc(var(--spacing) * 4)}.top-6{top:calc(var(--spacing) * 6)}.top-full{top:100%}.-right-2{right:calc(var(--spacing) * -2)}.right-0{right:calc(var(--spacing) * 0)}.right-1{right:calc(var(--spacing) * 1)}.right-1\.5{right:calc(var(--spacing) * 1.5)}.right-2{right:calc(var(--spacing) * 2)}.right-3{right:calc(var(--spacing) * 3)}.right-4{right:calc(var(--spacing) * 4)}.right-6{right:calc(var(--spacing) * 6)}.right-8{right:calc(var(--spacing) * 8)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-6{bottom:calc(var(--spacing) * 6)}.bottom-7{bottom:calc(var(--spacing) * 7)}.bottom-8{bottom:calc(var(--spacing) * 8)}.bottom-\[30px\]{bottom:30px}.left-0{left:calc(var(--spacing) * 0)}.left-1\.5{left:calc(var(--spacing) * 1.5)}.left-1\/2{left:50%}.left-6{left:calc(var(--spacing) * 6)}.z-10{z-index:10}.z-50{z-index:50}.z-\[1\]{z-index:1}.z-\[2\]{z-index:2}.z-\[3\]{z-index:3}.z-\[100\]{z-index:100}.z-\[200\]{z-index:200}.z-\[1000\]{z-index:1000}.z-\[1500\]{z-index:1500}.z-\[2000\]{z-index:2000}.z-\[2001\]{z-index:2001}.z-\[9999\]{z-index:9999}.col-span-full{grid-column:1/-1}.col-start-2{grid-column-start:2}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.m-0{margin:calc(var(--spacing) * 0)}.-mx-0\.5{margin-inline:calc(var(--spacing) * -.5)}.-mx-5{margin-inline:calc(var(--spacing) * -5)}.mx-1{margin-inline:calc(var(--spacing) * 1)}.mx-2{margin-inline:calc(var(--spacing) * 2)}.mx-5{margin-inline:calc(var(--spacing) * 5)}.mx-auto{margin-inline:auto}.my-4{margin-block:calc(var(--spacing) * 4)}.my-5{margin-block:calc(var(--spacing) * 5)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-3\.5{margin-top:calc(var(--spacing) * 3.5)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-auto{margin-top:auto}.\!mb-0{margin-bottom:calc(var(--spacing) * 0)!important}.-mb-5{margin-bottom:calc(var(--spacing) * -5)}.mb-0\.5{margin-bottom:calc(var(--spacing) * .5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-2\.5{margin-bottom:calc(var(--spacing) * 2.5)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-5{margin-left:calc(var(--spacing) * 5)}.ml-6{margin-left:calc(var(--spacing) * 6)}.ml-auto{margin-left:auto}.box-border{box-sizing:border-box}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.aspect-video{aspect-ratio:var(--aspect-video)}.h-0{height:calc(var(--spacing) * 0)}.h-2{height:calc(var(--spacing) * 2)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-20{height:calc(var(--spacing) * 20)}.h-24{height:calc(var(--spacing) * 24)}.h-40{height:calc(var(--spacing) * 40)}.h-\[11px\]{height:11px}.h-\[22px\]{height:22px}.h-\[90vh\]{height:90vh}.h-\[95vh\]{height:95vh}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.max-h-\[35vh\]{max-height:35vh}.max-h-\[60vh\]{max-height:60vh}.max-h-\[80vh\]{max-height:80vh}.max-h-\[85vh\]{max-height:85vh}.max-h-\[90vh\]{max-height:90vh}.max-h-\[95vh\]{max-height:95vh}.max-h-\[120px\]{max-height:120px}.max-h-\[150px\]{max-height:150px}.max-h-\[200px\]{max-height:200px}.max-h-\[280px\]{max-height:280px}.max-h-full{max-height:100%}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-\[5\.6em\]{min-height:5.6em}.min-h-\[28px\]{min-height:28px}.min-h-\[40px\]{min-height:40px}.min-h-\[60px\]{min-height:60px}.min-h-\[80px\]{min-height:80px}.min-h-\[100px\]{min-height:100px}.min-h-\[120px\]{min-height:120px}.min-h-\[150px\]{min-height:150px}.min-h-\[200px\]{min-height:200px}.min-h-\[280px\]{min-height:280px}.min-h-\[300px\]{min-height:300px}.min-h-\[350px\]{min-height:350px}.min-h-\[400px\]{min-height:400px}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-0{width:calc(var(--spacing) * 0)}.w-0\.5{width:calc(var(--spacing) * .5)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-10{width:calc(var(--spacing) * 10)}.w-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-60{width:calc(var(--spacing) * 60)}.w-\[11px\]{width:11px}.w-\[72px\]{width:72px}.w-\[90\%\]{width:90%}.w-\[90vw\]{width:90vw}.w-\[95vw\]{width:95vw}.w-\[280px\]{width:280px}.w-\[400px\]{width:400px}.w-auto{width:auto}.w-fit{width:fit-content}.w-full{width:100%}.w-px{width:1px}.max-w-3xl{max-width:var(--container-3xl)}.max-w-\[90vw\]{max-width:90vw}.max-w-\[95vw\]{max-width:95vw}.max-w-\[120px\]{max-width:120px}.max-w-\[200px\]{max-width:200px}.max-w-\[300px\]{max-width:300px}.max-w-\[360px\]{max-width:360px}.max-w-\[380px\]{max-width:380px}.max-w-\[400px\]{max-width:400px}.max-w-\[420px\]{max-width:420px}.max-w-\[480px\]{max-width:480px}.max-w-\[500px\]{max-width:500px}.max-w-\[560px\]{max-width:560px}.max-w-\[600px\]{max-width:600px}.max-w-\[700px\]{max-width:700px}.max-w-\[800px\]{max-width:800px}.max-w-\[900px\]{max-width:900px}.max-w-\[1200px\]{max-width:1200px}.max-w-full{max-width:100%}.max-w-lg{max-width:var(--container-lg)}.max-w-none{max-width:none}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-7{min-width:calc(var(--spacing) * 7)}.min-w-\[20px\]{min-width:20px}.min-w-\[22px\]{min-width:22px}.min-w-\[100px\]{min-width:100px}.min-w-\[180px\]{min-width:180px}.min-w-\[200px\]{min-width:200px}.min-w-\[220px\]{min-width:220px}.min-w-\[320px\]{min-width:320px}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-90{rotate:90deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-\[checkPop_0\.2s_ease-out\]{animation:.2s ease-out checkPop}.animate-\[confirmPulse_1s_ease_infinite\]{animation:1s infinite confirmPulse}.animate-\[fadeIn_0\.2s_ease-out\]{animation:.2s ease-out fadeIn}.animate-\[fadeIn_0\.15s_ease-out\]{animation:.15s ease-out fadeIn}.animate-\[fadeIn_0\.15s_ease\]{animation:.15s fadeIn}.animate-\[fadeIn_0\.25s_ease\]{animation:.25s fadeIn}.animate-\[fadeIn_250ms_ease-out\]{animation:.25s ease-out fadeIn}.animate-\[fullscreenFadeIn_0\.15s_ease-out\]{animation:.15s ease-out fullscreenFadeIn}.animate-\[fullscreenZoomIn_0\.2s_ease-out\]{animation:.2s ease-out fullscreenZoomIn}.animate-\[modalSlideIn_0\.2s_ease-out\]{animation:.2s ease-out modalSlideIn}.animate-\[promptSlideUp_0\.2s_ease-out\]{animation:.2s ease-out promptSlideUp}.animate-\[scaleIn_0\.15s_ease\]{animation:.15s scaleIn}.animate-\[simBarIn_0\.3s_ease-out\]{animation:.3s ease-out simBarIn}.animate-\[slideUp_0\.2s_ease-out\]{animation:.2s ease-out slideUp}.animate-\[spFadeIn_0\.25s_ease-out\]{animation:.25s ease-out spFadeIn}.animate-\[spImageIn_0\.2s_ease-out\]{animation:.2s ease-out spImageIn}.animate-\[spe-fade-in_0\.15s_ease\]{animation:.15s spe-fade-in}.animate-\[spe-toast-in_0\.25s_ease\]{animation:.25s spe-toast-in}.animate-\[toastSlideIn_0\.3s_ease-out\]{animation:.3s ease-out toastSlideIn}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-move{cursor:move}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize{resize:both}.resize-none{resize:none}.resize-y{resize:vertical}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.list-none{list-style-type:none}.columns-2{columns:2}.break-inside-avoid{break-inside:avoid}.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))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-\[14px_100px_1fr\]{grid-template-columns:14px 100px 1fr}.grid-cols-\[14px_110px_1fr\]{grid-template-columns:14px 110px 1fr}.grid-cols-\[14px_140px_1fr\]{grid-template-columns:14px 140px 1fr}.grid-cols-\[90px_1fr\]{grid-template-columns:90px 1fr}.grid-cols-\[110px_1fr\]{grid-template-columns:110px 1fr}.grid-cols-\[repeat\(auto-fill\,minmax\(180px\,1fr\)\)\]{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.grid-cols-\[repeat\(auto-fill\,minmax\(200px\,1fr\)\)\]{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.grid-cols-\[repeat\(auto-fill\,minmax\(280px\,1fr\)\)\]{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.content-start{align-content:flex-start}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0{gap:calc(var(--spacing) * 0)}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-8{gap:calc(var(--spacing) * 8)}.gap-\[0\.3rem\]{gap:.3rem}.gap-\[3px\]{gap:3px}.self-start{align-self:flex-start}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[10px\]{border-radius:10px}.rounded-\[14px\]{border-radius:14px}.rounded-\[20px\]{border-radius:20px}.rounded-\[var\(--radius-lg\)\]{border-radius:var(--radius-lg)}.rounded-\[var\(--radius-lg\,8px\)\]{border-radius:var(--radius-lg,8px)}.rounded-\[var\(--radius-md\)\]{border-radius:var(--radius-md)}.rounded-\[var\(--radius-md\,6px\)\]{border-radius:var(--radius-md,6px)}.rounded-\[var\(--radius-sm\)\]{border-radius:var(--radius-sm)}.rounded-\[var\(--radius-xl\)\]{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-t-\[var\(--radius-lg\,8px\)\]{border-top-left-radius:var(--radius-lg,8px);border-top-right-radius:var(--radius-lg,8px)}.rounded-r-md{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.rounded-b-xl{border-bottom-right-radius:var(--radius-xl);border-bottom-left-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-3,.border-\[3px\]{border-style:var(--tw-border-style);border-width:3px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-none{--tw-border-style:none;border-style:none}.\!border-\[rgba\(255\,120\,50\,0\.5\)\]{border-color:#ff783280!important}.border-\[\#0071e3\]{border-color:#0071e3}.border-\[\#c3e6cb\]{border-color:#c3e6cb}.border-\[\#d0d0d0\]{border-color:#d0d0d0}.border-\[\#e5e7eb\]{border-color:#e5e7eb}.border-\[\#f5c6cb\]{border-color:#f5c6cb}.border-\[rgba\(26\,26\,46\,0\.3\)\]{border-color:#1a1a2e4d}.border-\[rgba\(59\,130\,246\,0\.5\)\]{border-color:#3b82f680}.border-\[rgba\(220\,38\,38\,0\.3\)\]{border-color:#dc26264d}.border-\[var\(--border-color\)\]{border-color:var(--border-color)}.border-\[var\(--color-accent\)\]{border-color:var(--color-accent)}.border-\[var\(--color-accent\)\]\/30{border-color:#0071e34d}@supports (color:color-mix(in lab,red,red)){.border-\[var\(--color-accent\)\]\/30{border-color:color-mix(in oklab,var(--color-accent) 30%,transparent)}}.border-\[var\(--color-accent\,\#6366f1\)\]{border-color:var(--color-accent,#6366f1)}.border-\[var\(--color-border\)\]{border-color:var(--color-border)}.border-\[var\(--color-border-strong\)\]{border-color:var(--color-border-strong)}.border-\[var\(--color-danger\,\#e53e3e\)\]{border-color:var(--color-danger,#e53e3e)}.border-\[var\(--color-divider\)\]{border-color:var(--color-divider)}.border-\[var\(--color-divider\,var\(--color-border\)\)\]{border-color:var(--color-divider,var(--color-border))}.border-\[var\(--color-error\)\]{border-color:var(--color-error)}.border-\[var\(--color-primary\,\#6C63FF\)\]{border-color:var(--color-primary,#6c63ff)}.border-black\/10{border-color:#0000001a}@supports (color:color-mix(in lab,red,red)){.border-black\/10{border-color:color-mix(in oklab,var(--color-black) 10%,transparent)}}.border-black\/15{border-color:#00000026}@supports (color:color-mix(in lab,red,red)){.border-black\/15{border-color:color-mix(in oklab,var(--color-black) 15%,transparent)}}.border-black\/\[0\.06\]{border-color:#0000000f}@supports (color:color-mix(in lab,red,red)){.border-black\/\[0\.06\]{border-color:color-mix(in oklab,var(--color-black) 6%,transparent)}}.border-black\/\[0\.12\]{border-color:#0000001f}@supports (color:color-mix(in lab,red,red)){.border-black\/\[0\.12\]{border-color:color-mix(in oklab,var(--color-black) 12%,transparent)}}.border-transparent{border-color:#0000}.border-white{border-color:var(--color-white)}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.border-white\/10{border-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.border-white\/15{border-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.border-white\/15{border-color:color-mix(in oklab,var(--color-white) 15%,transparent)}}.border-white\/30{border-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.border-white\/30{border-color:color-mix(in oklab,var(--color-white) 30%,transparent)}}.border-white\/80{border-color:#fffc}@supports (color:color-mix(in lab,red,red)){.border-white\/80{border-color:color-mix(in oklab,var(--color-white) 80%,transparent)}}.border-white\/\[0\.06\]{border-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.border-white\/\[0\.06\]{border-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.border-t-\[var\(--color-accent\)\]{border-top-color:var(--color-accent)}.border-t-transparent{border-top-color:#0000}.border-b-\[var\(--color-accent\)\]{border-bottom-color:var(--color-accent)}.border-b-transparent{border-bottom-color:#0000}.\!bg-\[rgba\(255\,120\,50\,0\.3\)\]{background-color:#ff78324d!important}.bg-\[\#0a0a0c\]{background-color:#0a0a0c}.bg-\[\#34c759\]{background-color:#34c759}.bg-\[\#d4edda\]{background-color:#d4edda}.bg-\[\#f0f0f0\]{background-color:#f0f0f0}.bg-\[\#f5f5f7\]{background-color:#f5f5f7}.bg-\[\#f8d7da\]{background-color:#f8d7da}.bg-\[\#f9f9fb\]{background-color:#f9f9fb}.bg-\[\#f9fafb\]{background-color:#f9fafb}.bg-\[\#ff3b30\]{background-color:#ff3b30}.bg-\[rgba\(0\,113\,227\,0\.9\)\]{background-color:#0071e3e6}.bg-\[rgba\(0\,113\,227\,0\.12\)\]{background-color:#0071e31f}.bg-\[rgba\(0\,113\,227\,0\.15\)\]{background-color:#0071e326}.bg-\[rgba\(0\,113\,227\,0\.35\)\]{background-color:#0071e359}.bg-\[rgba\(0\,122\,255\,0\.12\)\]{background-color:#007aff1f}.bg-\[rgba\(10\,10\,20\,0\.95\)\]{background-color:#0a0a14f2}.bg-\[rgba\(26\,26\,46\,0\.2\)\]{background-color:#1a1a2e33}.bg-\[rgba\(52\,199\,89\,0\.1\)\]{background-color:#34c7591a}.bg-\[rgba\(52\,199\,89\,0\.12\)\]{background-color:#34c7591f}.bg-\[rgba\(52\,199\,89\,0\.92\)\]{background-color:#34c759eb}.bg-\[rgba\(59\,130\,246\,0\.3\)\]{background-color:#3b82f64d}.bg-\[rgba\(99\,102\,241\,0\.15\)\]{background-color:#6366f126}.bg-\[rgba\(108\,99\,255\,0\.2\)\]{background-color:#6c63ff33}.bg-\[rgba\(108\,99\,255\,0\.12\)\]{background-color:#6c63ff1f}.bg-\[rgba\(142\,142\,147\,0\.12\)\]{background-color:#8e8e931f}.bg-\[rgba\(168\,85\,247\,0\.15\)\]{background-color:#a855f726}.bg-\[rgba\(175\,82\,222\,0\.12\)\]{background-color:#af52de1f}.bg-\[rgba\(220\,38\,38\,0\.1\)\]{background-color:#dc26261a}.bg-\[rgba\(239\,68\,68\,0\.1\)\]{background-color:#ef44441a}.bg-\[rgba\(255\,59\,48\,0\.1\)\]{background-color:#ff3b301a}.bg-\[rgba\(255\,59\,48\,0\.12\)\]{background-color:#ff3b301f}.bg-\[rgba\(255\,149\,0\,0\.12\)\]{background-color:#ff95001f}.bg-\[rgba\(255\,159\,10\,0\.12\)\]{background-color:#ff9f0a1f}.bg-\[rgba\(255\,193\,7\,0\.15\)\]{background-color:#ffc10726}.bg-\[var\(--bg-tertiary\)\]{background-color:var(--bg-tertiary)}.bg-\[var\(--color-accent\)\]{background-color:var(--color-accent)}.bg-\[var\(--color-accent\)\]\/10{background-color:#0071e31a}@supports (color:color-mix(in lab,red,red)){.bg-\[var\(--color-accent\)\]\/10{background-color:color-mix(in oklab,var(--color-accent) 10%,transparent)}}.bg-\[var\(--color-bg\)\]{background-color:var(--color-bg)}.bg-\[var\(--color-bg-secondary\)\]{background-color:var(--color-bg-secondary)}.bg-\[var\(--color-bg-tertiary\)\]{background-color:var(--color-bg-tertiary)}.bg-\[var\(--color-border\)\]{background-color:var(--color-border)}.bg-\[var\(--color-border-strong\)\]{background-color:var(--color-border-strong)}.bg-\[var\(--color-danger\)\]{background-color:var(--color-danger)}.bg-\[var\(--color-danger\,\#e53e3e\)\],.bg-\[var\(--color-danger\,\#e53e3e\)\]\/15{background-color:var(--color-danger,#e53e3e)}@supports (color:color-mix(in lab,red,red)){.bg-\[var\(--color-danger\,\#e53e3e\)\]\/15{background-color:color-mix(in oklab,var(--color-danger,#e53e3e) 15%,transparent)}}.bg-\[var\(--color-primary\)\]{background-color:var(--color-primary)}.bg-\[var\(--color-primary\,\#6C63FF\)\]{background-color:var(--color-primary,#6c63ff)}.bg-\[var\(--color-surface\)\]{background-color:var(--color-surface)}.bg-\[var\(--color-surface-elevated\)\]{background-color:var(--color-surface-elevated)}.bg-\[var\(--color-surface-elevated\,var\(--color-surface\)\)\]{background-color:var(--color-surface-elevated,var(--color-surface))}.bg-black{background-color:var(--color-black)}.bg-black\/35{background-color:#00000059}@supports (color:color-mix(in lab,red,red)){.bg-black\/35{background-color:color-mix(in oklab,var(--color-black) 35%,transparent)}}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab,red,red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black) 40%,transparent)}}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-black\/60{background-color:#0009}@supports (color:color-mix(in lab,red,red)){.bg-black\/60{background-color:color-mix(in oklab,var(--color-black) 60%,transparent)}}.bg-black\/70{background-color:#000000b3}@supports (color:color-mix(in lab,red,red)){.bg-black\/70{background-color:color-mix(in oklab,var(--color-black) 70%,transparent)}}.bg-black\/75{background-color:#000000bf}@supports (color:color-mix(in lab,red,red)){.bg-black\/75{background-color:color-mix(in oklab,var(--color-black) 75%,transparent)}}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:color-mix(in oklab,var(--color-black) 80%,transparent)}}.bg-black\/92{background-color:#000000eb}@supports (color:color-mix(in lab,red,red)){.bg-black\/92{background-color:color-mix(in oklab,var(--color-black) 92%,transparent)}}.bg-black\/95{background-color:#000000f2}@supports (color:color-mix(in lab,red,red)){.bg-black\/95{background-color:color-mix(in oklab,var(--color-black) 95%,transparent)}}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.bg-white\/15{background-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.bg-white\/15{background-color:color-mix(in oklab,var(--color-white) 15%,transparent)}}.bg-white\/\[0\.04\]{background-color:#ffffff0a}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.04\]{background-color:color-mix(in oklab,var(--color-white) 4%,transparent)}}.bg-white\/\[0\.06\]{background-color:#ffffff0f}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.06\]{background-color:color-mix(in oklab,var(--color-white) 6%,transparent)}}.bg-white\/\[0\.08\]{background-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.bg-white\/\[0\.08\]{background-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-t{--tw-gradient-position:to top in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-none{background-image:none}.from-\[\#6C63FF\]{--tw-gradient-from:#6c63ff;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[\#667eea\]{--tw-gradient-from:#667eea;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[\#f59e0b\]{--tw-gradient-from:#f59e0b;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[var\(--color-bg-secondary\)\]{--tw-gradient-from:var(--color-bg-secondary);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[var\(--color-primary\)\]{--tw-gradient-from:var(--color-primary);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-black\/65{--tw-gradient-from:#000000a6}@supports (color:color-mix(in lab,red,red)){.from-black\/65{--tw-gradient-from:color-mix(in oklab, var(--color-black) 65%, transparent)}}.from-black\/65{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[\#764ba2\]{--tw-gradient-to:#764ba2;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[\#897CFF\]{--tw-gradient-to:#897cff;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[\#d97706\]{--tw-gradient-to:#d97706;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[var\(--color-bg-tertiary\)\]{--tw-gradient-to:var(--color-bg-tertiary);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[var\(--color-secondary\)\]{--tw-gradient-to:var(--color-secondary);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.p-0{padding:calc(var(--spacing) * 0)}.p-0\.5{padding:calc(var(--spacing) * .5)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.p-10{padding:calc(var(--spacing) * 10)}.p-12{padding:calc(var(--spacing) * 12)}.p-\[3px\]{padding:3px}.\!px-2{padding-inline:calc(var(--spacing) * 2)!important}.px-0\.5{padding-inline:calc(var(--spacing) * .5)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-3\.5{padding-inline:calc(var(--spacing) * 3.5)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-8{padding-inline:calc(var(--spacing) * 8)}.px-10{padding-inline:calc(var(--spacing) * 10)}.\!py-1{padding-block:calc(var(--spacing) * 1)!important}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-3\.5{padding-block:calc(var(--spacing) * 3.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-10{padding-block:calc(var(--spacing) * 10)}.py-12{padding-block:calc(var(--spacing) * 12)}.py-16{padding-block:calc(var(--spacing) * 16)}.py-px{padding-block:1px}.pt-0\.5{padding-top:calc(var(--spacing) * .5)}.pt-1{padding-top:calc(var(--spacing) * 1)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-5{padding-top:calc(var(--spacing) * 5)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.pb-3\.5{padding-bottom:calc(var(--spacing) * 3.5)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.pl-2{padding-left:calc(var(--spacing) * 2)}.pl-5{padding-left:calc(var(--spacing) * 5)}.pl-\[38px\]{padding-left:38px}.text-center{text-align:center}.text-left{text-align:left}.font-\[inherit\]{font-family:inherit}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.\!text-\[0\.8rem\]{font-size:.8rem!important}.text-\[0\.6rem\]{font-size:.6rem}.text-\[0\.7rem\]{font-size:.7rem}.text-\[0\.8rem\]{font-size:.8rem}.text-\[0\.9rem\]{font-size:.9rem}.text-\[0\.65rem\]{font-size:.65rem}.text-\[0\.72rem\]{font-size:.72rem}.text-\[0\.75rem\]{font-size:.75rem}.text-\[0\.78rem\]{font-size:.78rem}.text-\[0\.82rem\]{font-size:.82rem}.text-\[0\.85rem\]{font-size:.85rem}.text-\[0\.87rem\]{font-size:.87rem}.text-\[0\.95rem\]{font-size:.95rem}.text-\[0\.825rem\]{font-size:.825rem}.text-\[0\.875rem\]{font-size:.875rem}.text-\[0\.8125rem\]{font-size:.8125rem}.text-\[0\.9375rem\]{font-size:.9375rem}.text-\[1\.1rem\]{font-size:1.1rem}.text-\[1\.2rem\]{font-size:1.2rem}.text-\[1\.4rem\]{font-size:1.4rem}.text-\[1\.15rem\]{font-size:1.15rem}.text-\[2\.2rem\]{font-size:2.2rem}.text-\[2\.5rem\]{font-size:2.5rem}.text-\[2rem\]{font-size:2rem}.text-\[3rem\]{font-size:3rem}.text-\[4rem\]{font-size:4rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[13px\]{font-size:13px}.text-\[15px\]{font-size:15px}.text-\[28px\]{font-size:28px}.leading-\[1\.45\]{--tw-leading:1.45;line-height:1.45}.leading-none{--tw-leading:1;line-height:1}.leading-normal{--tw-leading:var(--leading-normal);line-height:var(--leading-normal)}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.text-ellipsis{text-overflow:ellipsis}.whitespace-normal{white-space:normal}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.\!text-\[var\(--color-text-tertiary\)\]{color:var(--color-text-tertiary)!important}.\!text-transparent{color:#0000!important}.text-\[\#1a1a2e\]{color:#1a1a2e}.text-\[\#1d1d1f\]{color:#1d1d1f}.text-\[\#1d1d1f\]\!{color:#1d1d1f!important}.text-\[\#1f2937\]{color:#1f2937}.text-\[\#4b5563\]{color:#4b5563}.text-\[\#6b7280\]{color:#6b7280}.text-\[\#007aff\]{color:#007aff}.text-\[\#8e8e93\]{color:#8e8e93}.text-\[\#34c759\]{color:#34c759}.text-\[\#333\]{color:#333}.text-\[\#721c24\]{color:#721c24}.text-\[\#888\]{color:#888}.text-\[\#897CFF\]{color:#897cff}.text-\[\#86868b\]{color:#86868b}.text-\[\#155724\]{color:#155724}.text-\[\#374151\]{color:#374151}.text-\[\#EF4444\]{color:#ef4444}.text-\[\#FFC107\]{color:#ffc107}.text-\[\#a855f7\]{color:#a855f7}.text-\[\#aaa\]{color:#aaa}.text-\[\#af52de\]{color:#af52de}.text-\[\#dc2626\]{color:#dc2626}.text-\[\#ff3b30\]{color:#ff3b30}.text-\[\#ff9f0a\]{color:#ff9f0a}.text-\[inherit\]{color:inherit}.text-\[var\(--color-accent\)\]{color:var(--color-accent)}.text-\[var\(--color-danger\)\]{color:var(--color-danger)}.text-\[var\(--color-error\)\]{color:var(--color-error)}.text-\[var\(--color-primary\,\#6C63FF\)\]{color:var(--color-primary,#6c63ff)}.text-\[var\(--color-success\)\]{color:var(--color-success)}.text-\[var\(--color-success\,\#34c759\)\]{color:var(--color-success,#34c759)}.text-\[var\(--color-text\)\]{color:var(--color-text)}.text-\[var\(--color-text-primary\)\]{color:var(--color-text-primary)}.text-\[var\(--color-text-secondary\)\]{color:var(--color-text-secondary)}.text-\[var\(--color-text-tertiary\)\]{color:var(--color-text-tertiary)}.text-\[var\(--color-text-tertiary\,\#666\)\]{color:var(--color-text-tertiary,#666)}.text-\[var\(--color-warning\)\]{color:var(--color-warning)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-inherit{color:inherit}.text-white{color:var(--color-white)}.text-white\/20{color:#fff3}@supports (color:color-mix(in lab,red,red)){.text-white\/20{color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.text-white\/30{color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.text-white\/30{color:color-mix(in oklab,var(--color-white) 30%,transparent)}}.text-white\/40{color:#fff6}@supports (color:color-mix(in lab,red,red)){.text-white\/40{color:color-mix(in oklab,var(--color-white) 40%,transparent)}}.text-white\/50{color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.text-white\/50{color:color-mix(in oklab,var(--color-white) 50%,transparent)}}.text-white\/60{color:#fff9}@supports (color:color-mix(in lab,red,red)){.text-white\/60{color:color-mix(in oklab,var(--color-white) 60%,transparent)}}.text-white\/70{color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.text-white\/70{color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.text-white\/75{color:#ffffffbf}@supports (color:color-mix(in lab,red,red)){.text-white\/75{color:color-mix(in oklab,var(--color-white) 75%,transparent)}}.text-white\/80{color:#fffc}@supports (color:color-mix(in lab,red,red)){.text-white\/80{color:color-mix(in oklab,var(--color-white) 80%,transparent)}}.text-white\/85{color:#ffffffd9}@supports (color:color-mix(in lab,red,red)){.text-white\/85{color:color-mix(in oklab,var(--color-white) 85%,transparent)}}.text-white\/90{color:#ffffffe6}@supports (color:color-mix(in lab,red,red)){.text-white\/90{color:color-mix(in oklab,var(--color-white) 90%,transparent)}}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.\!italic{font-style:italic!important}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.no-underline{text-decoration-line:none}.underline{text-decoration-line:underline}.underline-offset-2{text-underline-offset:2px}.accent-\[\#0071e3\]{accent-color:#0071e3}.accent-\[var\(--color-accent\)\]{accent-color:var(--color-accent)}.\!opacity-90{opacity:.9!important}.\!opacity-100{opacity:1!important}.opacity-0{opacity:0}.opacity-30{opacity:.3}.opacity-35{opacity:.35}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-55{opacity:.55}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-80{opacity:.8}.opacity-90{opacity:.9}.opacity-95{opacity:.95}.opacity-100{opacity:1}.shadow-\[0_0_0_3px_rgba\(0\,113\,227\,0\.15\)\]{--tw-shadow:0 0 0 3px var(--tw-shadow-color,#0071e326);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_0_12px_rgba\(99\,102\,241\,0\.3\)\]{--tw-shadow:0 0 12px var(--tw-shadow-color,#6366f14d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_1px_2px_rgba\(0\,0\,0\,0\.1\)\]{--tw-shadow:0 1px 2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_1px_3px_rgba\(0\,0\,0\,0\.1\)\]{--tw-shadow:0 1px 3px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_1px_3px_rgba\(0\,0\,0\,0\.12\)\]{--tw-shadow:0 1px 3px var(--tw-shadow-color,#0000001f);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_2px_8px_rgba\(0\,0\,0\,0\.15\)\]{--tw-shadow:0 2px 8px var(--tw-shadow-color,#00000026);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_2px_12px_rgba\(245\,158\,11\,0\.4\)\]{--tw-shadow:0 2px 12px var(--tw-shadow-color,#f59e0b66);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_4px_16px_rgba\(0\,0\,0\,0\.25\)\]{--tw-shadow:0 4px 16px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_8px_32px_rgba\(0\,0\,0\,0\.3\)\]{--tw-shadow:0 8px 32px var(--tw-shadow-color,#0000004d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_8px_32px_rgba\(0\,0\,0\,0\.12\)\]{--tw-shadow:0 8px 32px var(--tw-shadow-color,#0000001f);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_8px_40px_rgba\(0\,0\,0\,0\.5\)\]{--tw-shadow:0 8px 40px var(--tw-shadow-color,#00000080);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_10px_40px_rgba\(0\,0\,0\,0\.5\)\]{--tw-shadow:0 10px 40px var(--tw-shadow-color,#00000080);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_12px_40px_rgba\(0\,0\,0\,0\.15\)\]{--tw-shadow:0 12px 40px var(--tw-shadow-color,#00000026);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_20px_60px_rgba\(0\,0\,0\,0\.3\)\]{--tw-shadow:0 20px 60px var(--tw-shadow-color,#0000004d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_20px_60px_rgba\(0\,0\,0\,0\.4\)\]{--tw-shadow:0 20px 60px var(--tw-shadow-color,#0006);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_24px_48px_rgba\(0\,0\,0\,0\.2\)\]{--tw-shadow:0 24px 48px var(--tw-shadow-color,#0003);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--shadow-md\)\]{--tw-shadow:var(--shadow-md);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--shadow-sm\)\]{--tw-shadow:var(--shadow-sm);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--shadow-xl\)\]{--tw-shadow:var(--shadow-xl);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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,)}.drop-shadow-\[0_2px_8px_rgba\(0\,0\,0\,0\.5\)\]{--tw-drop-shadow-size:drop-shadow(0 2px 8px var(--tw-drop-shadow-color,#00000080));--tw-drop-shadow:var(--tw-drop-shadow-size);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-\[8px\]{--tw-backdrop-blur:blur(8px);-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,)}.backdrop-blur-\[16px\]{--tw-backdrop-blur:blur(16px);-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,)}.backdrop-blur-\[20px\]{--tw-backdrop-blur:blur(20px);-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,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-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,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[width\]{transition-property:width;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-250{--tw-duration:.25s;transition-duration:.25s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.\[scrollbar-color\:rgba\(255\,255\,255\,0\.1\)_transparent\]{scrollbar-color:#ffffff1a transparent}.\[scrollbar-width\:thin\]{scrollbar-width:thin}@media(hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *),.group-hover\/char\:opacity-100:is(:where(.group\/char):hover *),.group-hover\/item\:opacity-100:is(:where(.group\/item):hover *),.group-hover\/shot\:opacity-100:is(:where(.group\/shot):hover *){opacity:1}}.peer-checked\:bg-\[var\(--color-success\)\]:is(:where(.peer):checked~*){background-color:var(--color-success)}.placeholder\:text-\[var\(--color-text-tertiary\)\]::placeholder{color:var(--color-text-tertiary)}.before\:absolute:before{content:var(--tw-content);position:absolute}.before\:top-0\.5:before{content:var(--tw-content);top:calc(var(--spacing) * .5)}.before\:left-0\.5:before{content:var(--tw-content);left:calc(var(--spacing) * .5)}.before\:h-5:before{content:var(--tw-content);height:calc(var(--spacing) * 5)}.before\:w-5:before{content:var(--tw-content);width:calc(var(--spacing) * 5)}.before\:rounded-full:before{content:var(--tw-content);border-radius:var(--radius-full)}.before\:bg-white:before{content:var(--tw-content);background-color:var(--color-white)}.before\:shadow-\[var\(--shadow-sm\)\]:before{content:var(--tw-content);--tw-shadow:var(--shadow-sm);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.before\:transition-transform:before{content:var(--tw-content);transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.before\:content-\[\'\'\]:before{--tw-content:"";content:var(--tw-content)}.peer-checked\:before\:translate-x-4:is(:where(.peer):checked~*):before{content:var(--tw-content);--tw-translate-x:calc(var(--spacing) * 4);translate:var(--tw-translate-x) var(--tw-translate-y)}.last\:mb-0:last-child{margin-bottom:calc(var(--spacing) * 0)}.last\:border-b-0:last-child{border-bottom-style:var(--tw-border-style);border-bottom-width:0}@media(hover:hover){.hover\:mx-\[-1rem\]:hover{margin-inline:-1rem}.hover\:-translate-x-1:hover{--tw-translate-x:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:translate-x-0\.5:hover{--tw-translate-x:calc(var(--spacing) * .5);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:-translate-y-0\.5:hover{--tw-translate-y:calc(var(--spacing) * -.5);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x) var(--tw-scale-y)}.hover\:scale-110:hover{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}.hover\:scale-\[1\.02\]:hover{scale:1.02}.hover\:scale-\[1\.15\]:hover{scale:1.15}.hover\:border-\[var\(--color-accent\)\]:hover{border-color:var(--color-accent)}.hover\:border-black\/20:hover{border-color:#0003}@supports (color:color-mix(in lab,red,red)){.hover\:border-black\/20:hover{border-color:color-mix(in oklab,var(--color-black) 20%,transparent)}}.hover\:border-white:hover{border-color:var(--color-white)}.hover\:border-white\/20:hover{border-color:#fff3}@supports (color:color-mix(in lab,red,red)){.hover\:border-white\/20:hover{border-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.hover\:border-white\/50:hover{border-color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.hover\:border-white\/50:hover{border-color:color-mix(in oklab,var(--color-white) 50%,transparent)}}.hover\:border-b-\[var\(--color-text-secondary\)\]:hover{border-bottom-color:var(--color-text-secondary)}.hover\:\!bg-\[rgba\(239\,68\,68\,0\.2\)\]:hover{background-color:#ef444433!important}.hover\:\!bg-\[var\(--color-danger\,\#e53e3e\)\]:hover{background-color:var(--color-danger,#e53e3e)!important}.hover\:bg-\[\#c53030\]:hover{background-color:#c53030}.hover\:bg-\[\#e5e5e5\]:hover{background-color:#e5e5e5}.hover\:bg-\[\#f0f1f5\]:hover{background-color:#f0f1f5}.hover\:bg-\[\#f3f4f6\]:hover{background-color:#f3f4f6}.hover\:bg-\[rgba\(0\,113\,227\,0\.1\)\]:hover{background-color:#0071e31a}.hover\:bg-\[rgba\(0\,113\,227\,0\.3\)\]:hover{background-color:#0071e34d}.hover\:bg-\[rgba\(0\,113\,227\,0\.7\)\]:hover{background-color:#0071e3b3}.hover\:bg-\[rgba\(26\,26\,46\,0\.35\)\]:hover{background-color:#1a1a2e59}.hover\:bg-\[rgba\(239\,68\,68\,0\.6\)\]:hover{background-color:#ef444499}.hover\:bg-\[rgba\(255\,59\,48\,0\.1\)\]:hover{background-color:#ff3b301a}.hover\:bg-\[rgba\(255\,59\,48\,0\.2\)\]:hover{background-color:#ff3b3033}.hover\:bg-\[var\(--color-accent-hover\)\]:hover{background-color:var(--color-accent-hover)}.hover\:bg-\[var\(--color-bg\)\]:hover{background-color:var(--color-bg)}.hover\:bg-\[var\(--color-bg-hover\)\]:hover{background-color:var(--color-bg-hover)}.hover\:bg-\[var\(--color-bg-secondary\)\]:hover{background-color:var(--color-bg-secondary)}.hover\:bg-\[var\(--color-bg-tertiary\)\]:hover{background-color:var(--color-bg-tertiary)}.hover\:bg-\[var\(--color-border\)\]:hover{background-color:var(--color-border)}.hover\:bg-\[var\(--color-border-strong\)\]:hover{background-color:var(--color-border-strong)}.hover\:bg-\[var\(--color-primary\)\]:hover{background-color:var(--color-primary)}.hover\:bg-black\/60:hover{background-color:#0009}@supports (color:color-mix(in lab,red,red)){.hover\:bg-black\/60:hover{background-color:color-mix(in oklab,var(--color-black) 60%,transparent)}}.hover\:bg-white\/15:hover{background-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/15:hover{background-color:color-mix(in oklab,var(--color-white) 15%,transparent)}}.hover\:bg-white\/20:hover{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/20:hover{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.hover\:bg-white\/25:hover{background-color:#ffffff40}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/25:hover{background-color:color-mix(in oklab,var(--color-white) 25%,transparent)}}.hover\:bg-white\/\[0\.08\]:hover{background-color:#ffffff14}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.08\]:hover{background-color:color-mix(in oklab,var(--color-white) 8%,transparent)}}.hover\:bg-white\/\[0\.12\]:hover{background-color:#ffffff1f}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/\[0\.12\]:hover{background-color:color-mix(in oklab,var(--color-white) 12%,transparent)}}.hover\:px-4:hover{padding-inline:calc(var(--spacing) * 4)}.hover\:text-\[\#1d1d1f\]:hover{color:#1d1d1f}.hover\:text-\[\#ff453a\]:hover{color:#ff453a}.hover\:text-\[var\(--color-accent\)\]:hover{color:var(--color-accent)}.hover\:text-\[var\(--color-error\)\]:hover{color:var(--color-error)}.hover\:text-\[var\(--color-text\)\]:hover{color:var(--color-text)}.hover\:text-\[var\(--color-text-primary\)\]:hover{color:var(--color-text-primary)}.hover\:text-white:hover,.hover\:text-white\/100:hover{color:var(--color-white)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-55:hover{opacity:.55}.hover\:opacity-70:hover{opacity:.7}.hover\:opacity-80:hover{opacity:.8}.hover\:opacity-85:hover{opacity:.85}.hover\:opacity-95:hover{opacity:.95}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-\[0_2px_6px_rgba\(0\,0\,0\,0\.2\)\]:hover{--tw-shadow:0 2px 6px var(--tw-shadow-color,#0003);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-\[0_2px_8px_rgba\(0\,113\,227\,0\.1\)\]:hover{--tw-shadow:0 2px 8px var(--tw-shadow-color,#0071e31a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-\[0_4px_12px_rgba\(0\,0\,0\,0\.2\)\]:hover{--tw-shadow:0 4px 12px var(--tw-shadow-color,#0003);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-\[0_4px_12px_rgba\(0\,0\,0\,0\.25\)\]:hover{--tw-shadow:0 4px 12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-\[0_4px_20px_rgba\(108\,99\,255\,0\.08\)\]:hover{--tw-shadow:0 4px 20px var(--tw-shadow-color,#6c63ff14);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-\[0_12px_40px_rgba\(0\,0\,0\,0\.16\)\]:hover{--tw-shadow:0 12px 40px var(--tw-shadow-color,#00000029);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-\[var\(--shadow-lg\)\]:hover{--tw-shadow:var(--shadow-lg);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:brightness-90:hover{--tw-brightness:brightness(90%);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,)}.hover\:not-disabled\:scale-\[1\.02\]:hover:not(:disabled){scale:1.02}.hover\:not-disabled\:bg-\[var\(--color-accent-hover\)\]:hover:not(:disabled){background-color:var(--color-accent-hover)}.hover\:not-disabled\:bg-\[var\(--color-border\)\]:hover:not(:disabled){background-color:var(--color-border)}}.focus\:border-\[\#0071e3\]:focus{border-color:#0071e3}.focus\:border-\[var\(--color-accent\)\]:focus{border-color:var(--color-accent)}.focus\:border-\[var\(--color-primary\)\]:focus{border-color:var(--color-primary)}.focus\:bg-\[var\(--color-surface\)\]:focus{background-color:var(--color-surface)}.focus\:shadow-\[0_0_0_3px_rgba\(0\,113\,227\,0\.12\)\]:focus{--tw-shadow:0 0 0 3px var(--tw-shadow-color,#0071e31f);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:shadow-\[0_0_0_3px_rgba\(0\,113\,227\,0\.15\)\]:focus{--tw-shadow:0 0 0 3px var(--tw-shadow-color,#0071e326);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.active\:scale-\[0\.98\]:active{scale:.98}@media(hover:hover){.hover\:enabled\:bg-white\/10:hover:enabled{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.hover\:enabled\:bg-white\/10:hover:enabled{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.hover\:enabled\:text-white:hover:enabled{color:var(--color-white)}}.disabled\:transform-none:disabled{transform:none}.disabled\:cursor-default:disabled{cursor:default}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-15:disabled{opacity:.15}.disabled\:opacity-20:disabled{opacity:.2}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}@media not all and (min-width:1200px){.max-\[1200px\]\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media not all and (min-width:900px){.max-\[900px\]\:w-full{width:100%}.max-\[900px\]\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.max-\[900px\]\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.max-\[900px\]\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.max-\[900px\]\:flex-col{flex-direction:column}.max-\[900px\]\:items-start{align-items:flex-start}.max-\[900px\]\:gap-3{gap:calc(var(--spacing) * 3)}}@media not all and (min-width:800px){.max-\[800px\]\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media not all and (min-width:768px){.max-\[768px\]\:w-full{width:100%}.max-\[768px\]\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.max-\[768px\]\:flex-col{flex-direction:column}.max-\[768px\]\:gap-3{gap:calc(var(--spacing) * 3)}}@media not all and (min-width:600px){.max-\[600px\]\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.dark\:border-\[rgba\(255\,255\,255\,0\.1\)\]:where([data-theme=dark],[data-theme=dark] *){border-color:#ffffff1a}.dark\:bg-\[rgba\(40\,40\,40\,0\.95\)\]:where([data-theme=dark],[data-theme=dark] *){background-color:#282828f2}.\[\&_\.fv\]\:min-h-\[5\.6em\] .fv{min-height:5.6em}.\[\&_\.section-fields-inner\]\:opacity-40 .section-fields-inner{opacity:.4}.\[\&_input\]\:pointer-events-none input{pointer-events:none}.\[\&_input\]\:cursor-default input{cursor:default}.\[\&_input\:focus\]\:border-\[var\(--color-border\)\] input:focus{border-color:var(--color-border)}.\[\&_input\:focus\]\:shadow-none input:focus{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.\[\&_select\]\:pointer-events-none select{pointer-events:none}.\[\&_select\]\:cursor-default select{cursor:default}.\[\&_select\:focus\]\:border-\[var\(--color-border\)\] select:focus{border-color:var(--color-border)}.\[\&_select\:focus\]\:shadow-none select:focus{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.\[\&_textarea\]\:pointer-events-none textarea{pointer-events:none}.\[\&_textarea\]\:cursor-default textarea{cursor:default}.\[\&_textarea\:focus\]\:border-\[var\(--color-border\)\] textarea:focus{border-color:var(--color-border)}.\[\&_textarea\:focus\]\:shadow-none textarea:focus{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.\[\&\>\.fe\]\:opacity-35>.fe,.\[\&\>\.field-val\]\:opacity-35>.field-val,.\[\&\>\.fv\]\:opacity-35>.fv{opacity:.35}@media not all and (min-width:900px){.max-\[900px\]\:\[\&\>button\]\:flex-1>button{flex:1}}.\[\&\>label\]\:mb-2>label{margin-bottom:calc(var(--spacing) * 2)}.\[\&\>label\]\:block>label{display:block}.\[\&\>label\]\:text-\[0\.85rem\]>label{font-size:.85rem}.\[\&\>label\]\:text-\[var\(--color-text-secondary\)\]>label{color:var(--color-text-secondary)}.\[\&\>label\]\:opacity-35>label{opacity:.35}}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes simBarIn{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes checkPop{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95)translateY(-10px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes fullscreenFadeIn{0%{opacity:0}to{opacity:1}}@keyframes fullscreenZoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes confirmPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes promptSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spe-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes spe-toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}body:has(.simulation-bar) .app-layout,body:has(.simulation-bar) .project-layout{margin-top:40px}@keyframes spFadeIn{0%{opacity:0}to{opacity:1}}@keyframes spImageIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.project-gallery-view h2{margin-bottom:1.5rem}.project-gallery-filters{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.project-gallery-filters select{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:6px;min-width:150px;padding:.5rem 1rem}.favorites-filter{cursor:pointer;align-items:center;gap:.5rem;display:flex}.gallery-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:transform .2s;position:relative;overflow:hidden}.gallery-card:hover{transform:scale(1.02)}.gallery-card img{cursor:pointer;width:100%;height:auto}.gallery-card-badge{color:#fff;z-index:2;opacity:.85;pointer-events:none;background:#00000080;border-radius:8px;padding:.125rem .5rem;font-size:.65rem;position:absolute;top:8px;left:8px}.gallery-card-fav-badge{filter:drop-shadow(0 1px 3px #00000080);z-index:2;pointer-events:none;font-size:1.1rem;position:absolute;top:8px;right:8px}.gallery-card-info-btn{z-index:3;cursor:pointer;opacity:0;background:#00000073;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;transition:opacity .2s;display:flex;position:absolute;bottom:42px;left:8px}.gallery-card:hover .gallery-card-info-btn{opacity:1}.gallery-card-info-btn:hover{background:#000000b3}.gallery-card-actions{justify-content:flex-end;gap:.25rem;padding:.4rem .5rem;display:flex}.gallery-card-actions .btn-icon{cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:4px;padding:.25rem .4rem;font-size:1rem;transition:background .15s}.gallery-card-actions .btn-icon:hover{background:var(--color-border);opacity:1}.gallery-card-actions .btn-icon.active{opacity:1}.gallery-card-actions .btn-icon.danger:hover{background:#dc262633}.gallery-card-prompt{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;padding:.5rem;font-size:.75rem;overflow:hidden}.gallery-media-tabs{background:var(--color-bg-secondary);border-radius:var(--radius-full,20px);gap:.25rem;width:fit-content;margin-bottom:.5rem;padding:3px;display:flex}.media-tab{border-radius:var(--radius-full,18px);color:var(--color-text-secondary);font-family:inherit;font-size:var(--font-size-sm,.85rem);cursor:pointer;background:0 0;border:none;padding:.4rem 1rem;font-weight:500;transition:all .2s}.media-tab:hover{color:var(--color-text-primary)}.media-tab.active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:0 1px 3px #0000001a}.video-card video{width:100%;height:auto;display:block}.gallery-card-info{color:var(--color-text-secondary);align-items:center;gap:.5rem;padding:.4rem .5rem;font-size:.75rem;display:flex}.video-label{color:var(--color-text-primary);font-weight:600}.video-duration{background:var(--color-bg-secondary);border-radius:4px;padding:.1rem .4rem;font-size:.7rem}.video-play-overlay{color:#fff;pointer-events:none;background:#00000080;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;transition:background .2s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-70%)}.video-card:hover .video-play-overlay{background:#000000b3}.loading{text-align:center;color:var(--color-text-secondary);padding:2rem}.dashboard-new{background:var(--color-bg);flex-direction:column;height:calc(100vh - 36px);display:flex;overflow:hidden}.dashboard-header{background:var(--color-surface-elevated);border-bottom:1px solid var(--color-border);align-items:center;gap:1rem;padding:1rem 2rem;display:flex}.dashboard-header h1{flex:1;font-size:1.25rem;font-weight:600}.header-stats{gap:1rem;display:flex}.header-stats .stat{color:var(--color-text-secondary);font-size:.875rem}.theme-toggle{cursor:pointer;opacity:.7;background:0 0;border:none;align-self:center;align-items:center;padding:.25rem;font-size:1.25rem;line-height:1;transition:opacity .15s,transform .15s;display:flex}.theme-toggle:hover{opacity:1;transform:scale(1.15)}.dashboard-body{flex:1;display:flex;position:relative;overflow:hidden}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;transition:width 50ms;display:flex;position:relative;overflow:hidden}.sidebar::-webkit-scrollbar{display:none}.sidebar-nav{flex-shrink:0}.sidebar-tree{scrollbar-width:none;-ms-overflow-style:none;flex:1;min-height:0;overflow-y:auto}.sidebar-tree::-webkit-scrollbar{display:none}.sidebar>.sidebar-section-bottom{flex-shrink:0}.sidebar.collapsed{border-right:none;min-width:0;overflow:hidden;width:0!important}.sidebar-resize-handle{cursor:col-resize;z-index:10;width:4px;height:100%;transition:background .15s;position:absolute;top:0;right:0}.sidebar-resize-handle:hover{background:var(--color-accent)}.sidebar-toggle{z-index:20;border:1px solid var(--color-border);background:var(--color-surface-elevated);width:24px;height:24px;color:var(--color-text-tertiary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:9px;transition:all .25s;display:flex;position:absolute;top:12px;box-shadow:0 1px 4px #0000001a}.sidebar-toggle:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent);transform:scale(1.15)}.sidebar-section{border-bottom:1px solid var(--color-border);padding:.5rem}.sidebar-section-bottom{border-top:1px solid var(--color-border);margin-top:auto;padding:.5rem}.sidebar-section-header{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;padding:.75rem;font-size:.75rem;font-weight:600;display:flex}.sidebar-item{cursor:pointer;color:var(--color-text-primary);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:background .15s;display:flex}.sidebar-item:hover{background:var(--color-surface-elevated)}.sidebar-item.active{color:var(--color-accent);background:#3b82f626}.sidebar-item .icon{font-size:1.25rem}.sidebar-item.small{padding:.5rem 1rem;font-size:.875rem}.sidebar-item .char-nick{color:var(--color-accent);min-width:60px;font-size:.75rem}.sidebar-item.character-item{align-items:center;gap:.5rem;display:flex}.char-sidebar-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:24px;height:24px}.char-sidebar-no-avatar{background:var(--color-surface-elevated);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex}.character-item .char-nick{flex:1}.sidebar-item .delete-char{opacity:0;width:18px;height:18px;color:var(--color-text-tertiary);font-size:10px;transition:opacity .2s,color .2s}.sidebar-item:hover .delete-char{opacity:.6}.sidebar-item .delete-char:hover{opacity:1;color:var(--color-danger)}.expand-toggle{color:var(--color-text-tertiary);cursor:pointer;padding:.25rem;font-size:.6rem;transition:transform .2s;display:inline-block}.expand-toggle.expanded{transform:rotate(90deg)}.expand-toggle:hover{color:var(--color-text-primary)}.sidebar-scene{margin-left:0}.sidebar-scene .scene-number{min-width:35px;color:var(--color-accent);font-weight:600}.sidebar-scene .scene-title{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.875rem;overflow:hidden}.sidebar-scene .scene-shots-count{background:var(--color-surface-elevated);color:var(--color-text-secondary);border-radius:10px;padding:.125rem .5rem;font-size:.75rem}.sidebar-scene .scene-duration{color:var(--color-text-tertiary);text-align:right;min-width:35px;font-size:.7rem}.sidebar-scene .scene-chrono{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.7rem;overflow:hidden}.sidebar-sequences{border-left:2px solid var(--color-border);margin-left:1rem;padding-bottom:.25rem;padding-left:0}.sidebar-sequence-container{margin-bottom:1px}.sidebar-sequence{cursor:pointer;color:var(--color-text-primary);border-radius:6px;align-items:center;gap:.4rem;padding:.35rem .5rem;font-size:.8rem;transition:background .15s;display:flex}.sidebar-sequence:hover{background:var(--color-surface-elevated)}.sidebar-sequence.active{color:var(--color-accent);background:#3b82f626}.sidebar-sequence .seq-number{min-width:30px;color:var(--color-accent);white-space:nowrap;font-size:.8rem;font-weight:600}.sidebar-sequence.active .seq-number{color:var(--color-accent)}.sidebar-sequence .seq-duration{color:var(--color-text-tertiary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.7rem;overflow:hidden}.sidebar-sequence .seq-shots-count{background:var(--color-surface-elevated);color:var(--color-text-secondary);border-radius:10px;padding:.125rem .5rem;font-size:.7rem}.sidebar-empty-hint{color:var(--color-text-tertiary);padding:.5rem .75rem;font-size:.75rem;font-style:italic}.btn-delete-small{opacity:0;width:18px;height:18px;color:var(--color-text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;margin-left:auto;font-size:14px;transition:all .15s;display:flex}.sidebar-item:hover .btn-delete-small,.sidebar-shot:hover .btn-delete-small{opacity:1}.btn-delete-small:hover{color:#ff3b30;background:#ff3b3026}.btn-move{opacity:0;width:16px;height:16px;color:var(--color-text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:0;font-size:8px;transition:all .15s;display:flex}.btn-move:hover{color:var(--color-accent);background:#3b82f626}.sidebar-actions{flex-shrink:0;align-items:center;gap:1px;margin-left:auto;display:flex}.sidebar-item:hover .sidebar-actions .btn-move,.sidebar-item:hover .sidebar-actions .btn-delete-small,.sidebar-sequence:hover .sidebar-actions .btn-move,.sidebar-sequence:hover .sidebar-actions .btn-delete-small,.sidebar-shot:hover .sidebar-actions .btn-move,.sidebar-shot:hover .sidebar-actions .btn-delete-small{opacity:.7}.sidebar-actions .btn-move:hover,.sidebar-actions .btn-delete-small:hover{opacity:1!important}.btn-add-inline{border:1px dashed var(--color-border);width:100%;color:var(--color-text-tertiary);cursor:pointer;text-align:center;opacity:0;background:0 0;border-radius:6px;margin-top:.25rem;padding:.25rem .5rem;font-size:.7rem;transition:all .15s}.sidebar-sequences:hover .btn-add-inline,.sidebar-shots:hover .btn-add-inline{opacity:.6}.btn-add-inline:hover{border-color:var(--color-accent);color:var(--color-accent);background:#3b82f60d;opacity:1!important}.sidebar-shots{border-left:2px solid var(--color-border);margin-left:1rem;padding-left:.5rem}.sidebar-shot{cursor:pointer;color:var(--color-text-secondary);border-radius:6px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;transition:background .15s;display:flex}.sidebar-shot:hover{background:var(--color-surface-elevated)}.sidebar-shot.active{color:var(--color-accent);background:#3b82f626}.sidebar-shot .shot-duration{color:var(--color-text-tertiary);font-size:.75rem}.sidebar-shot .drag-handle{opacity:0;cursor:grab;color:var(--color-text-tertiary);-webkit-user-select:none;user-select:none;flex-shrink:0;padding:0 2px;font-size:.7rem;transition:opacity .15s}.sidebar-shot:hover .drag-handle{opacity:.6}.sidebar-shot .drag-handle:hover{opacity:1;color:var(--color-accent)}.sidebar-shot .drag-handle:active{cursor:grabbing}.sidebar-shot.dragging{opacity:.35;background:var(--color-surface-elevated)}.drag-insert-line{background:var(--color-accent);pointer-events:none;border-radius:2px;height:3px;margin:1px 0;box-shadow:0 0 6px #3b82f680}.done-badge{background:#22c55e;border-radius:50%;width:16px;height:16px;margin-left:.25rem;display:inline-block;position:relative}.done-badge:before{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:4px;height:8px;position:absolute;top:3px;left:5px;transform:rotate(45deg)}.main-content{flex:1;padding:2rem;overflow-y:auto}.content-panel{max-width:900px;margin:0 auto}.panel-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.panel-header h2{font-size:1.5rem;font-weight:600}.panel-actions{gap:.5rem;display:flex}.script-textarea{background:var(--color-surface);border:1px solid var(--color-border);resize:vertical;width:100%;min-height:400px;color:var(--color-text-primary);border-radius:12px;margin-bottom:1rem;padding:1.5rem;font-family:SF Mono,Monaco,monospace;font-size:.9rem;line-height:1.6}.script-textarea::placeholder{color:var(--color-text-tertiary)}.script-textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #3b82f61a}.script-actions{text-align:center;margin-top:1rem;padding:2rem 0}.script-actions .hint{color:var(--color-text-secondary);margin-top:1rem;font-size:.875rem}.generation-progress{max-width:400px;margin:0 auto}.progress-bar{background:var(--color-surface-elevated);border-radius:6px;height:12px;margin-bottom:.75rem;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--color-accent),#8b5cf6);border-radius:6px;height:100%;transition:width .5s ease-out;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{50%{opacity:.5}}.progress-text{color:var(--color-text-secondary);text-align:center;font-size:.875rem}.scene-info{margin-bottom:2rem}.scene-info h4{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;font-size:.875rem;font-weight:600}.scene-script-text{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);white-space:pre-wrap;border-radius:8px;max-height:200px;padding:1rem;font-family:SF Mono,Monaco,monospace;font-size:.85rem;line-height:1.6;overflow-y:auto}.scene-script-textarea{background:var(--color-surface);border:1px solid var(--color-border);width:100%;min-height:200px;color:var(--color-text-primary);resize:vertical;border-radius:8px;padding:1rem;font-family:SF Mono,Monaco,monospace;font-size:.85rem;line-height:1.6}.scene-script-textarea:focus{border-color:var(--color-accent);outline:none}.scene-actions{gap:.75rem;margin-top:1rem;display:flex}.scene-total-duration{color:var(--color-text-secondary);background:var(--color-surface);border-radius:6px;padding:.25rem .75rem;font-size:.875rem}.scene-shots h4{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;font-size:.875rem;font-weight:600}.shots-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;display:grid}.shot-card{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;padding:1rem;transition:all .2s}.shot-card:hover{border-color:var(--color-accent);transform:translateY(-2px)}.shot-card-header{justify-content:space-between;margin-bottom:.5rem;font-weight:600;display:flex}.shot-synopsis-preview{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.875rem;line-height:1.5}.detail-block{margin-bottom:1.5rem}.detail-block h4{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;font-size:.875rem;font-weight:600}.synopsis-text{color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1rem;line-height:1.6}.detailed-text{color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-word;background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border:1px solid #3b82f61a;border-radius:8px;max-height:400px;padding:1rem;font-family:inherit;font-size:.875rem;line-height:1.6;overflow-y:auto}.shot-duration-badge{background:var(--color-surface);color:var(--color-text-secondary);border-radius:4px;padding:.25rem .75rem;font-size:.875rem}.meta-block{color:var(--color-text-secondary);background:var(--color-surface);border-radius:8px;grid-template-columns:1fr 1fr;gap:.5rem;padding:1rem;font-size:.875rem;display:grid}.shot-view{flex-direction:column;gap:1rem;display:flex}.shot-tabs{border-bottom:2px solid var(--color-border);gap:.5rem;padding-bottom:0;display:flex}.shot-tabs-instruments{border-bottom:none;align-items:center;gap:.25rem;padding-top:.25rem;padding-left:1.5rem}.shot-tabs-instruments .shot-tab{color:var(--color-text-tertiary);padding:.4rem .75rem;font-size:.8rem}.shot-tabs-label{color:var(--color-text-tertiary);white-space:nowrap;padding-right:.25rem;font-size:.75rem;font-weight:500}.shot-tab{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.5rem;margin-bottom:-2px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.shot-tab:hover{color:var(--color-text-primary);background:#3b82f60d}.shot-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.tab-check{color:#22c55e;font-size:.875rem}.shot-tab-content{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:12px;min-height:200px}.tab-panel{padding:1.5rem}.shot-textarea{border:1px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text-primary);resize:vertical;border-radius:8px;padding:1rem;font-family:inherit;font-size:.9rem;line-height:1.6}.shot-textarea.large{min-height:250px}.shot-textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #3b82f61a}.prompt-highlight-container{position:relative}.prompt-highlight-backdrop{color:#0000;white-space:pre-wrap;word-wrap:break-word;pointer-events:none;border:1px solid #0000;border-radius:8px;padding:1rem;font-family:inherit;font-size:.9rem;line-height:1.6;position:absolute;inset:0;overflow:auto}.prompt-highlight-backdrop .nickname-highlight{color:#0000;background:#ff980033;border-radius:3px;padding:0 2px}.prompt-highlight-textarea{z-index:1;position:relative;background:0 0!important}.tab-actions{gap:.75rem;margin-top:1rem;display:flex}.description-section{margin-bottom:1.5rem}.section-header-row{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.section-header-row h4{color:var(--color-text-primary);margin:0;font-size:.95rem;font-weight:600}.duration-badge{color:var(--color-accent);background:#3b82f61a;border-radius:20px;padding:.25rem .75rem;font-size:.8rem;font-weight:500}.shot-section{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.shot-section .section-header{border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,#3b82f614,#8b5cf614);align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.shot-section .section-number{background:var(--color-accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex}.shot-section .section-header h3{color:var(--color-text-primary);margin:0;font-size:.9rem;font-weight:600}.shot-section .section-content{padding:1rem}.section-empty{text-align:center;color:var(--color-text-secondary);padding:1.5rem}.section-empty p{margin-bottom:1rem}.location-info{color:var(--color-text-secondary);grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1.5rem;font-size:.875rem;display:grid}.location-step{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.location-step h4{color:var(--color-text-primary);margin-bottom:.75rem;font-size:.875rem;font-weight:600}.step-hint{color:var(--color-text-secondary);margin-bottom:1rem;font-size:.875rem;font-style:italic}.tab-panel>h3{margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.tab-panel>h3+.step-hint{margin-top:0;margin-bottom:1.25rem}.frame-panel h3{margin-bottom:.25rem}.frame-preview-section{margin:1rem 0}.preview-row{flex-wrap:wrap;gap:1.5rem;display:flex}.preview-item{flex:1;min-width:150px}.preview-item label{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.8rem;display:block}.preview-thumb{object-fit:cover;border-radius:8px;width:100%;max-width:200px;height:auto}.characters-list{flex-wrap:wrap;gap:.5rem;display:flex}.char-badge{background:var(--color-accent);color:#fff;border-radius:4px;padding:.25rem .5rem;font-size:.8rem;font-weight:500;display:inline-block}.char-info{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.5rem;display:flex}.char-ref-thumb{object-fit:cover;border-radius:50%;width:32px;height:32px}.char-desc-preview{color:var(--color-text-secondary);flex:1;font-size:.75rem}.no-location,.no-chars{color:var(--color-text-secondary);text-align:center;background:#8080801a;border-radius:8px;padding:1rem;font-style:italic}.location-preview{flex-direction:column;gap:.5rem;display:flex}.characters-preview{flex:2}.btn-small{padding:.375rem .75rem;font-size:.8rem}.characters-selection{flex-direction:column;gap:.5rem;max-height:200px;display:flex;overflow-y:auto}.char-card{background:var(--color-surface);border:2px solid var(--color-border);cursor:pointer;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem;transition:all .2s;display:flex}.char-card:hover{border-color:var(--color-accent)}.char-card.selected{border-color:var(--color-accent);background:#0071e31a}.selected-chars-preview{border:1px solid var(--color-accent);background:#3b82f61a;border-radius:8px;margin-top:1rem;padding:.75rem}.selected-chars-preview strong{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.8rem;display:block}.selected-nicknames{flex-wrap:wrap;gap:.5rem;display:flex}.char-badge.selected{background:var(--color-accent);font-weight:600}.frame-step{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.frame-step h4{color:var(--color-text-primary);margin-bottom:.75rem;font-size:.875rem;font-weight:600}.frame-prompt-input{resize:vertical;width:100%;min-height:100px}.frame-image-container{cursor:pointer;margin:1rem 0;position:relative}.frame-image{object-fit:cover;border-radius:8px;width:100%;max-height:400px}.gallery-tab{border-left:2px solid var(--color-border);margin-left:auto;padding-left:1rem}.location-image-container{margin-top:1rem}.location-image{object-fit:contain;border-radius:8px;width:100%;max-height:400px;margin-bottom:1rem}.image-settings{border:1px solid var(--color-border);background:#8080801a;border-radius:8px;flex-wrap:wrap;align-items:center;gap:.625rem;margin:.75rem 0;padding:.5rem .625rem;display:flex}.image-settings .setting-row{align-items:center;gap:.25rem;display:flex}.image-settings label{color:var(--color-text-secondary);white-space:nowrap;font-size:.75rem}.image-settings select{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;border-radius:4px;max-width:150px;padding:.25rem .5rem;font-size:.75rem}.image-settings select:focus{border-color:var(--color-accent);outline:none}.location-image-container .btn{width:fit-content;margin:0 auto;display:block}.location-image-container.clickable{cursor:pointer;position:relative}.location-images-grid{gap:.5rem;margin-bottom:1rem;display:grid}.location-images-grid.grid-1{grid-template-columns:1fr}.location-images-grid.grid-2{grid-template-columns:repeat(2,1fr)}.location-images-grid.grid-3{grid-template-columns:repeat(3,1fr)}.location-images-grid.grid-4{grid-template-columns:repeat(2,1fr)}.location-grid-item{cursor:pointer;border-radius:8px;position:relative;overflow:hidden}.location-grid-item img{width:100%;height:auto;transition:transform .2s;display:block}.location-grid-item:hover img{transform:scale(1.05)}.grid-item-overlay{opacity:0;background:#00000080;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.grid-item-overlay span{color:#fff;background:#000000b3;border-radius:4px;padding:.5rem 1rem;font-size:.875rem}.location-grid-item:hover .grid-item-overlay,.location-image-container.clickable:hover .grid-item-overlay{opacity:1}.meta-block strong{color:var(--color-text-tertiary)}.empty-state{height:100%;color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.dashboard-loading{height:100vh;color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.btn-icon{width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-icon:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.btn-icon.danger:hover{color:#ff3b30;background:#ff3b301a}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:16px;width:90%;max-width:420px;max-height:90vh;padding:2rem;overflow-y:auto}.modal h2{margin-bottom:1.5rem}.modal .input{background:var(--color-surface-elevated);border:1px solid var(--color-border);width:100%;color:var(--color-text-primary);border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1.5rem;display:flex}.char-image-upload{margin-top:1rem}.char-image-upload .upload-label{cursor:pointer;justify-content:space-between;align-items:center;gap:1rem;display:flex}.char-image-upload .upload-label>span:first-child{color:var(--color-text-secondary);font-size:.9rem}.char-image-upload .image-preview{border-radius:8px;max-width:200px;margin-top:.75rem;position:relative;overflow:hidden}.char-image-upload .image-preview img{width:100%;height:auto;display:block}.char-image-upload .remove-image{color:#fff;background:#000000b3;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex;position:absolute;top:4px;right:4px}.char-image-upload .remove-image:hover{background:var(--color-danger)}.btn-sm{padding:.35rem .75rem;font-size:.85rem}.character-modal{max-width:450px}.char-nick-edit{margin-bottom:1rem}.char-nick-input{transition:all .2s;background:0 0!important;border:1px solid #0000!important;padding:.5rem .75rem!important;font-size:1.25rem!important;font-weight:600!important}.char-nick-input:hover:not(:disabled){border-color:var(--color-border)!important;background:var(--color-surface-elevated)!important}.char-nick-input:focus{outline:none;box-shadow:0 0 0 3px #0071e326;border-color:var(--color-accent)!important;background:var(--color-surface-elevated)!important}.char-images-row{gap:1.5rem;margin-bottom:1.5rem;display:flex}.char-avatar-section{flex-direction:column;align-items:center;gap:.5rem;display:flex}.char-avatar-section label,.char-reference-section label{color:var(--color-text-secondary);margin-bottom:.25rem;font-size:.85rem}.char-avatar-preview{object-fit:cover;border:3px solid var(--color-accent);border-radius:50%;width:100px;height:100px}.char-no-avatar{background:var(--color-surface-elevated);border:2px dashed var(--color-border);width:100px;height:100px;color:var(--color-text-tertiary);border-radius:50%;justify-content:center;align-items:center;font-size:2rem;display:flex}.char-reference-section{text-align:center;flex:1}.char-reference-image{object-fit:contain;border-radius:12px;max-width:100%;max-height:250px;margin-bottom:1rem}.char-no-image{background:var(--color-surface-elevated);border:2px dashed var(--color-border);width:200px;height:150px;color:var(--color-text-tertiary);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}.char-no-image span{margin-bottom:.5rem;font-size:2rem}.char-no-image p{margin:0;font-size:.85rem}.upload-new-image{cursor:pointer;display:inline-block}.new-image-preview{margin-top:.75rem}.new-image-preview img{border:2px solid var(--color-accent);border-radius:8px;max-width:150px;max-height:100px}.char-desc-section{margin-bottom:1rem}.char-desc-section label{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.9rem;display:block}.char-desc-section textarea{resize:vertical;min-height:80px}.btn{cursor:pointer;border:none;border-radius:8px;padding:.5rem 1rem;font-weight:500;transition:all .2s}.btn-primary{color:#fff;background:#0071e3}.btn-primary:hover{background:#0077ed}.btn-secondary{background:var(--color-surface-elevated);color:var(--color-text-primary)}.btn-secondary:hover{background:var(--color-border)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{color:var(--color-text-primary)}.btn-lg{padding:1rem 2rem;font-size:1rem}.gallery-panel{flex-direction:column;gap:1rem;display:flex}.gallery-controls{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.favorites-filter{cursor:pointer;color:var(--color-text-secondary);align-items:center;gap:.5rem;font-size:.875rem;display:flex}.favorites-filter input{cursor:pointer}.gallery-loading,.gallery-empty{min-height:200px;color:var(--color-text-tertiary);flex-direction:column;justify-content:center;align-items:center;display:flex}.gallery-empty .hint{opacity:.7;margin-top:.5rem;font-size:.8rem}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.gallery-card{background:var(--color-bg-secondary);border-radius:8px;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.gallery-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d}.gallery-card img{object-fit:contain;cursor:pointer;border-radius:8px 8px 0 0;width:100%;height:auto}.gallery-card-actions{opacity:0;gap:4px;transition:opacity .2s;display:flex;position:absolute;top:4px;right:4px}.gallery-card:hover .gallery-card-actions{opacity:1}.gallery-card .btn-icon{cursor:pointer;background:#0009;border:none;border-radius:4px;padding:4px 8px;font-size:1rem;transition:background .2s}.gallery-card .btn-icon:hover{background:#000c}.gallery-card .btn-icon.active{color:gold}.gallery-card .btn-icon.delete:hover{background:#b43c3ccc}.gallery-card-prompt{color:var(--color-text-tertiary);background:var(--color-bg-tertiary);white-space:nowrap;text-overflow:ellipsis;padding:.5rem;font-size:.75rem;overflow:hidden}.edit-modal-overlay{z-index:1000;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.edit-modal{background:var(--color-bg-primary);border-radius:12px;width:90%;max-width:600px;max-height:90vh;padding:1.5rem;overflow-y:auto}.edit-modal h3{color:var(--color-text-primary);margin:0 0 1rem}.edit-modal-content{flex-direction:column;gap:1rem;display:flex}.edit-modal-content img{object-fit:contain;background:#000;border-radius:0;width:100%;max-height:300px}.edit-modal-content textarea{border:1px solid var(--color-border);background:var(--color-bg-secondary);width:100%;color:var(--color-text-primary);resize:vertical;border-radius:8px;padding:.75rem;font-family:inherit}.edit-modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.edit-characters-section{padding:.5rem 0}.edit-characters-section label{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.85rem;display:block}.edit-characters-grid{flex-wrap:wrap;gap:.5rem;display:flex}.edit-char-item{border:2px solid var(--color-border);cursor:pointer;background:var(--color-bg-secondary);border-radius:8px;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;transition:all .2s;display:flex}.edit-char-item:hover{border-color:var(--color-accent)}.edit-char-item.selected{background:#0071e31a;border-color:#0071e3}.edit-char-item img{object-fit:cover;border-radius:50%;width:48px;height:48px}.edit-char-item span{color:var(--color-text-secondary);font-size:.75rem}.edit-chars-dropdown{display:inline-block;position:relative}.edit-chars-toggle{white-space:nowrap;padding:.3rem .6rem!important;font-size:.8rem!important}.edit-chars-menu{z-index:100;background:var(--color-bg-primary,#fff);border:1px solid var(--color-border,#e0e0e0);border-radius:8px;min-width:200px;max-height:250px;margin-top:4px;padding:.25rem;display:none;position:absolute;top:100%;left:0;overflow-y:auto;box-shadow:0 4px 16px #00000026}.edit-chars-menu.open{display:block}.edit-char-option{cursor:pointer;color:var(--color-text-primary,#1d1d1f);border-radius:6px;align-items:center;gap:.5rem;padding:.4rem .5rem;font-size:.85rem;transition:background .15s;display:flex}.edit-char-option:hover{background:#0071e314}.edit-char-option.selected{background:#0071e31f}.edit-char-option input[type=checkbox]{accent-color:#0071e3;flex-shrink:0;width:14px;height:14px}.edit-char-avatar{flex-shrink:0;object-fit:cover!important;border-radius:50%!important;width:28px!important;height:28px!important}.edit-char-option span{color:var(--color-text-primary,#1d1d1f);font-size:.85rem}.fullscreen-overlay{z-index:9999;cursor:pointer;background:#000;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden}.fullscreen-overlay img{object-fit:contain;cursor:pointer;border-radius:0;max-width:100vw;max-height:100vh}.fullscreen-close{color:#fff;cursor:pointer;z-index:2001;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;transition:background .2s,transform .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.fullscreen-close:hover{background:#ffffff4d;transform:scale(1.1)}.project-gallery-view{padding:.75rem 1rem}.project-gallery-view h2{color:var(--color-text-primary);margin:0 0 .5rem;font-size:1.25rem}.project-gallery-filters{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.5rem .75rem;display:flex}.project-gallery-filters select{border:1px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-primary);border-radius:6px;min-width:120px;padding:.35rem .75rem;font-size:.8rem}.project-gallery-filters select:disabled{opacity:.5;cursor:not-allowed}.favorites-filter{color:var(--color-text-secondary);cursor:pointer;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.favorites-filter input[type=checkbox]{cursor:pointer;width:18px;height:18px}.project-gallery-grid{grid-template-columns:repeat(4,1fr)}.gallery-card-badge{color:#fff;z-index:5;opacity:.85;pointer-events:none;background:#00000080;border-radius:8px;padding:.125rem .5rem;font-size:.65rem;font-weight:600;position:absolute;top:.5rem;left:.5rem}.shotplan-panel h4{color:var(--color-text);margin:0 0 .5rem}.shotplan-panel .help-text{color:var(--color-text-secondary);margin-bottom:1.5rem;font-size:.85rem}.shotplan-section{background:#ffffff08;border:1px solid #ffffff0f;border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.shotplan-section h4{color:#1d1d1f;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem;font-weight:600;display:flex}.shotplan-section>label{color:var(--color-text);margin-bottom:.75rem;font-weight:600;display:block}.shotplan-source-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.shotplan-source-header label{color:var(--color-text);margin:0;font-weight:600}.shotplan-source-actions{align-items:center;gap:.5rem;display:flex}.shotplan-images-grid{grid-template-columns:repeat(4,1fr);gap:.75rem;display:grid}.shotplan-image-option{cursor:pointer;border:2px solid var(--color-border);border-radius:8px;transition:all .2s;position:relative;overflow:hidden}.shotplan-image-option:hover{border-color:var(--color-accent);transform:scale(1.02)}.shotplan-image-option.selected{border-color:var(--color-accent);box-shadow:0 0 0 3px #0071e34d}.shotplan-image-option img{width:100%;height:auto;display:block}.shotplan-image-option .selected-overlay{background:var(--color-accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-weight:700;display:flex;position:absolute;top:.5rem;right:.5rem}.shotplan-characters{flex-wrap:wrap;gap:.75rem;display:flex}.shotplan-actions{border-top:1px solid var(--color-border);flex-wrap:wrap;gap:1rem;margin-top:1.5rem;padding-top:1rem;display:flex}.shotplan-result{background:var(--color-surface);border-radius:12px;margin-top:1.5rem;padding:1rem}.shotplan-result h5{color:var(--color-text);margin:0 0 1rem}.shotplan-result-grid{flex-wrap:wrap;gap:1rem;display:flex}.shotplan-result-item{cursor:pointer;border-radius:8px;max-width:500px;position:relative;overflow:hidden}.shotplan-result-item:hover .shotplan-result-overlay{opacity:1}.shotplan-result-overlay{color:#fff;opacity:0;background:#00000080;justify-content:center;align-items:center;font-size:1.1rem;font-weight:600;transition:opacity .2s;display:flex;position:absolute;inset:0}.shotplan-result-image{cursor:pointer;border-radius:8px;width:100%;max-width:500px;transition:transform .2s;display:block}.shotplan-result-image:hover{transform:scale(1.02)}.no-images{text-align:center;color:var(--color-text-secondary);background:var(--color-surface);border-radius:8px;grid-column:1/-1;padding:2rem}.shotplan-settings-row{flex-wrap:wrap;gap:1.5rem;display:flex}.shotplan-settings-row .setting-item{align-items:center;gap:.5rem;display:flex}.shotplan-settings-row .setting-item span{color:var(--color-text-secondary);font-size:.9rem}.shotplan-settings-row .setting-item select{border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;border-radius:6px;padding:.4rem .8rem}.shotplan-panel{padding:1rem}.edit-modal-image{border-radius:8px;max-height:60vh;margin-bottom:1rem;overflow:hidden}.edit-modal-image img{object-fit:contain;width:100%;height:auto;max-height:60vh}.modal-textarea{border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);resize:vertical;border-radius:8px;margin-bottom:1rem;padding:1rem;font-family:inherit;font-size:.95rem}.video-tab{padding:1.5rem}.video-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;margin-bottom:2rem;padding:1.5rem}.video-form h3{color:var(--color-text-primary);margin:0 0 1.5rem;font-size:1.1rem;font-weight:600}.frame-selection{align-items:center;gap:1.5rem;margin-bottom:1.5rem;display:flex}.frame-select{flex:1;position:relative}.frame-select label{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.frame-preview{background:var(--color-surface-elevated);border:2px dashed var(--color-border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:100%;min-height:120px;transition:all .2s;display:flex;overflow:hidden}.frame-preview:hover{border-color:var(--color-accent);background:#3b82f60d}.frame-preview.drag-over{border-color:var(--color-accent);background:#3b82f61f;border-style:solid;transform:scale(1.02);box-shadow:0 0 0 3px #3b82f640}.frame-preview.has-image{border-style:solid;border-color:var(--color-accent)}.frame-preview img{object-fit:contain;width:100%;height:auto;display:block}.frame-preview span{color:var(--color-text-tertiary);font-size:.9rem}.frame-arrow{color:var(--color-text-tertiary);flex-shrink:0;font-size:1.5rem}.frame-select .clear-btn{background:var(--color-danger);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex;position:absolute;top:2rem;right:.5rem}.prompt-section{margin-bottom:1.5rem}.prompt-section label{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.prompt-row{gap:1rem;display:flex}.prompt-row textarea{border:1px solid var(--color-border);background:var(--color-surface-elevated);color:var(--color-text-primary);resize:vertical;border-radius:8px;flex:1;padding:1rem;font-family:inherit;font-size:.9rem}.prompt-row textarea:focus{border-color:var(--color-accent);outline:none}.generate-prompt-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#8b5cf6,#a855f7);border:none;border-radius:8px;padding:.75rem 1.25rem;font-weight:500;transition:all .2s}.generate-prompt-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.generate-prompt-btn:disabled{opacity:.6;cursor:not-allowed}.video-settings{flex-wrap:nowrap;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;display:flex}.video-settings .setting{flex-direction:column;gap:.35rem;min-width:0;display:flex}.video-settings .setting label{color:var(--color-text-secondary);white-space:nowrap;font-size:.75rem}.video-settings .setting select{border:1px solid var(--color-border);background:var(--color-surface-elevated);color:var(--color-text-primary);border-radius:6px;padding:.4rem .6rem;font-size:.825rem}.generate-video-btn{background:linear-gradient(135deg,var(--color-accent),#8b5cf6);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;padding:1rem 2rem;font-size:1rem;font-weight:600;transition:all .2s}.generate-video-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.generate-video-btn:disabled{opacity:.5;cursor:not-allowed}.videos-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem}.videos-section h3{color:var(--color-text-primary);margin:0 0 1.5rem;font-size:1rem;font-weight:600}.videos-section .loading,.videos-section .empty{text-align:center;color:var(--color-text-secondary);padding:2rem}.videos-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.video-card{background:var(--color-surface-elevated);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;transition:all .2s;position:relative;overflow:hidden}.video-card:hover{border-color:var(--color-accent);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.video-card video{width:100%;display:block}.video-card .video-info{color:#fff;background:linear-gradient(#0000,#000c);gap:.5rem;padding:.5rem;font-size:.75rem;display:flex;position:absolute;bottom:0;left:0;right:0}.video-modal-overlay{z-index:1000;background:#000000d9;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.video-modal{background:var(--color-surface);border-radius:16px;width:100%;max-width:900px;overflow:hidden}.video-modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.video-modal-header span{font-weight:600}.video-modal-header button{background:var(--color-surface-elevated);width:32px;height:32px;color:var(--color-text-primary);cursor:pointer;border:none;border-radius:50%;font-size:1rem}.video-modal-info{padding:1rem 1.5rem}.video-modal-info p{color:var(--color-text-primary);margin:0 0 .5rem}.video-modal-info span{color:var(--color-text-secondary);font-size:.875rem}.video-step{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.video-step .step-header{align-items:center;gap:1rem;margin-bottom:.75rem;display:flex}.video-step .step-number{background:linear-gradient(135deg,var(--color-accent),#8b5cf6);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.9rem;font-weight:700;display:flex}.video-step h4{color:var(--color-text-primary);margin:0;font-size:1rem;font-weight:600}.video-step .step-description{color:var(--color-text-secondary);margin:0 0 1rem;font-size:.875rem}.prompt-display{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:8px;padding:1rem}.prompt-display textarea{border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text-primary);resize:vertical;border-radius:8px;margin-bottom:.75rem;padding:1rem;font-family:inherit;font-size:.9rem}.prompt-display textarea:focus{border-color:var(--color-accent);outline:none}.prompt-display .prompt-actions{gap:.75rem;display:flex}.prompt-display .no-prompt{text-align:center;padding:1.5rem}.prompt-display .no-prompt p{color:var(--color-text-secondary);margin:0 0 1rem}.prompt-modal-overlay{z-index:1000;background:#000000bf;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.prompt-modal{background:var(--color-surface);border-radius:16px;flex-direction:column;width:100%;max-width:700px;max-height:90vh;display:flex;overflow:hidden}.prompt-modal-header{border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.prompt-modal-header h3{margin:0;font-size:1.1rem;font-weight:600}.prompt-modal-header button{background:var(--color-surface-elevated);width:32px;height:32px;color:var(--color-text-primary);cursor:pointer;border:none;border-radius:50%;font-size:1rem;transition:all .2s}.prompt-modal-header button:hover{background:var(--color-danger);color:#fff}.prompt-modal-body{flex:1;padding:1.5rem;overflow-y:auto}.prompt-field{margin-bottom:1.25rem}.prompt-field:last-child{margin-bottom:0}.prompt-field label{color:var(--color-text-primary);margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.prompt-field textarea{border:1px solid var(--color-border);background:var(--color-surface-elevated);width:100%;color:var(--color-text-primary);resize:vertical;border-radius:8px;padding:1rem;font-family:inherit;font-size:.9rem;line-height:1.5;transition:border-color .2s}.prompt-field textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #3b82f61a}.prompt-field textarea::placeholder{color:var(--color-text-tertiary)}.prompt-modal-footer{border-top:1px solid var(--color-border);background:var(--color-surface-elevated);justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.btn-primary{background:linear-gradient(135deg,var(--color-accent),#8b5cf6);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--color-surface-elevated);color:var(--color-text-primary);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;padding:.75rem 1.5rem;font-weight:500;transition:all .2s}.btn-secondary:hover{background:var(--color-surface);border-color:var(--color-accent)}.gallery-pagination{justify-content:center;align-items:center;gap:1rem;margin-top:.5rem;padding:1rem 0;display:flex}.gallery-pagination .pagination-info{color:var(--color-text-secondary);text-align:center;min-width:120px;font-size:.875rem}.gallery-pagination .btn-sm{padding:.25rem .75rem;font-size:.8rem}.gallery-count{color:var(--color-text-secondary);margin-left:auto;font-size:.85rem}.filter-select{background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border);border-radius:6px;padding:.35rem .5rem;font-size:.85rem}.storyboard-tab{flex-direction:column;gap:1.5rem;display:flex}.storyboard-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.storyboard-section h4{color:var(--color-text-primary);align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem;font-weight:600;display:flex}.storyboard-section .section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.storyboard-section .section-header h4{margin:0}.warning-message{color:#ffc107;background:#ffc1071a;border:1px solid #ffc1074d;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem}.storyboard-tab .context-options{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem}.storyboard-tab .context-options h5{color:var(--color-text-secondary);margin:0 0 .5rem;font-size:.85rem;font-weight:500}.storyboard-tab .context-options label{cursor:pointer;color:var(--color-text-primary);-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;padding:.3rem .75rem .3rem 0;font-size:.85rem;display:inline-flex}.storyboard-tab .context-options input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-accent);cursor:pointer}.character-selection{margin-bottom:1rem}.character-selection label{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.85rem;display:block}.character-chips{flex-wrap:wrap;gap:.5rem;display:flex}.character-chip{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-primary);cursor:pointer;border-radius:20px;align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.85rem;transition:all .15s;display:flex}.character-chip:hover{background:var(--color-bg-hover,var(--color-bg-secondary));border-color:var(--color-border)}.character-chip.selected{border-color:var(--color-accent);color:var(--color-text-primary);background:#0071e326}.chip-avatar{object-fit:cover;border-radius:50%;width:20px;height:20px}.reference-section{margin-bottom:1rem}.reference-section label{color:var(--color-text-secondary);margin-right:.75rem;font-size:.85rem;display:inline-block}.selected-refs-preview{align-items:center;gap:.5rem;margin-top:.75rem;display:flex}.ref-thumb{border-radius:6px;width:60px;height:40px;position:relative;overflow:hidden}.ref-thumb img{object-fit:cover;width:100%;height:100%}.ref-remove{color:#fff;cursor:pointer;background:#f44;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.ref-more{color:var(--color-text-secondary);font-size:.85rem}.gallery-picker{background:var(--color-bg-secondary);border-radius:8px;grid-template-columns:repeat(4,1fr);gap:.5rem;max-height:200px;margin-top:.75rem;padding:.5rem;display:grid;overflow-y:auto}.gallery-thumb{cursor:pointer;background:var(--color-bg-secondary);border:2px solid #0000;border-radius:6px;transition:all .15s;position:relative;overflow:hidden}.gallery-thumb img{width:100%;height:auto;display:block}.gallery-thumb:hover{border-color:var(--color-border)}.gallery-thumb.selected{border-color:var(--color-accent)}.gallery-thumb .selected-overlay{color:#fff;background:#0071e366;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex;position:absolute;inset:0}.no-images{color:var(--color-text-secondary);text-align:center;padding:1rem;font-size:.85rem}.generation-settings{flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem;display:flex}.setting-group{align-items:center;gap:.5rem;display:flex}.setting-group label{color:var(--color-text-secondary);white-space:nowrap;font-size:.813rem}.setting-group select{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;border-radius:4px;padding:.375rem .75rem;font-size:.813rem}.setting-group select:focus{border-color:var(--color-accent);outline:none}.storyboard-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.storyboard-image{background:var(--color-bg-secondary);border-radius:8px;position:relative;overflow:hidden}.storyboard-image img{cursor:pointer;width:100%;height:auto;transition:transform .2s;display:block}.storyboard-image img:hover{transform:scale(1.02)}.section-actions{gap:.75rem;margin-top:1rem;display:flex}.btn-large{width:100%;padding:.85rem 1.5rem;font-size:1rem}.section-hint{color:var(--color-text-secondary);margin:0 0 1rem;font-size:.85rem}.grid-image-selector{margin-bottom:1rem}.grid-image-selector label{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.85rem;display:block}.grid-image-list{flex-wrap:wrap;gap:.5rem;display:flex}.grid-image-option{cursor:pointer;background:var(--color-bg-secondary);border:2px solid #0000;border-radius:8px;width:80px;transition:all .15s;position:relative;overflow:hidden}.grid-image-option img{width:100%;height:auto;display:block}.grid-image-option span{color:#fff;background:#0009;border-radius:4px;padding:1px 5px;font-size:11px;position:absolute;bottom:2px;right:4px}.grid-image-option:hover{border-color:var(--color-border)}.grid-image-option.selected{border-color:var(--color-accent)}.generation-settings{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;flex-wrap:wrap;gap:1rem;margin:1rem 0;padding:.75rem;display:flex}.generation-settings .setting-group{align-items:center;gap:.5rem;display:flex}.generation-settings .setting-group label{color:var(--color-text-secondary);white-space:nowrap;font-size:.813rem}.generation-settings .setting-group select{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;border-radius:4px;padding:.375rem .75rem;font-size:.813rem}.generation-settings .setting-group select:focus{border-color:var(--color-accent);outline:none}.upscaled-gallery{border-top:1px solid var(--color-border);margin-top:1.5rem;padding-top:1rem}.upscaled-gallery h5{color:var(--color-text-primary);margin:0 0 .75rem;font-size:.95rem}.upscaled-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;display:grid}.upscaled-item{cursor:pointer;border-radius:8px;transition:transform .15s;position:relative;overflow:hidden}.upscaled-item:hover{transform:scale(1.02)}.upscaled-item img{width:100%;height:auto;display:block}.upscaled-label{color:#f5f5f7;white-space:nowrap;text-overflow:ellipsis;background:#000000b3;padding:4px 8px;font-size:.7rem;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.extra-prompt-section{margin:.75rem 0}.extra-prompt-input{background:var(--color-bg);border:1px solid var(--color-border);width:100%;color:var(--color-text);border-radius:8px;padding:.5rem .75rem;font-family:inherit;font-size:.85rem;transition:border-color .2s}.extra-prompt-input::placeholder{color:var(--color-text-secondary);opacity:.6}.extra-prompt-input:focus{border-color:var(--color-accent);outline:none}.chat-panel{border:1px solid var(--color-border);background:var(--color-bg);border-radius:10px;flex:1;gap:0;min-height:0;display:flex;overflow:hidden}.chat-list{border-right:1px solid var(--color-border);background:var(--color-bg-secondary);flex-direction:column;width:280px;min-width:280px;display:flex;overflow:hidden}.chat-list-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.chat-list-header h3{color:var(--color-text);margin:0;font-size:14px;font-weight:600}.chat-list-new-btn{background:var(--color-accent,#0071e3);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:500;transition:opacity .2s}.chat-list-new-btn:hover{background:var(--color-accent-hover,#0077ed)}.chat-list-new-btn:disabled{opacity:.5;cursor:not-allowed}.chat-list-items{scrollbar-width:none;-ms-overflow-style:none;flex:1;padding:8px;overflow-y:auto}.chat-list-items::-webkit-scrollbar{display:none}.chat-list-item{cursor:pointer;border-radius:8px;margin-bottom:4px;padding:10px 12px;transition:background .15s;position:relative}.chat-list-item:hover{background:var(--color-bg-tertiary)}.chat-list-item.active{border:1px solid var(--color-accent,#0071e3);background:#0071e314}.chat-list-item-title{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:13px;font-weight:500;overflow:hidden}.chat-list-item-meta{color:var(--color-text-secondary);align-items:center;gap:6px;font-size:11px;display:flex}.chat-list-item-author-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.chat-list-item-delete{cursor:pointer;opacity:0;color:var(--color-text-secondary);background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:12px;transition:opacity .15s;position:absolute;top:8px;right:8px}.chat-list-item:hover .chat-list-item-delete{opacity:.6}.chat-list-item-delete:hover{color:#ef4444;opacity:1!important}.chat-list-empty{text-align:center;color:var(--color-text-secondary);padding:24px 16px;font-size:13px}.chat-conversation{flex-direction:column;flex:1;min-width:0;transition:border-color .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.chat-conversation--drag-over{border:2px dashed var(--color-accent,#3b82f6);box-shadow:inset 0 0 40px #3b82f60f}.chat-conversation--drag-over:after{content:"📥 Перетащите файл сюда";color:var(--color-accent,#3b82f6);z-index:10;pointer-events:none;background:#3b82f60f;border-radius:8px;justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex;position:absolute;inset:0}.chat-empty-state-hint{color:var(--color-text-tertiary);opacity:.6;margin-top:8px;font-size:12px}.chat-conv-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.chat-conv-title{color:var(--color-text);font-size:14px;font-weight:600}.chat-conv-tokens{color:var(--color-text-secondary);background:var(--color-bg-secondary);font-variant-numeric:tabular-nums;border-radius:12px;padding:3px 10px;font-size:11px}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px 20px;display:flex;overflow-y:auto}.chat-msg{gap:10px;max-width:85%;display:flex}.chat-msg.user{flex-direction:row-reverse;align-self:flex-end}.chat-msg.assistant{align-self:flex-start}.chat-msg-avatar{letter-spacing:-.02em;background:var(--color-accent,#0071e3);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:600;display:flex}.chat-msg-avatar-photo{object-fit:cover}.chat-msg-author{color:var(--color-text-secondary);letter-spacing:.01em;margin-bottom:2px;font-size:11px;font-weight:600}.chat-msg.user .chat-msg-author{text-align:right}.chat-msg-content{white-space:pre-wrap;word-break:break-word;border-radius:12px;padding:10px 14px;font-size:13px;line-height:1.5}.chat-msg.user .chat-msg-content{background:var(--color-accent,#0071e3);color:#fff;border-bottom-right-radius:4px}.chat-msg.user .chat-msg-content ::selection{color:#1a1a2e;background:#ffffff59}.chat-msg.user .chat-msg-content::selection{color:#1a1a2e;background:#ffffff59}.chat-msg.assistant .chat-msg-content{background:var(--color-bg-secondary);color:var(--color-text);border-bottom-left-radius:4px}.chat-msg.assistant .chat-msg-content p,.chat-msg.assistant .chat-msg-content li,.chat-msg.assistant .chat-msg-content h1,.chat-msg.assistant .chat-msg-content h2,.chat-msg.assistant .chat-msg-content h3,.chat-msg.assistant .chat-msg-content h4,.chat-msg.assistant .chat-msg-content td,.chat-msg.assistant .chat-msg-content th,.chat-msg.assistant .chat-msg-content blockquote,.chat-msg.assistant .chat-msg-content strong,.chat-msg.assistant .chat-msg-content em,.chat-msg.assistant .chat-msg-content span{color:inherit}.chat-msg-streaming:after{content:"█";color:var(--color-accent,#0071e3);animation:1s step-end infinite blink}@keyframes blink{50%{opacity:0}}.chat-msg-bubble{max-width:100%;position:relative}.chat-msg-hover-bar{opacity:0;align-items:center;gap:6px;margin-top:2px;padding:3px 0;transition:opacity .15s;display:flex}.chat-msg:hover .chat-msg-hover-bar{opacity:1}.chat-msg.user .chat-msg-hover-bar{justify-content:flex-end}.chat-msg-time{color:var(--color-text-secondary);white-space:nowrap;font-size:10px}.chat-msg-copy-btn{border:1px solid var(--color-border);cursor:pointer;opacity:.6;background:0 0;border-radius:4px;padding:1px 4px;font-size:11px;line-height:1;transition:opacity .15s}.chat-msg-copy-btn:hover{opacity:1;border-color:var(--color-accent,#0071e3)}.chat-markdown{white-space:normal}.chat-msg.user .chat-markdown{white-space:pre-wrap}.chat-markdown p{margin:0 0 8px}.chat-markdown p:last-child{margin-bottom:0}.chat-markdown h1,.chat-markdown h2,.chat-markdown h3,.chat-markdown h4,.chat-markdown h5,.chat-markdown h6{margin:12px 0 6px;font-weight:600;line-height:1.3}.chat-markdown h1{font-size:1.25em}.chat-markdown h2{font-size:1.15em}.chat-markdown h3{font-size:1.05em}.chat-markdown strong{font-weight:600}.chat-markdown em{font-style:italic}.chat-markdown code{background:#00000014;border-radius:4px;padding:2px 5px;font-family:SF Mono,Fira Code,monospace;font-size:.88em}.chat-msg.user .chat-markdown,.chat-msg.user .chat-markdown p,.chat-msg.user .chat-markdown h1,.chat-msg.user .chat-markdown h2,.chat-msg.user .chat-markdown h3,.chat-msg.user .chat-markdown h4,.chat-msg.user .chat-markdown li,.chat-msg.user .chat-markdown strong,.chat-msg.user .chat-markdown em,.chat-msg.user .chat-markdown td,.chat-msg.user .chat-markdown th,.chat-msg.user .chat-markdown blockquote{color:#fff}.chat-msg.user .chat-markdown code{background:#ffffff26}.chat-markdown pre{background:#0000000f;border-radius:8px;margin:8px 0;overflow-x:auto}.chat-code-block pre{border-radius:0;margin:0;overflow-x:auto}.chat-code-block{background:#0000000f;border-radius:8px;flex-direction:column;margin:8px 0;display:flex;overflow:hidden}.chat-msg.user .chat-code-block,.chat-msg.user .chat-markdown pre{background:#ffffff1a}.chat-markdown pre code{white-space:pre;background:0 0;padding:10px 12px;font-size:12px;line-height:1.5;display:block}.chat-text-block code{word-wrap:break-word;word-break:break-word;white-space:pre-wrap!important}.chat-markdown ul,.chat-markdown ol{margin:6px 0;padding-left:20px}.chat-markdown li{margin-bottom:3px}.chat-markdown blockquote{border-left:3px solid var(--color-accent,#0071e3);opacity:.85;margin:8px 0;padding:4px 12px}.chat-msg.user .chat-markdown blockquote{border-left-color:#ffffff80}.chat-markdown a{color:var(--color-accent,#0071e3);text-decoration:underline}.chat-msg.user .chat-markdown a{color:#ffffffe6}.chat-markdown table{border-collapse:collapse;width:100%;margin:8px 0;font-size:12px}.chat-markdown th,.chat-markdown td{border:1px solid var(--color-border);text-align:left;padding:4px 8px}.chat-markdown th{background:#0000000a;font-weight:600}.chat-markdown hr{border:none;border-top:1px solid var(--color-border);margin:10px 0}.chat-context-bar{border-top:1px solid var(--color-border);background:var(--color-bg-secondary);flex-wrap:wrap;gap:6px;padding:6px 20px;display:flex}.chat-context-tag{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;background:#6366f11a;border:1px solid #6366f140;border-radius:12px;align-items:center;gap:4px;max-width:250px;padding:3px 8px;font-size:11px;display:inline-flex;overflow:hidden}.chat-context-tag-file{background:#eab3081a;border-color:#eab30840}.chat-context-tag-remove{cursor:pointer;color:var(--color-text-secondary);opacity:.6;background:0 0;border:none;padding:0 2px;font-size:10px;line-height:1;transition:opacity .15s}.chat-context-tag-remove:hover{opacity:1;color:#ef4444}.chat-context-tag-uploading{background:#6366f114;border:1px dashed #6366f166;animation:1.2s ease-in-out infinite chat-upload-pulse}@keyframes chat-upload-pulse{0%,to{opacity:.6}50%{opacity:1}}.chat-upload-spinner{border:2px solid #6366f14d;border-top-color:var(--color-accent,#6366f1);border-radius:50%;flex-shrink:0;width:12px;height:12px;animation:.7s linear infinite chat-spinner-spin;display:inline-block}@keyframes chat-spinner-spin{to{transform:rotate(360deg)}}.chat-input-actions{align-items:flex-end;display:flex;position:relative}.chat-context-picker{background:var(--color-bg);border:1px solid var(--color-border);z-index:100;border-radius:10px;width:340px;max-height:360px;position:absolute;bottom:42px;left:0;overflow-y:auto;box-shadow:0 8px 30px #00000026}.chat-context-picker-header{color:var(--color-text);border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);border-radius:10px 10px 0 0;padding:10px 14px;font-size:12px;font-weight:600}.chat-context-picker-empty{text-align:center;color:var(--color-text-secondary);padding:20px 14px;font-size:12px}.chat-context-picker-list{padding:6px 0}.chat-context-picker-item{cursor:pointer;color:var(--color-text);align-items:center;gap:8px;padding:6px 14px;font-size:12px;transition:background .1s;display:flex}.chat-context-picker-item:hover{background:var(--color-bg-secondary)}.chat-context-picker-child{padding-left:34px}.chat-context-picker-deep{padding-left:50px}.chat-context-group{border-top:1px solid var(--color-border)}.chat-context-group:first-of-type{border-top:none}.chat-context-group-header{align-items:center;display:flex}.chat-context-group-toggle{cursor:pointer;width:24px;height:28px;color:var(--color-text-secondary);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-left:6px;font-size:9px;transition:color .15s;display:flex}.chat-context-group-toggle:hover{color:var(--color-accent,#0071e3)}.chat-context-group-label{flex:1;font-weight:500}.chat-context-group-badge{background:var(--color-accent,#0071e3);color:#fff;border-radius:8px;flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:600}.chat-context-picker-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--color-accent,#0071e3);cursor:pointer;flex-shrink:0}.chat-context-picker-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.chat-context-picker-chars{color:var(--color-text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:10px}.chat-attach-btn{border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;transition:background .15s,border-color .15s;display:flex}.chat-attach-btn:hover{background:var(--color-bg-secondary);border-color:var(--color-accent,#0071e3)}.chat-attach-btn:disabled{opacity:.4;cursor:not-allowed}.chat-role-bar{border-top:1px solid var(--color-border);background:var(--color-bg-secondary);align-items:center;gap:8px;padding:6px 20px;display:flex;position:relative}.chat-role-selector-btn{background:var(--color-bg);border:1px solid var(--color-border);cursor:pointer;color:var(--color-text);white-space:nowrap;border-radius:8px;align-items:center;gap:4px;padding:4px 12px;font-family:inherit;font-size:12px;transition:all .15s;display:flex}.chat-role-selector-btn:hover{border-color:var(--color-accent,#6366f1);background:#6366f10f}.chat-role-manage-btn{border:1px solid var(--color-border);cursor:pointer;color:var(--color-text-secondary);white-space:nowrap;background:0 0;border-radius:6px;align-items:center;gap:4px;margin-left:auto;padding:4px 10px;font-family:inherit;font-size:11px;transition:all .15s;display:flex}.chat-role-manage-btn:hover{color:var(--color-accent,#6366f1);border-color:var(--color-accent,#6366f1)}.chat-role-dropdown{background:var(--color-bg);border:1px solid var(--color-border);z-index:100;border-radius:10px;min-width:280px;max-height:320px;margin-bottom:4px;position:absolute;bottom:100%;left:20px;overflow-y:auto;box-shadow:0 8px 30px #0000002e}.chat-role-dropdown-item{cursor:pointer;color:var(--color-text);border-bottom:1px solid var(--color-border);padding:10px 14px;font-size:13px;transition:background .1s}.chat-role-dropdown-item:last-child{border-bottom:none}.chat-role-dropdown-item:hover{background:var(--color-bg-secondary)}.chat-role-dropdown-item.active{border-left:3px solid var(--color-accent,#6366f1);background:#6366f11a}.chat-role-dropdown-name{font-weight:500}.chat-role-dropdown-author{color:var(--color-text-secondary);margin-top:2px;font-size:11px}.chat-role-dropdown-item{align-items:center;gap:8px;display:flex}.chat-role-dropdown-info{flex:1;min-width:0}.chat-role-dropdown-delete{cursor:pointer;opacity:0;background:0 0;border:1px solid #0000;border-radius:5px;flex-shrink:0;padding:2px 4px;font-size:12px;transition:all .15s}.chat-role-dropdown-item:hover .chat-role-dropdown-delete{opacity:.5}.chat-role-dropdown-delete:hover{background:#ef444414;border-color:#ef4444;opacity:1!important}.chat-role-dropdown-create{color:var(--color-accent,#6366f1);text-align:center;border-top:1px solid var(--color-border);font-weight:500}.chat-role-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.chat-role-modal{background:var(--color-bg);border-radius:14px;width:520px;max-height:80vh;animation:.2s ease-out modal-slide-up;overflow-y:auto;box-shadow:0 20px 60px #0000004d}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-role-modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.chat-role-modal-header h3{margin:0;font-size:16px;font-weight:600}.chat-role-modal-close{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:18px;transition:all .15s;display:flex}.chat-role-modal-close:hover{background:var(--color-bg-secondary);color:var(--color-text)}.chat-role-modal-body{padding:16px 20px}.chat-role-card{border:1px solid var(--color-border);background:var(--color-bg-secondary);border-radius:10px;margin-bottom:10px;padding:12px 14px;transition:border-color .15s}.chat-role-card:hover{border-color:var(--color-accent,#6366f1)}.chat-role-card-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.chat-role-card-name{font-size:13px;font-weight:600}.chat-role-card-meta{color:var(--color-text-secondary);font-size:11px}.chat-role-card-preview{color:var(--color-text-secondary);max-height:40px;margin-bottom:8px;font-size:12px;line-height:1.4;overflow:hidden}.chat-role-card-actions{justify-content:flex-end;gap:6px;display:flex}.chat-role-card-actions button{border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;transition:all .15s;display:flex}.chat-role-card-actions button:hover{background:var(--color-bg);border-color:var(--color-accent,#6366f1)}.chat-role-empty{text-align:center;color:var(--color-text-secondary);padding:20px;font-size:13px}.chat-role-divider{background:var(--color-border);height:1px;margin:14px 0}.chat-role-form label{color:var(--color-text-secondary);margin-top:10px;margin-bottom:4px;font-size:12px;font-weight:500;display:block}.chat-role-form label:first-child{margin-top:0}.chat-role-input{border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);box-sizing:border-box;border-radius:8px;outline:none;padding:8px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.chat-role-input:focus{border-color:var(--color-accent,#6366f1)}.chat-role-textarea{border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);resize:vertical;box-sizing:border-box;border-radius:8px;outline:none;min-height:140px;padding:10px 12px;font-family:SF Mono,Fira Code,monospace;font-size:12px;line-height:1.5;transition:border-color .15s}.chat-role-textarea:focus{border-color:var(--color-accent,#6366f1)}.chat-role-form-footer{justify-content:space-between;align-items:center;margin-top:12px;display:flex}.chat-role-char-count{color:var(--color-text-secondary);font-variant-numeric:tabular-nums;font-size:11px}.chat-role-form-btns{gap:8px;display:flex}.chat-role-cancel-btn{border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;border-radius:8px;padding:6px 14px;font-family:inherit;font-size:12px;transition:all .15s}.chat-role-cancel-btn:hover{background:var(--color-bg-secondary)}.chat-role-save-btn{background:var(--color-accent,#6366f1);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:6px 16px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.chat-role-save-btn:hover{filter:brightness(1.1)}.chat-role-save-btn:disabled{opacity:.4;cursor:not-allowed}.chat-input-area{border-top:1px solid var(--color-border);align-items:flex-end;gap:8px;padding:12px 20px;display:flex}.chat-input-textarea{resize:none;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);scrollbar-width:none;-ms-overflow-style:none;border-radius:10px;outline:none;flex:1;min-height:40px;max-height:200px;padding:10px 14px;font-family:inherit;font-size:13px;line-height:1.5;transition:border-color .2s;overflow-y:auto}.chat-input-textarea::-webkit-scrollbar{display:none}.chat-input-textarea:focus{border-color:var(--color-accent,#0071e3)}.chat-input-textarea::placeholder{color:var(--color-text-secondary)}.chat-send-btn{background:var(--color-accent,#0071e3);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;transition:opacity .2s,transform .1s;display:flex}.chat-send-btn:hover{background:var(--color-accent-hover,#0077ed);transform:scale(1.05)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.chat-empty-state{color:var(--color-text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.chat-empty-state-icon{opacity:.4;font-size:48px}.chat-empty-state-text{font-size:14px}.chat-no-access{color:var(--color-text-secondary);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.chat-settings-toggle{border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:6px;padding:4px 8px;font-size:14px;line-height:1;transition:background .15s}.chat-settings-toggle:hover{background:var(--color-bg-secondary)}.chat-settings-panel{border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);flex-wrap:wrap;align-items:center;gap:24px;padding:10px 20px;display:flex}.chat-setting-row{align-items:center;gap:8px;font-size:12px;display:flex}.chat-setting-row label{color:var(--color-text-secondary);white-space:nowrap;min-width:110px}.chat-setting-control{align-items:center;gap:6px;display:flex}.chat-setting-control input[type=range]{width:120px;accent-color:var(--color-accent,#0071e3)}.chat-setting-control select{border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;border-radius:6px;padding:4px 8px;font-size:12px}.chat-setting-value{color:var(--color-text);text-align:center;font-variant-numeric:tabular-nums;min-width:28px;font-size:12px;font-weight:600}.chat-msg-attachments{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.chat-attach-card{cursor:pointer;border-radius:10px;transition:opacity .15s;overflow:hidden}.chat-attach-card:hover{opacity:.85}.chat-attach-card.image{border:1px solid var(--color-border);max-width:180px}.chat-attach-thumb{object-fit:cover;border-radius:10px;width:100%;max-height:120px;display:block}.chat-attach-card.file,.chat-attach-card.context{background:var(--color-bg-secondary);border:1px solid var(--color-border);align-items:center;gap:6px;padding:6px 10px;display:flex}.chat-attach-file-icon{flex-shrink:0;font-size:18px;line-height:1}.chat-attach-file-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;max-width:150px;font-size:11px;font-weight:500;overflow:hidden}.chat-msg.user .chat-attach-card.file,.chat-msg.user .chat-attach-card.context{background:#ffffff1f;border-color:#fff3}.chat-msg.user .chat-attach-file-name{color:#ffffffe6}.chat-msg.user .chat-attach-card.image{border-color:#fff3}.chat-code-copy-btn{border:1px solid var(--color-border);cursor:pointer;opacity:0;white-space:nowrap;color:var(--color-text-secondary);background:0 0;border-radius:5px;align-self:flex-end;margin:6px 10px 0 0;padding:2px 5px;font-size:13px;line-height:1;transition:all .15s}.chat-code-block:hover .chat-code-copy-btn{opacity:.7}.chat-code-copy-btn:hover{border-color:var(--color-accent,#6366f1);color:var(--color-accent,#6366f1);opacity:1!important}.chat-text-block .chat-code-copy-btn{opacity:.7;background:#0000000a;border-radius:5px}.chat-text-block .chat-code-copy-btn:hover{background:var(--color-accent,#6366f1);color:#fff;border-color:var(--color-accent,#6366f1);opacity:1!important}.char-confirm-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);animation:fadeIn var(--duration-fast,.15s) var(--ease-out,ease-out);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.char-confirm-modal{background:var(--color-surface-elevated,#fff);border:1px solid var(--color-border,#e0e0e0);border-radius:var(--radius-xl,16px);min-width:320px;max-width:480px;animation:modalSlideUp .2s var(--ease-out,ease-out);flex-direction:column;gap:4px;padding:24px 28px;display:flex;box-shadow:0 16px 48px #0003}.char-confirm-icon{text-align:center;margin-bottom:4px;font-size:32px}.char-confirm-modal h3{color:var(--color-text-primary,#1d1d1f);text-align:center;margin:0 0 4px;font-size:1.1rem;font-weight:600}.char-confirm-modal p{color:var(--color-text-secondary,#86868b);text-align:center;margin:0;font-size:.85rem;line-height:1.5}.char-confirm-actions{justify-content:center;gap:8px;margin-top:16px;display:flex}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.team-board{padding:var(--space-6);animation:fadeIn var(--duration-normal) var(--ease-out)}.team-board-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.team-board-header h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary)}.team-board-stats{gap:var(--space-4);display:flex}.team-board-stat{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex}.team-board-stat strong{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.team-board-filters{align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);flex-wrap:wrap;display:flex}.team-filter{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);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='%2386868b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding-right:28px}.team-filter:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #0071e31f}.team-filter:hover{background:var(--color-surface-elevated)}.team-search{min-width:200px;max-width:320px;padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out);outline:none;flex:1}.team-search:focus{border-color:var(--color-accent);background:var(--color-surface);box-shadow:0 0 0 3px #0071e31f}.team-search::placeholder{color:var(--color-text-tertiary)}.team-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);overflow-x:auto}.team-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm);table-layout:fixed}.team-table thead{z-index:2;position:sticky;top:0}.team-table th{padding:var(--space-1) var(--space-2);text-align:center;font-weight:var(--font-weight-medium);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);color:var(--color-text-tertiary);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;-webkit-user-select:none;user-select:none;overflow:hidden}.team-table th:first-child{border-top-left-radius:var(--radius-lg)}.team-table th:last-child{border-top-right-radius:var(--radius-lg)}.team-table td{padding:var(--space-1) var(--space-2);border-bottom:1px solid var(--color-divider);vertical-align:middle;color:var(--color-text-primary);text-overflow:ellipsis;overflow:hidden}.team-table tbody tr{transition:background var(--duration-fast) var(--ease-out)}.team-table tbody tr:hover{background:var(--color-bg-secondary)}.team-table tbody tr:last-child td{border-bottom:none}.shot-id-cell{font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums;color:var(--color-text-primary);white-space:nowrap}.shot-scene-info{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.cell-mono{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center;white-space:nowrap}.cell-shotsize{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-accent);text-align:center;cursor:default;letter-spacing:.02em;white-space:normal;word-break:break-word;background:#0071e30f;min-width:4em;max-width:7em;line-height:1.25}td.cell-beat{font-size:var(--font-size-xs);color:var(--color-text-secondary);word-break:break-word;line-height:1.3;display:table-cell;overflow:hidden;white-space:normal!important}.assignee-cell{text-align:center;position:relative;overflow:visible!important}.assignee-badge{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);font-size:var(--font-size-xs);color:var(--color-text-primary);white-space:nowrap;display:inline-flex}.assignee-badge:hover{border-color:var(--color-accent);background:#0071e30f}.assignee-avatar{border-radius:var(--radius-full);background:var(--color-accent);color:#fff;width:20px;height:20px;font-size:10px;font-weight:var(--font-weight-semibold);justify-content:center;align-items:center;display:flex}.assignee-unassigned{color:var(--color-text-tertiary);font-style:italic}.assignee-dropdown{z-index:10;background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:200px;box-shadow:var(--shadow-lg);padding:var(--space-2) 0;animation:fadeIn var(--duration-fast) var(--ease-out);position:absolute;top:calc(100% + 4px);left:0}.assignee-dropdown-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-primary);transition:background var(--duration-fast) var(--ease-out);display:flex}.assignee-dropdown-item:hover{background:var(--color-bg-secondary)}.assignee-dropdown-item.active{color:var(--color-accent);font-weight:var(--font-weight-medium)}.assignee-dropdown-item .assignee-avatar{flex-shrink:0}.deadline-cell{font-size:var(--font-size-xs);color:var(--color-text-secondary);cursor:pointer;text-align:center}.deadline-clickable{cursor:pointer;border-bottom:1px dashed #0000;transition:border-color .15s}.deadline-clickable:hover{border-bottom-color:var(--color-text-tertiary)}.deadline-input{width:120px;font-size:var(--font-size-xs);border:1px solid var(--color-accent);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-primary);outline:none;padding:2px 4px}.deadline-overdue{color:var(--color-error);font-weight:var(--font-weight-medium)}.deadline-soon{color:var(--color-warning)}.log-cell{text-align:center;position:relative}.log-btn{cursor:pointer;opacity:.25;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:12px;transition:all .15s;display:inline-flex}.shot-row:hover .log-btn{opacity:.6}.log-btn:hover{background:var(--color-bg-secondary);opacity:1!important}.log-popup{z-index:30;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:300px;max-height:280px;box-shadow:var(--shadow-lg,0 8px 24px #0000001f);flex-direction:column;display:flex;position:absolute;top:0;right:32px;overflow:hidden}.log-popup-header{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);border-bottom:1px solid var(--color-divider);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.log-popup-close{cursor:pointer;width:20px;height:20px;color:var(--color-text-tertiary);border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;font-size:11px;display:flex}.log-popup-close:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.log-popup-entries{padding:4px 0;overflow-y:auto}.log-entry{align-items:flex-start;gap:8px;padding:6px 12px;transition:background .1s;display:flex}.log-entry:hover{background:var(--color-bg-secondary)}.log-entry-avatar{background:var(--color-accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:1px;font-size:9px;font-weight:600;display:flex}.log-entry-body{flex-direction:column;gap:1px;min-width:0;display:flex}.log-entry-author{font-size:11px;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.log-entry-action{color:var(--color-text-secondary);font-size:11px}.log-entry-time{color:var(--color-text-tertiary);font-size:10px}.status-badge{border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-weight-medium);letter-spacing:.01em;white-space:nowrap;transition:all var(--duration-fast) var(--ease-out);align-items:center;gap:4px;padding:3px 12px 3px 10px;display:inline-flex}.status-badge--draft{background:var(--color-bg-secondary);color:var(--color-text-tertiary)}.status-badge--in-review{color:var(--color-accent);background:#0071e31a}.status-badge--approved{color:var(--color-success);background:#34c7591a}.status-badge--revision{color:var(--color-warning);background:#ff95001a}.status-badge .status-dot{border-radius:var(--radius-full);background:currentColor;width:6px;height:6px}.review-status-cell{cursor:pointer;transition:opacity var(--duration-fast) var(--ease-out)}.status-selector-dropdown{z-index:100;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:2px;min-width:130px;margin-top:4px;padding:6px;display:flex;position:absolute;top:100%;left:0;box-shadow:0 8px 24px #00000040}.status-selector-option{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast) var(--ease-out);padding:4px 6px}.status-selector-option:hover{background:var(--color-bg-secondary)}.status-selector-option.active{opacity:.5;pointer-events:none}.review-status-cell:hover{opacity:.8}.shot-thumb{border-radius:var(--radius-sm);object-fit:cover;background:var(--color-bg-secondary);border:1px solid var(--color-border);width:48px;height:28px}.shot-thumb-empty{border-radius:var(--radius-sm);background:var(--color-bg-secondary);border:1px solid var(--color-divider);width:48px;height:28px;color:var(--color-text-tertiary);justify-content:center;align-items:center;font-size:14px;display:flex}.review-overlay{z-index:100;background:var(--color-bg);animation:reviewFadeIn var(--duration-normal) var(--ease-out);flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}@keyframes reviewFadeIn{0%{opacity:0}to{opacity:1}}.review-backdrop{display:none}.review-header{padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.review-header h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.review-close{border-radius:var(--radius-full);background:var(--color-bg-secondary);width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;justify-content:center;align-items:center;font-size:16px;display:flex}.review-close:hover{background:var(--color-border-strong);color:var(--color-text-primary)}.review-body{flex:1;min-height:0;display:flex;overflow:hidden}.review-preview-area{padding:var(--space-6);background:var(--color-bg);flex-direction:column;flex:7;justify-content:flex-start;align-items:center;min-width:0;display:flex;position:relative;overflow-y:auto}.review-preview-area .review-asset-preview{border-radius:var(--radius-lg);max-width:100%;max-height:calc(100% - 80px);box-shadow:var(--shadow-lg);justify-content:center;align-items:center;display:flex;overflow:hidden}.batch-slot-filled:hover .batch-slot-actions{opacity:1!important}.review-asset-meta-bar{justify-content:center;align-items:center;gap:var(--space-4);margin-top:var(--space-4);flex-shrink:0;display:flex}.review-asset-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.review-asset-version{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-secondary);border-radius:var(--radius-full);padding:2px 10px}.review-preview-area .video-timeline{width:100%;max-width:800px;padding:var(--space-3) 0 0;border-bottom:none}.review-sidebar{border-left:1px solid var(--color-border);background:var(--color-surface);flex-direction:column;flex:3;min-width:280px;max-width:420px;display:flex}.review-actions{gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;display:flex}.btn-approve{color:var(--color-success);border-radius:var(--radius-full);background:#34c7591a;border:1px solid #34c75933}.btn-approve:hover{background:#34c7592e}.btn-revision{color:var(--color-warning);border-radius:var(--radius-full);background:#ff95001a;border:1px solid #ff950033}.btn-revision:hover{background:#ff95002e}.video-timeline{padding:0 var(--space-5) var(--space-3);border-bottom:1px solid var(--color-border);flex-shrink:0}.timeline-slider{appearance:none;background:var(--color-bg-secondary);cursor:pointer;border-radius:2px;outline:none;width:100%;height:4px}.timeline-slider::-webkit-slider-thumb{-webkit-appearance:none;border-radius:var(--radius-full);background:var(--color-accent);cursor:pointer;width:14px;height:14px;box-shadow:var(--shadow-sm)}.timeline-markers{height:8px;margin-top:4px;position:relative}.timeline-marker{border-radius:var(--radius-full);background:var(--color-warning);cursor:pointer;width:6px;height:6px;transition:transform var(--duration-fast) var(--ease-out);position:absolute;top:1px;transform:translate(-50%)}.timeline-marker:hover{transform:translate(-50%)scale(1.4)}.timeline-time{font-size:10px;font-family:var(--font-mono);color:var(--color-text-tertiary);justify-content:space-between;margin-top:2px;display:flex}.review-comments{padding:var(--space-4) var(--space-5);flex:1;overflow-y:auto}.review-comment{gap:var(--space-3);margin-bottom:var(--space-4);animation:fadeIn var(--duration-fast) var(--ease-out);display:flex}.review-comment-avatar{border-radius:var(--radius-full);background:var(--color-bg-tertiary);width:28px;height:28px;font-size:12px;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.review-comment-avatar--lg{width:36px;height:36px;font-size:13px}.review-comment-body{flex:1;min-width:0}.review-comment-header{align-items:baseline;gap:var(--space-2);margin-bottom:2px;display:flex}.review-comment-author{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.review-comment-time{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.review-comment-timecode{font-size:10px;font-family:var(--font-mono);color:var(--color-accent);border-radius:var(--radius-sm);cursor:pointer;background:#0071e314;padding:1px 6px}.review-comment-timecode:hover{background:#0071e326}.review-comment-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.review-comment--system{opacity:.85}.review-comment--system .review-comment-text{color:var(--color-text-secondary);font-style:italic}.status-change-label{align-items:center;gap:4px;font-style:italic;display:inline-flex}.status-change-label strong{color:var(--color-accent);font-style:normal}.review-comment-input{gap:var(--space-2);padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border);flex-shrink:0;align-items:flex-end;display:flex}.review-comment-input textarea{padding:var(--space-2) var(--space-3);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);resize:none;min-height:36px;max-height:100px;transition:border-color var(--duration-fast) var(--ease-out);outline:none;flex:1}.review-comment-input textarea:focus{border-color:var(--color-accent)}.review-comment-input textarea::placeholder{color:var(--color-text-tertiary)}.review-upload-btn{border-radius:var(--radius-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);flex-shrink:0;padding:6px 10px;font-size:16px}.review-upload-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-accent)}.review-upload-btn:disabled{opacity:.5;cursor:not-allowed}.review-send-btn{border-radius:var(--radius-full);background:var(--color-accent);color:#fff;cursor:pointer;width:36px;height:36px;transition:all var(--duration-fast) var(--ease-out);border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.review-send-btn:hover{background:var(--color-accent-hover);transform:scale(1.05)}.review-send-btn:active{transform:scale(.95)}.timecode-attach{align-items:center;gap:var(--space-2);padding:0 var(--space-5) var(--space-2);flex-shrink:0;display:flex}.timecode-attach-badge{font-size:11px;font-family:var(--font-mono);color:var(--color-accent);border-radius:var(--radius-sm);background:#0071e314;align-items:center;gap:4px;padding:2px 8px;display:inline-flex}.timecode-attach-remove{cursor:pointer;opacity:.6;transition:opacity var(--duration-fast)}.timecode-attach-remove:hover{opacity:1}.team-empty{text-align:center;padding:var(--space-16) var(--space-6);color:var(--color-text-tertiary)}.team-empty-icon{margin-bottom:var(--space-4);opacity:.4;font-size:48px}.team-empty h3{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.team-empty p{font-size:var(--font-size-sm)}.group-row{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--duration-fast) var(--ease-out)}.group-row:hover{background:var(--color-bg-secondary)!important}.group-row--scene{background:var(--color-bg-secondary)}.group-row--scene td{padding-top:var(--space-2);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border);font-weight:var(--font-weight-medium)}.group-row--sequence{background:0 0}.group-row--sequence td{padding-top:var(--space-1);padding-bottom:var(--space-1);border-bottom:1px solid var(--color-divider)}.group-toggle{text-align:center;width:28px;padding-left:4px!important;padding-right:0!important}.chevron{color:var(--color-text-tertiary);transition:transform var(--duration-fast) var(--ease-out);font-size:10px;display:inline-block;transform:rotate(0)}.chevron--open{transform:rotate(90deg)}.group-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-right:var(--space-3)}.group-label--seq{font-weight:var(--font-weight-medium);font-size:var(--font-size-xs);color:var(--color-text-secondary);padding-left:4px}.group-label--link,.shot-id-cell--link{cursor:pointer;transition:color var(--duration-fast) var(--ease-out)}.group-label--link:hover,.shot-id-cell--link:hover{color:var(--color-accent);text-underline-offset:2px;text-decoration:underline}.group-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:var(--font-weight-normal)}.group-status-summary{gap:var(--space-3);align-items:center;display:flex}.group-progress{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-normal);font-variant-numeric:tabular-nums}.shot-row td:first-child{width:48px}.team-table td.asset-cell{overflow:visible;padding:var(--space-2) var(--space-3)!important}.asset-preview{align-items:flex-start;gap:var(--space-1);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out);flex-direction:column;padding:4px;display:flex}.asset-preview--clickable{cursor:pointer}.asset-preview--clickable:hover{background:var(--color-bg-secondary);transform:translateY(-1px)}.asset-thumb{aspect-ratio:16/9;border-radius:var(--radius-sm);border:1px solid #0000000f;flex-shrink:0;justify-content:center;align-items:center;width:100%;max-width:120px;display:flex;position:relative;overflow:hidden}.asset-thumb--empty{background:var(--color-bg-secondary);border:1px solid var(--color-divider);color:var(--color-text-tertiary);font-size:var(--font-size-xs)}.asset-thumb-play-overlay{opacity:0;pointer-events:none;z-index:2;background:#0000004d;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.asset-thumb:hover .asset-thumb-play-overlay{opacity:1}.asset-thumb-play-icon{background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex;box-shadow:0 2px 8px #0000004d}.asset-thumb-play-icon:after{content:"";border:5px solid #0000;border-left:9px solid #333;border-right-width:0;width:0;height:0;margin-left:2px;display:block}.asset-thumb-icon{color:#ffffffd9;text-shadow:0 1px 3px #0000004d;font-size:14px}.asset-info{flex-direction:column;gap:2px;min-width:0;display:flex}.asset-comment-count{color:var(--color-text-tertiary);white-space:nowrap;font-size:10px}.asset-upload-btn{color:#fff;cursor:pointer;border-radius:var(--radius-sm);opacity:0;z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:none;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:11px;transition:opacity .15s;display:flex;position:absolute;bottom:2px;right:2px}.asset-upload-btn:hover{background:#6366f1d9}.asset-thumb:hover .asset-upload-btn{opacity:1}.review-asset-preview{border-radius:var(--radius-md);width:100%;overflow:hidden}.review-upload-buttons{gap:6px;margin-left:auto;display:flex}.review-upload-btn{font-size:var(--font-size-xs);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);align-items:center;gap:4px;padding:4px 10px;display:flex}.review-upload-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.review-upload-btn--gallery{border-color:var(--color-accent);color:var(--color-accent)}.review-upload-btn--gallery:hover{background:rgba(var(--color-accent-rgb,99, 102, 241),.1)}.gallery-picker-backdrop{z-index:1100;animation:fadeIn var(--transition-fast) ease-out;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.gallery-picker-modal{background:var(--color-bg-primary);border-radius:var(--radius-xl);width:min(90vw,720px);max-height:80vh;box-shadow:var(--shadow-xl);flex-direction:column;display:flex}.gallery-picker-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.gallery-picker-header h4{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.gallery-picker-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:16px;display:grid;overflow-y:auto}.gallery-picker-item{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:2px solid #0000;overflow:hidden}.gallery-picker-item:hover{border-color:var(--color-accent);transform:scale(1.03)}.gallery-picker-item img,.gallery-picker-item video{width:100%;height:auto;display:block}.seq-video-upload-btn{cursor:pointer;opacity:.5;font-size:14px;transition:opacity .15s}.seq-video-upload-btn:hover{opacity:1}.cell-frame{width:130px;position:relative;overflow:visible;padding:var(--space-1) var(--space-2)!important}.frame-thumb-wrap{border-radius:var(--radius-sm);background:var(--color-bg-secondary);border:1px solid var(--color-divider);width:100%;max-width:120px;position:relative}.frame-thumb-img{object-fit:cover;width:100%;height:100%;display:block}.frame-thumb-empty{opacity:.3;justify-content:center;align-items:center;width:100%;height:100%;font-size:14px;display:flex}.frame-thumb-loading{aspect-ratio:16/9;background:var(--color-bg-tertiary,#2a2a2e);justify-content:center;align-items:center;width:100%;display:flex}.frame-spinner{border:2px solid #ffffff26;border-top-color:var(--color-accent,#6366f1);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite frame-spin}@keyframes frame-spin{to{transform:rotate(360deg)}}.frame-regen-btn{color:#fff;cursor:pointer;border-radius:0 0 0 var(--radius-sm);opacity:0;background:#0000008c;border:none;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-size:10px;transition:opacity .15s;display:flex;position:absolute;top:0;right:0}.frame-thumb-wrap:hover .frame-regen-btn{opacity:1}.cell-beat--editable{cursor:text}.cell-beat--editable:hover{background:#ffffff0a}.beat-text{white-space:pre-wrap;word-break:break-word;line-height:1.4;display:block}.beat-inline-editor{width:100%;min-height:60px;max-height:none;font-family:var(--font-family);font-size:inherit;color:var(--color-text-primary);border:1px solid var(--color-accent);border-radius:var(--radius-sm);resize:none;white-space:pre-wrap;word-break:break-word;field-sizing:content;background:0 0;outline:none;margin:0;padding:0;line-height:1.4;overflow:hidden}.auto-gen-btn:disabled{cursor:not-allowed!important}.beat-expand-btn{cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-sm);background:0 0;border:1px solid #ffffff1f;flex-shrink:0;padding:1px 4px;font-size:.6rem;line-height:1;transition:all .15s}.beat-expand-btn:hover{color:var(--color-accent);border-color:var(--color-accent);background:#0071e314}td.cell-composition,td.cell-subjects{font-size:var(--font-size-xs);color:var(--color-text-secondary);word-break:break-word;line-height:1.3;display:table-cell;overflow:hidden;white-space:normal!important}.projects-page{flex-direction:column;min-height:100vh;display:flex}.projects-header{border-bottom:1px solid var(--color-border);background:var(--color-surface);z-index:50;justify-content:space-between;align-items:center;padding:12px 24px;display:flex;position:sticky;top:0}.projects-header .header-left{align-items:center;gap:12px;display:flex}.projects-header h1{color:var(--color-text);margin:0;font-size:1.1rem;font-weight:600}.projects-page .projects-content{flex:1}.feedback-board{max-width:800px;margin:0 auto;padding:24px}.feedback-board__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.feedback-board__header h2{margin:0;font-size:1.4rem}.feedback-board__tabs{background:var(--color-surface,#1a1a2e);border-radius:10px;gap:4px;padding:4px;display:flex}.feedback-board__tab{color:var(--color-text-secondary,#888);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 20px;font-size:.9rem;font-weight:500;transition:all .15s}.feedback-board__tab:hover{color:var(--color-text-primary,#fff);background:var(--color-surface-elevated,#252540)}.feedback-board__tab.active{background:var(--color-accent,#3b82f6);color:#fff}.feedback-board__toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.feedback-board__sort{align-items:center;gap:8px;display:flex}.feedback-board__sort label{color:var(--color-text-secondary,#888);font-size:.8rem}.feedback-board__sort select{border:1px solid var(--color-border,#333);background:var(--color-surface,#1a1a2e);color:var(--color-text-primary,#eee);border-radius:6px;padding:5px 10px;font-size:.85rem}.feedback-board__sort select option{background:var(--color-surface,#1a1a2e);color:var(--color-text-primary,#eee)}.feedback-board__resolved-toggle{color:var(--color-text-secondary,#888);cursor:pointer;align-items:center;gap:6px;font-size:.8rem;display:flex}.feedback-board__resolved-toggle input{cursor:pointer}.feedback-board__new-btn{background:linear-gradient(90deg,var(--color-accent,#3b82f6),#8b5cf6);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:.9rem;font-weight:500;transition:opacity .15s}.feedback-board__new-btn:hover{opacity:.85}.feedback-board__list{flex-direction:column;gap:12px;display:flex}.feedback-board__empty{text-align:center;color:var(--color-text-secondary,#888);padding:60px 20px;font-size:.95rem}.feedback-card{background:var(--color-surface,#1a1a2e);border:1px solid var(--color-border,#2a2a3e);border-radius:12px;padding:16px;transition:border-color .15s,background .15s}.feedback-card:hover{border-color:var(--color-border-hover,#555);background:var(--color-surface-elevated,#252540)}.feedback-card.resolved{opacity:.6;border-left:3px solid #22c55e}.feedback-card__top{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.feedback-card__author{align-items:center;gap:10px;display:flex}.feedback-card__avatar{object-fit:cover;background:var(--color-surface-elevated,#252540);border-radius:50%;width:32px;height:32px}.feedback-card__avatar-placeholder{background:var(--color-accent,#3b82f6);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:600;display:flex}.feedback-card__author-name{color:var(--color-text-primary,#eee);font-size:.9rem;font-weight:600}.feedback-card__date{color:var(--color-text-secondary,#888);font-size:.75rem}.feedback-card__title{color:var(--color-text-primary,#eee);align-items:center;gap:8px;margin:6px 0;font-size:1.05rem;font-weight:600;display:flex}.feedback-card__ticket-id{color:var(--color-accent,#3b82f6);white-space:nowrap;background:#3b82f61f;border-radius:4px;flex-shrink:0;padding:2px 7px;font-family:monospace;font-size:.7rem;font-weight:600}.feedback-card__project-badge{color:#a855f7;white-space:nowrap;background:#a855f71f;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:.65rem;font-weight:500}.feedback-card__body{color:var(--color-text-secondary,#ccc);white-space:pre-wrap;word-break:break-word;margin-bottom:8px;font-size:.9rem;line-height:1.5}.feedback-card__body strong{color:var(--color-text-primary,#fff);font-weight:700}.feedback-card__media{margin:10px 0}.feedback-card__media img{object-fit:cover;cursor:pointer;border-radius:8px;max-width:180px;max-height:120px;transition:opacity .15s}.feedback-card__media img:hover{opacity:.8}.feedback-card__media video{border-radius:8px;max-width:280px;max-height:160px}.feedback-lightbox{z-index:2000;cursor:pointer;background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.feedback-lightbox__close{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;transition:background .15s;display:flex;position:absolute;top:16px;right:20px}.feedback-lightbox__close:hover{background:#ffffff4d}.feedback-lightbox img{object-fit:contain;cursor:default;border-radius:8px;max-width:90vw;max-height:90vh}.feedback-card__footer{justify-content:space-between;align-items:center;gap:10px;margin-top:10px;display:flex}.feedback-card__left{align-items:center;gap:12px;display:flex}.feedback-card__severity{text-transform:uppercase;border-radius:12px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.feedback-card__severity.critical{color:#ef4444;background:#ef444426}.feedback-card__severity.high{color:#f97316;background:#f9731626}.feedback-card__severity.medium{color:#eab308;background:#eab30826}.feedback-card__severity.low{color:#22c55e;background:#22c55e26}.feedback-card__vote{border:1px solid var(--color-border,#333);color:var(--color-text-secondary,#888);cursor:pointer;background:0 0;border-radius:16px;align-items:center;gap:5px;padding:4px 12px;font-size:.85rem;transition:all .15s;display:flex}.feedback-card__vote:hover{border-color:var(--color-accent,#3b82f6);color:var(--color-accent,#3b82f6)}.feedback-card__vote.voted{border-color:var(--color-accent,#3b82f6);color:var(--color-accent,#3b82f6);background:#3b82f626}.feedback-card__actions{align-items:center;gap:6px;display:flex}.feedback-card__action-btn{border:1px solid var(--color-border,#333);color:var(--color-text-secondary,#888);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font-size:.75rem;transition:all .15s}.feedback-card__action-btn:hover{border-color:var(--color-accent,#3b82f6);color:var(--color-accent,#3b82f6)}.feedback-card__action-btn.delete:hover{color:#ef4444;border-color:#ef4444}.feedback-card__action-btn.resolve{color:#22c55e;border-color:#22c55e}.feedback-card__resolved-badge{color:#22c55e;font-size:.75rem;font-weight:600}.feedback-card__status-badge{border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-flex}.feedback-card__status-badge.status-needs_clarification{color:#eab308;background:#eab30826}.feedback-card__status-badge.status-in_progress{color:#3b82f6;background:#3b82f626}.feedback-card__status-select{border:1px solid var(--color-border,#333);background:var(--color-surface-elevated,#252540);color:var(--color-text-primary,#eee);cursor:pointer;border-radius:6px;padding:3px 8px;font-size:.75rem}.feedback-card__status-select option{background:var(--color-surface-elevated,#252540);color:var(--color-text-primary,#eee)}.feedback-board__status-filter select{border:1px solid var(--color-border,#333);background:var(--color-surface,#1a1a2e);color:var(--color-text-primary,#eee);border-radius:6px;padding:5px 10px;font-size:.85rem}.feedback-board__status-filter select option{background:var(--color-surface,#1a1a2e);color:var(--color-text-primary,#eee)}.feedback-modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.feedback-modal{background:var(--color-surface,#1a1a2e);border:1px solid var(--color-border,#2a2a3e);border-radius:16px;width:640px;max-width:90vw;max-height:85vh;padding:28px;overflow-y:auto}.feedback-modal h3{margin:0 0 20px;font-size:1.2rem}.feedback-modal__field{margin-bottom:16px}.feedback-modal__field label{color:var(--color-text-secondary,#888);margin-bottom:6px;font-size:.8rem;display:block}.feedback-modal__field input[type=text],.feedback-modal__field textarea,.feedback-modal__field select{border:1px solid var(--color-border,#333);background:var(--color-surface-elevated,#252540);width:100%;color:var(--color-text-primary,#eee);box-sizing:border-box;border-radius:8px;padding:10px 14px;font-size:.9rem}.feedback-modal__field input[type=text]:focus,.feedback-modal__field textarea:focus,.feedback-modal__field select:focus{border-color:var(--color-accent,#3b82f6);outline:none}.feedback-modal__field textarea{resize:vertical;min-height:180px;font-family:inherit;line-height:1.5}.feedback-modal__field select option{background:var(--color-surface-elevated,#252540);color:var(--color-text-primary,#eee)}.feedback-modal__upload-btn{border:1px dashed var(--color-border,#555);color:var(--color-text-secondary,#888);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:.85rem;transition:border-color .15s;display:inline-flex}.feedback-modal__upload-btn:hover{border-color:var(--color-accent,#3b82f6);color:var(--color-accent,#3b82f6)}.feedback-modal__preview{margin-top:8px;display:inline-block;position:relative}.feedback-modal__preview img{border-radius:6px;max-width:100%;max-height:150px}.feedback-modal__remove-media{color:#fff;cursor:pointer;background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;transition:background .15s;display:flex;position:absolute;top:4px;right:4px}.feedback-modal__remove-media:hover{background:#ef4444}.feedback-modal__actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.feedback-modal__cancel{border:1px solid var(--color-border,#333);color:var(--color-text-primary,#eee);cursor:pointer;background:0 0;border-radius:8px;padding:9px 18px;transition:background .15s}.feedback-modal__cancel:hover{background:var(--color-surface-elevated,#252540)}.feedback-modal__submit{background:linear-gradient(90deg,var(--color-accent,#3b82f6),#8b5cf6);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:9px 18px;font-weight:500;transition:opacity .15s}.feedback-modal__submit:hover{opacity:.85}.feedback-modal__submit:disabled{opacity:.5;cursor:not-allowed}.feedback-board__back-btn{border:1px solid var(--color-border,#333);color:var(--color-text-secondary,#888);cursor:pointer;background:0 0;border-radius:8px;margin-bottom:16px;padding:6px 14px;font-size:.85rem;transition:all .15s}.feedback-board__back-btn:hover{border-color:var(--color-accent,#3b82f6);color:var(--color-accent,#3b82f6)}.feedback-card.detail{cursor:default}.feedback-card.detail:hover{background:var(--color-surface,#1a1a2e);border-color:var(--color-border,#2a2a3e)}.feedback-card__comment-count{color:var(--color-text-secondary,#888);font-size:.8rem}.feedback-card__edit-form{flex-direction:column;gap:10px;margin:10px 0;display:flex}.feedback-card__edit-title{border:1px solid var(--color-border,#333);background:var(--color-surface-elevated,#252540);width:100%;color:var(--color-text-primary,#eee);box-sizing:border-box;border-radius:8px;padding:10px 14px;font-size:1rem;font-weight:600}.feedback-card__edit-body{border:1px solid var(--color-border,#333);background:var(--color-surface-elevated,#252540);width:100%;min-height:120px;color:var(--color-text-primary,#eee);resize:vertical;box-sizing:border-box;border-radius:8px;padding:10px 14px;font-family:inherit;font-size:.9rem;line-height:1.5}.feedback-card__edit-title:focus,.feedback-card__edit-body:focus{border-color:var(--color-accent,#3b82f6);outline:none}.feedback-comments{margin-top:24px}.feedback-comments h4{color:var(--color-text-primary,#eee);margin:0 0 14px;font-size:1rem}.feedback-comment{background:var(--color-surface,#1a1a2e);border:1px solid var(--color-border,#2a2a3e);border-radius:10px;margin-bottom:8px;padding:12px 14px}.feedback-comment__header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.feedback-comment__body{color:var(--color-text-secondary,#ccc);white-space:pre-wrap;word-break:break-word;font-size:.88rem;line-height:1.5}.feedback-comment__form{flex-direction:column;gap:8px;margin-top:14px;display:flex}.feedback-comment__form textarea{border:1px solid var(--color-border,#333);background:var(--color-surface-elevated,#252540);width:100%;color:var(--color-text-primary,#eee);resize:none;box-sizing:border-box;border-radius:8px;min-height:42px;max-height:120px;padding:10px 14px;font-family:inherit;font-size:.88rem}.feedback-comment__form textarea:focus{border-color:var(--color-accent,#3b82f6);outline:none}.feedback-comment__form button{align-self:flex-end}.feedback-card.with-ice{gap:0;display:flex}.feedback-card__main{flex:1;min-width:0}.feedback-card__ice-side{border-left:1px solid var(--color-border,#2a2a3e);grid-template-rows:repeat(3,auto) auto;grid-template-columns:12px 40px;align-items:center;gap:4px 5px;margin-left:12px;padding:8px 12px;display:grid}.feedback-card__ice-row{display:contents}.feedback-card__ice-row span{color:var(--color-text-secondary,#888);text-align:center;font-size:.7rem;font-weight:700}.feedback-card__ice-row input[type=text]{border:1px solid var(--color-border,#333);background:var(--color-surface-elevated,#252540);width:40px;color:var(--color-text-primary,#eee);text-align:center;border-radius:5px;padding:3px 4px;font-size:.8rem}.feedback-card__ice-row input[type=text]:focus{border-color:#fbbf24;outline:none}.feedback-card__ice-sum{text-align:center;color:#fbbf24;white-space:nowrap;grid-column:1/-1;margin-top:2px;font-size:.85rem;font-weight:700}.feedback-card__ice-admin{background:#fbbf240f;border:1px solid #fbbf2433;border-radius:10px;margin:12px 0 4px;padding:10px 14px}.feedback-card__ice-label{color:#fbbf24;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.feedback-card__ice-inputs{align-items:center;gap:12px;margin-top:8px;display:flex}.feedback-card__ice-inputs label{color:var(--color-text-secondary,#aaa);align-items:center;gap:4px;font-size:.8rem;font-weight:600;display:flex}.feedback-card__ice-inputs input[type=text]{border:1px solid var(--color-border,#333);background:var(--color-surface,#1a1a2e);width:48px;color:var(--color-text-primary,#eee);text-align:center;border-radius:6px;padding:4px 6px;font-size:.85rem}.feedback-card__ice-inputs input[type=text]:focus{border-color:#fbbf24;outline:none}.feedback-card__ice-total{color:#fbbf24;margin-left:4px;font-size:1rem;font-weight:700}.feedback-card__ice-badge{color:#fbbf24;background:#fbbf241f;border-radius:12px;align-items:center;gap:3px;padding:2px 8px;font-size:.75rem;font-weight:700;display:inline-flex}.main-content:has(.freeform-panel--chat-mode){overflow:hidden}.freeform-panel--chat-mode{flex-direction:column;height:calc(100vh - 160px);display:flex;overflow:hidden;padding:8px 12px!important}.freeform-panel--chat-mode .freeform-header-row{margin-bottom:6px}.freeform-header-row{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.freeform-header-row h4{margin:0}.freeform-mode-toggle{background:var(--color-bg-secondary);border-radius:var(--radius-full,20px);gap:2px;width:fit-content;padding:2px;display:flex}.freeform-mode-btn{border-radius:var(--radius-full,20px);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:5px 14px;font-size:.8rem;font-weight:500;transition:all .15s}.freeform-mode-btn.active{background:var(--color-surface-elevated,var(--color-surface));color:var(--color-text-primary);box-shadow:0 1px 3px #0000001a}.freeform-mode-btn:hover:not(.active){color:var(--color-text-primary)}.freeform-slots{gap:var(--space-2);flex-wrap:wrap;display:flex}.freeform-slot{border-radius:var(--radius-md);cursor:pointer;width:72px;height:72px;transition:all var(--duration-fast);flex-shrink:0;position:relative;overflow:visible}.freeform-slot--empty{border:2px dashed var(--color-border-strong);background:var(--color-bg-secondary);justify-content:center;align-items:center;display:flex;overflow:visible}.freeform-slot--empty:hover{border-color:var(--color-accent);background:#0071e30f}.freeform-slot__plus{color:var(--color-text-tertiary);font-size:26px;font-weight:300;line-height:1}.freeform-slot--empty:hover .freeform-slot__plus{color:var(--color-accent)}.freeform-slot--filled{border:1px solid var(--color-border);overflow:hidden}.freeform-slot--uploading{border:2px dashed var(--color-accent,#3b82f6);cursor:default;background:#3b82f60f;justify-content:center;align-items:center;animation:1.5s ease-in-out infinite slot-pulse;display:flex}@keyframes slot-pulse{0%,to{border-color:var(--color-accent,#3b82f6);opacity:.7}50%{border-color:var(--color-accent,#60a5fa);opacity:1}}.freeform-slot__spinner{border:2.5px solid #3b82f633;border-top-color:var(--color-accent,#3b82f6);border-radius:50%;width:22px;height:22px;animation:.8s linear infinite slot-spin}@keyframes slot-spin{to{transform:rotate(360deg)}}.freeform-slot__img{object-fit:cover;width:100%;height:100%;display:block}.freeform-slot__remove{background:var(--color-error);color:#fff;cursor:pointer;opacity:0;width:20px;height:20px;transition:opacity var(--duration-fast);z-index:2;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:11px;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.freeform-slot--filled:hover .freeform-slot__remove{opacity:1}.freeform-slot__menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;min-width:160px;position:absolute;top:calc(100% + 6px);left:50%;overflow:hidden;transform:translate(-50%)}.freeform-slot__menu-item{text-align:left;width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;transition:background var(--duration-fast);white-space:nowrap;background:0 0;border:none;display:block}.freeform-slot__menu-item:hover{background:var(--color-bg-secondary)}.freeform-slot__menu-item+.freeform-slot__menu-item{border-top:1px solid var(--color-border)}.freeform-panel__results-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.freeform-panel__result-card{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);transition:transform var(--duration-fast),box-shadow var(--duration-fast);cursor:pointer;position:relative;overflow:hidden}.freeform-panel__result-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.freeform-panel__result-img{width:100%;display:block}.freeform-video-play-overlay{color:#fff;pointer-events:none;opacity:.85;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;transition:opacity .15s,transform .15s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-60%)}.freeform-panel__result-card:hover .freeform-video-play-overlay{opacity:1;transform:translate(-50%,-60%)scale(1.1)}.freeform-video-badge{color:#fff;white-space:nowrap;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border-radius:10px;padding:2px 8px;font-size:10px;position:absolute;top:6px;left:6px}.freeform-panel__result-actions{justify-content:flex-end;gap:var(--space-2);padding:var(--space-2) var(--space-3);display:flex}.freeform-panel__action-btn{font-size:var(--font-size-sm);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--duration-fast);color:var(--color-text-secondary);background:0 0;border:none;padding:2px 6px}.freeform-panel__action-btn:hover{background:var(--color-bg-secondary)}.image-settings input[type=text],.image-settings input[type=number],.mj-input-number,.mj-input-text{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);border-radius:4px;padding:.375rem .75rem;font-size:.813rem}.mj-input-number{width:80px}.mj-input-text{flex:1;min-width:120px}.image-settings input:focus{border-color:var(--color-accent);outline:none}.image-settings input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-accent);cursor:pointer}.mj-ref-picker{align-items:center;gap:.5rem;width:100%;display:flex}.mj-ref-picker>label{color:var(--color-text-secondary);white-space:nowrap;min-width:110px;font-size:.813rem}.mj-ref-slot-row{gap:var(--space-2);display:flex}.freeform-character-item{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;text-align:left;align-items:center;gap:10px;width:100%;padding:8px 12px;transition:all .15s;display:flex}.freeform-character-item:hover{border-color:var(--color-accent);background:var(--color-bg-secondary)}.freeform-character-avatar{object-fit:cover;border:2px solid var(--color-border);border-radius:50%;flex-shrink:0;width:36px;height:36px}.freeform-character-info{flex-direction:column;min-width:0;display:flex}.freeform-character-name{color:var(--color-text-primary);font-size:.85rem;font-weight:600}.freeform-character-nick{color:var(--color-text-secondary);font-size:.75rem}.video-mode-selector{background:var(--color-bg-secondary);border-radius:var(--radius-lg,12px);margin-bottom:var(--space-3);gap:4px;padding:3px;display:flex}.video-mode-btn{border-radius:var(--radius-md,8px);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;flex:1;padding:6px 10px;font-size:.78rem;font-weight:500;transition:all .15s}.video-mode-btn.active{background:var(--color-surface-elevated,var(--color-surface));color:var(--color-text-primary);box-shadow:0 1px 4px #00000026}.video-mode-btn:hover:not(.active){color:var(--color-text-primary);background:#ffffff0d}.multishot-editor{gap:var(--space-3);margin-bottom:var(--space-3);flex-direction:column;display:flex}.multishot-item{background:var(--color-bg-secondary);border-radius:var(--radius-lg,12px);padding:var(--space-3);border:1px solid var(--color-border,#ffffff1a)}.multishot-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.multishot-drag{cursor:grab;color:var(--color-text-secondary);background:var(--color-surface-elevated,#ffffff14);border-radius:var(--radius-sm,6px);-webkit-user-select:none;user-select:none;padding:4px 8px;font-size:1.1rem}.multishot-label{color:var(--color-text-primary);background:var(--color-surface-elevated,#ffffff14);border-radius:var(--radius-sm,6px);padding:4px 12px;font-size:.85rem;font-weight:600}.multishot-duration{border-radius:var(--radius-sm,6px);background:var(--color-surface-elevated,#ffffff14);color:var(--color-text-primary);border:1px solid var(--color-border,#ffffff1a);padding:4px 8px;font-size:.85rem}.multishot-delete{cursor:pointer;opacity:.6;background:0 0;border:none;margin-left:auto;padding:4px;font-size:1rem;transition:opacity .15s}.multishot-delete:hover{opacity:1}.multishot-textarea{min-height:60px;font-size:.85rem}.multishot-add{align-self:flex-start;padding:6px 16px;font-size:.85rem}.multishot-total{color:var(--color-text-secondary);text-align:right;font-size:.8rem;font-weight:500}.multishot-total--error{color:var(--color-error,#ef4444);font-weight:600}.elements-editor{margin-bottom:var(--space-3)}.elements-editor h5{margin:0 0 var(--space-2) 0;color:var(--color-text-primary);font-size:.85rem}.elements-grid{gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));display:grid}.element-slot{aspect-ratio:1;border-radius:var(--radius-md,8px);border:1px solid var(--color-border,#ffffff1a);background:var(--color-bg-secondary);position:relative;overflow:hidden}.element-slot img{object-fit:cover;width:100%;height:100%}.element-remove{color:#fff;cursor:pointer;background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;padding:0;font-size:.7rem;display:flex;position:absolute;top:4px;right:4px}.element-slot--add{flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:8px;display:flex}.element-slot--add input[type=text]{border-radius:var(--radius-sm,4px);border:1px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text-primary);padding:4px 6px;font-size:.7rem}.element-upload-btn{color:var(--color-primary);cursor:pointer;font-size:.7rem;text-decoration:underline}.freeform-drop-active{outline:2px dashed var(--color-accent);outline-offset:-2px;transition:outline .15s,background .15s;background:#0071e30f!important}.freeform-drop-hint{text-align:center;color:var(--color-accent);padding:8px;font-size:.85rem;font-weight:500;animation:1s infinite dropPulse}@keyframes dropPulse{0%,to{opacity:.7}50%{opacity:1}}.locations-view{padding:1.5rem}.locations-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.locations-header h2{margin:0;font-size:1.4rem}.locations-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem;display:grid}.location-card{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;transition:all .2s;position:relative;overflow:hidden}.location-card:hover{border-color:var(--color-accent);transform:translateY(-2px);box-shadow:0 4px 16px #0003}.location-delete-btn{color:#fff;cursor:pointer;opacity:0;z-index:2;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;line-height:1;transition:opacity .15s,background .15s;display:flex;position:absolute;top:8px;right:8px}.location-card:hover .location-delete-btn{opacity:1}.location-delete-btn:hover{background:var(--color-danger,#e53e3e)}.loc-confirm-overlay{z-index:1500;background:#000000b3;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.loc-confirm-modal{background:var(--color-surface);border:1px solid var(--color-border);text-align:center;border-radius:16px;width:90%;max-width:360px;padding:2rem 2.5rem;animation:.15s scaleIn}.loc-confirm-icon{margin-bottom:.5rem;font-size:2.5rem}.loc-confirm-modal h3{margin:0 0 .5rem;font-size:1.2rem}.loc-confirm-modal p{color:var(--color-text-secondary);margin:0 0 1.5rem;font-size:.9rem}.loc-confirm-actions{justify-content:center;gap:.75rem;display:flex}.loc-confirm-actions .btn-danger{background:var(--color-danger,#e53e3e);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.5rem;font-weight:600;transition:background .2s}.loc-confirm-actions .btn-danger:hover{background:#c53030}.location-card-thumb{background:var(--color-bg);height:140px;overflow:hidden}.location-card-thumb img{object-fit:cover;width:100%;height:100%}.thumb-placeholder{opacity:.3;justify-content:center;align-items:center;width:100%;height:100%;font-size:3rem;display:flex}.location-card-body{padding:.8rem 1rem 1rem}.location-card-id{color:var(--color-accent);opacity:.8;font-family:JetBrains Mono,monospace;font-size:.7rem}.location-card-name{margin:.3rem 0 .2rem;font-size:.95rem;font-weight:600}.location-card-desc{color:var(--color-text-secondary);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.8rem;display:-webkit-box;overflow:hidden}.location-card-count{color:var(--color-text-secondary);margin-top:.5rem;font-size:.75rem}.btn-back{border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;background:0 0;border-radius:6px;padding:.4rem 1rem;font-size:.85rem}.btn-back:hover{border-color:var(--color-accent)}.location-detail{grid-template-columns:1fr 1fr;gap:2rem;margin-top:1rem;display:grid}.location-id-badge{color:var(--color-accent);background:var(--color-bg);border-radius:4px;margin-bottom:.5rem;padding:.2rem .6rem;font-family:JetBrains Mono,monospace;font-size:.75rem;display:inline-block}.location-name{cursor:pointer;margin:0 0 .5rem;font-size:1.3rem;font-weight:600}.location-name:hover .edit-hint,.location-description:hover .edit-hint{opacity:1}.edit-hint{opacity:0;font-size:.8em;transition:opacity .2s}.location-description{color:var(--color-text-secondary);cursor:pointer;margin:0 0 1rem;font-size:.9rem;line-height:1.5}.inline-edit{margin-bottom:.5rem}.edit-input{background:var(--color-bg);border:1px solid var(--color-accent);width:100%;color:var(--color-text);border-radius:6px;padding:.5rem;font-family:inherit}.name-input{font-size:1.3rem;font-weight:600}.desc-input{resize:vertical;font-size:.9rem}.location-sequences{margin-top:1.5rem}.location-sequences h3{margin:0 0 .5rem;font-size:.95rem}.sequence-link{cursor:pointer;color:var(--color-accent);border-radius:6px;padding:.4rem .6rem;font-size:.85rem;transition:background .15s}.sequence-link:hover{background:var(--color-surface)}.location-detail-images h3{margin:0 0 .8rem;font-size:.95rem}.location-images-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.6rem;display:grid}.location-image-item{aspect-ratio:4/3;border-radius:8px;position:relative;overflow:hidden}.location-image-item img{object-fit:cover;width:100%;height:100%}.img-delete-btn{color:#fff;cursor:pointer;opacity:0;background:#000000b3;border:none;border-radius:50%;width:22px;height:22px;font-size:.7rem;transition:opacity .2s;position:absolute;top:4px;right:4px}.location-image-item:hover .img-delete-btn{opacity:1}.location-image-add{aspect-ratio:4/3;border:2px dashed var(--color-border);cursor:pointer;opacity:.4;border-radius:8px;justify-content:center;align-items:center;font-size:2rem;transition:all .2s;display:flex}.location-image-add:hover{border-color:var(--color-accent);opacity:.7}.location-image-actions{gap:.5rem;margin-top:.6rem;display:flex}.btn-secondary{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;border-radius:6px;padding:.4rem .8rem;font-size:.8rem}.btn-secondary:hover{border-color:var(--color-accent)}.empty-state{text-align:center;color:var(--color-text-secondary);padding:3rem}.loc-fullscreen-overlay{z-index:2000;cursor:pointer;background:#000000eb;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.loc-fullscreen-close{color:#fff;cursor:pointer;opacity:.7;z-index:2001;background:0 0;border:none;font-size:2rem;transition:opacity .2s;position:absolute;top:1.5rem;right:1.5rem}.loc-fullscreen-close:hover{opacity:1}.loc-fullscreen-img{object-fit:contain;cursor:pointer;border-radius:8px;max-width:85vw;max-height:85vh}.loc-fullscreen-nav{color:#fff;cursor:pointer;opacity:.6;z-index:2001;background:#ffffff1a;border:none;border-radius:8px;justify-content:center;align-items:center;width:50px;height:80px;font-size:3rem;transition:all .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.loc-fullscreen-nav:hover{opacity:1;background:#fff3}.loc-fullscreen-prev{left:1.5rem}.loc-fullscreen-next{right:1.5rem}.loc-fullscreen-counter{color:#fff;z-index:2001;background:#0009;border-radius:20px;padding:.3rem 1rem;font-size:.85rem;position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%)}.loc-confirm-modal.loc-create-modal{text-align:left;max-width:420px}.loc-create-modal h3{text-align:center;margin:0 0 1rem;font-size:1.15rem}.loc-create-form{flex-direction:column;gap:.75rem;display:flex}.loc-create-form .edit-input{background:var(--color-bg);border:1px solid var(--color-border);width:100%;color:var(--color-text);border-radius:8px;padding:.6rem .75rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.loc-create-form .edit-input:focus{border-color:var(--color-accent);outline:none}.loc-create-form .name-input{font-size:1rem;font-weight:500}.loc-create-form .desc-input{resize:vertical;min-height:60px;font-size:.9rem}.loc-confirm-actions .btn-primary{background:var(--color-accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.5rem;font-weight:600;transition:opacity .2s}.loc-confirm-actions .btn-primary:hover{opacity:.85}.loc-confirm-actions .btn-primary:disabled{opacity:.4;cursor:not-allowed}.permissions-panel{flex-direction:column;gap:20px;height:100%;padding:24px;display:flex}.permissions-panel__header h2{color:var(--color-text-primary);margin:0 0 4px;font-size:1.4rem}.permissions-panel__subtitle{color:var(--color-text-secondary);margin:0;font-size:.85rem}.permissions-panel__layout{flex:1;gap:20px;min-height:0;display:flex}.permissions-panel__sidebar{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;width:240px;min-width:240px;display:flex;overflow:hidden}.permissions-panel__sidebar-header{border-bottom:1px solid var(--color-border);padding:12px 16px}.permissions-panel__sidebar-header h3{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.9rem}.permissions-panel__groups-list{flex:1;padding:8px;overflow-y:auto}.permissions-panel__group-item{cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:10px 12px;transition:all .15s;display:flex}.permissions-panel__group-item:hover{background:var(--color-bg-hover)}.permissions-panel__group-item.active{background:var(--color-accent,#3b82f6);color:#fff}.permissions-panel__group-item.active .permissions-panel__group-members{color:#ffffffb3}.permissions-panel__group-info{flex-direction:column;gap:2px;display:flex}.permissions-panel__group-name{font-size:.9rem;font-weight:600}.permissions-panel__group-members{color:var(--color-text-secondary);font-size:.75rem}.permissions-panel__delete-btn{color:var(--color-text-secondary);cursor:pointer;opacity:0;background:0 0;border:none;padding:0 4px;font-size:1.2rem;transition:opacity .15s}.permissions-panel__group-item:hover .permissions-panel__delete-btn{opacity:1}.permissions-panel__delete-btn:hover{color:#ef4444}.permissions-panel__new-group{border-top:1px solid var(--color-border);gap:4px;padding:8px;display:flex}.permissions-panel__new-group-input{border:1px solid var(--color-border);background:var(--color-bg-primary);color:var(--color-text-primary);border-radius:6px;flex:1;padding:6px 10px;font-size:.85rem}.permissions-panel__new-group-btn{border:1px solid var(--color-border);background:var(--color-accent,#3b82f6);color:#fff;cursor:pointer;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;display:flex}.permissions-panel__new-group-btn:disabled{opacity:.5;cursor:default}.permissions-panel__content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;flex:1;display:flex;overflow:hidden}.permissions-panel__content-header{border-bottom:1px solid var(--color-border);padding:16px 20px}.permissions-panel__content-header h3{margin:0 0 4px;font-size:1.1rem}.permissions-panel__content-desc{color:var(--color-text-secondary);margin:0 0 12px;font-size:.85rem}.permissions-panel__tabs{background:var(--color-bg-primary);border-radius:8px;gap:4px;width:fit-content;padding:3px;display:flex}.permissions-panel__tab{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:6px;padding:6px 16px;font-size:.85rem;transition:all .15s}.permissions-panel__tab.active{background:var(--color-accent,#3b82f6);color:#fff;font-weight:600}.permissions-panel__blocks{flex-direction:column;flex:1;gap:16px;padding:16px 20px;display:flex;overflow-y:auto}.permissions-panel__block{border:1px solid var(--color-border);border-radius:10px;overflow:hidden}.permissions-panel__block-header{background:var(--color-bg-primary);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.permissions-panel__block-header:hover{background:var(--color-bg-hover)}.permissions-panel__block-title{font-size:.9rem;font-weight:600}.permissions-panel__block-toggle{font-size:.8rem;font-weight:500}.permissions-panel__block-toggle.all{color:#22c55e}.permissions-panel__block-toggle.partial{color:#f59e0b}.permissions-panel__block-toggle.none{color:var(--color-text-secondary)}.permissions-panel__block-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:4px 16px;padding:12px 16px;display:grid}.permissions-panel__perm-item{cursor:pointer;align-items:center;gap:8px;padding:4px 0;font-size:.85rem;display:flex}.permissions-panel__perm-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-accent,#3b82f6);cursor:pointer}.permissions-panel__perm-label{color:var(--color-text-primary)}.permissions-panel__save-bar{justify-content:flex-end;padding:16px 0 0;display:flex}.permissions-panel__save-btn{background:var(--color-accent,#3b82f6);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:.9rem;font-weight:600;transition:all .15s}.permissions-panel__save-btn:hover{filter:brightness(1.1)}.permissions-panel__save-btn:disabled{opacity:.6;cursor:default}.permissions-panel__users-list{flex:1;padding:16px 20px;overflow-y:auto}.permissions-panel__users-hint{color:var(--color-text-secondary);margin:0 0 12px;font-size:.85rem}.permissions-panel__user-row{border-radius:8px;grid-template-columns:1fr 160px auto;align-items:center;gap:12px;margin-bottom:2px;padding:10px 16px;transition:background .12s;display:grid}.permissions-panel__user-row:nth-child(2n){background:#ffffff05}.permissions-panel__user-row:hover{background:var(--color-bg-hover)}.permissions-panel__user-info{flex-direction:column;gap:2px;min-width:0;display:flex}.permissions-panel__user-name{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-size:.9rem;font-weight:500;display:flex;overflow:hidden}.permissions-panel__admin-badge{color:#000;text-transform:uppercase;background:#f59e0b;border-radius:4px;padding:1px 6px;font-size:.7rem;font-weight:700}.permissions-panel__user-email{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.permissions-panel__user-actions{align-items:center;gap:4px;display:flex}.permissions-panel__assign-btn{border:1px solid var(--color-border);background:var(--color-bg-primary);color:var(--color-text-primary);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:.8rem;transition:all .15s}.permissions-panel__assign-btn:hover{border-color:var(--color-accent,#3b82f6);color:var(--color-accent,#3b82f6)}.permissions-panel__assign-btn.assigned{background:var(--color-accent,#3b82f6);color:#fff;border-color:var(--color-accent,#3b82f6)}.permissions-panel__role-select{border:1px solid var(--color-border);background:var(--color-bg-primary);color:var(--color-text-primary);cursor:pointer;border-radius:6px;width:100%;padding:6px 10px;font-size:.85rem;transition:border-color .15s}.permissions-panel__role-select:hover,.permissions-panel__role-select:focus{border-color:var(--color-accent,#3b82f6);outline:none}.permissions-panel__reset-btn{border:1px solid var(--color-border);cursor:pointer;opacity:.4;background:0 0;border-radius:6px;flex-shrink:0;padding:4px 8px;font-size:.9rem;transition:all .15s}.permissions-panel__reset-btn:hover{opacity:1;border-color:var(--color-accent,#3b82f6);background:#3b82f61a}.permissions-panel__delete-user-btn{cursor:pointer;opacity:.3;color:var(--color-text-secondary);background:0 0;border:1px solid #0000;border-radius:6px;flex-shrink:0;padding:4px 8px;font-size:.9rem;transition:all .15s}.permissions-panel__delete-user-btn:hover{opacity:1;color:#ef4444;background:#ef44441a;border-color:#ef4444}.permissions-panel__header-row{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.permissions-panel__sim-badge{white-space:nowrap;border-radius:10px;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:500;display:flex}.permissions-panel__sim-badge.active{color:#f59e0b;background:#f59e0b26;border:1px solid #f59e0b66}.permissions-panel__sim-badge.inactive{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e40}.permissions-panel__sim-dot{background:#f59e0b;border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite sim-pulse}@keyframes sim-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.permissions-panel__sim-exit{color:#f59e0b;cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 2px;font-size:1rem}.permissions-panel__sim-exit:hover{opacity:1}.permissions-panel__group-actions{align-items:center;gap:2px;display:flex}.permissions-panel__preview-btn{cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.9rem;transition:opacity .15s}.permissions-panel__group-item:hover .permissions-panel__preview-btn{opacity:.7}.permissions-panel__preview-btn:hover{background:#ffffff1a;opacity:1!important}.permissions-panel__preview-btn.active{background:#f59e0b33;opacity:1!important}.permissions-panel__invite{padding:20px}.permissions-panel__field-label{color:var(--color-text-secondary);margin-bottom:-6px;font-size:.8rem;font-weight:600}.permissions-panel__invite-form{flex-direction:column;gap:12px;max-width:400px;display:flex}.permissions-panel__invite-form .input,.permissions-panel__invite-form select{padding:10px 14px;font-size:.9rem}.permissions-panel__invite-result{border-radius:8px;margin-top:16px;padding:12px 16px;font-size:.9rem;font-weight:500}.permissions-panel__invite-result.success{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e40}.permissions-panel__invite-result.error{color:#ef4444;background:#ef44441f;border:1px solid #ef444440}.sequence-view{max-width:900px;margin:0 auto;padding:2rem}.sequence-view .sequence-header{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;padding:1rem 1.5rem;display:flex}.sequence-view .header-top{flex:1;align-items:center;gap:1rem;min-width:0;display:flex}.sequence-view .header-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.sequence-view .btn-copy-json{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;padding:.25rem .75rem;font-size:.8rem;transition:all .15s}.sequence-view .btn-copy-json:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sequence-view .btn-danger-subtle{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;padding:.25rem .75rem;font-size:.8rem;transition:all .15s}.sequence-view .btn-danger-subtle:hover{color:#ff3b30;background:#ff3b301a;border-color:#ff3b304d}.sequence-view .seq-badge{background:var(--color-accent);color:#fff;border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;padding:.25rem .75rem;font-size:.8rem;font-weight:600}.sequence-view h1{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:400px;margin:0;font-size:1.5rem;font-weight:600;overflow:hidden}.sequence-view .duration-badge{background:var(--color-bg-secondary);border-radius:var(--radius-full);color:var(--color-text-secondary);padding:.25rem .75rem;font-size:.85rem}.sequence-sections{flex-direction:column;gap:1.5rem;display:flex}.sequence-view .section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.sequence-view .section h2{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);color:var(--color-text-primary);align-items:center;gap:6px;margin:0;padding:.75rem 1rem;font-size:.9rem;font-weight:600;display:flex}.sequence-view .section-content{padding:1rem}.sequence-view .field-row{border-bottom:1px solid var(--color-divider);cursor:pointer;grid-template-columns:16px 140px 1fr;align-items:start;gap:.5rem .75rem;padding:.5rem 0;transition:background .15s;display:grid}.sequence-view .field-row>.mute-toggle-wrap{margin-top:2px}.sequence-view .field-row:last-child{border-bottom:none}.sequence-view .field-row:hover{background:var(--color-bg-secondary);margin:0 -1rem;padding-left:1rem;padding-right:1rem}.sequence-view .field-row label{color:var(--color-text-tertiary);font-size:.8rem;font-weight:500}.sequence-view .field-value{color:var(--color-text-primary);white-space:pre-line;font-size:.9rem}.sequence-view .field-value.empty{color:var(--color-text-tertiary);font-style:italic}.sequence-view .field-row.is-muted>label,.sequence-view .field-row.is-muted>.field-value,.sequence-view .field-row.is-muted>.field-editor{opacity:.35}.sequence-view .director-comment-section .field-value{min-height:5.6em}.sequence-view .microbeats-cards{cursor:pointer;grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.sequence-view .microbeat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);align-items:flex-start;gap:.75rem;min-height:60px;padding:.6rem .75rem;transition:all .15s;display:flex}.sequence-view .microbeat-card:hover{background:var(--color-bg-hover,var(--color-border));border-color:var(--color-accent);transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.sequence-view .microbeat-card:hover .microbeat-index{background:var(--color-accent);color:#fff}.sequence-view .microbeat-index{background:var(--color-bg-tertiary,#e5e7eb);width:20px;height:20px;color:var(--color-text-secondary);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:flex}.sequence-view .microbeat-text{color:var(--color-text-primary);font-size:.8rem;line-height:1.4}@media(max-width:700px){.sequence-view .microbeats-cards{grid-template-columns:repeat(2,1fr)}}.sequence-view .field-editor{flex-direction:column;gap:.5rem;display:flex}.sequence-view .field-editor input,.sequence-view .field-editor textarea{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text-primary);resize:vertical;padding:.5rem .75rem;font-family:inherit;font-size:.9rem}.sequence-view .field-editor input:focus,.sequence-view .field-editor textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #0071e326}.sequence-view .editor-actions{justify-content:flex-end;gap:.5rem;margin-top:.5rem;padding-top:.5rem;display:flex}.sequence-view .btn-save,.sequence-view .btn-cancel{border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;min-width:90px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.sequence-view .btn-save{background:var(--color-accent);color:#fff}.sequence-view .btn-save:hover{background:var(--color-accent-hover);transform:scale(1.02)}.sequence-view .btn-save:disabled{opacity:.6;cursor:not-allowed;transform:none}.sequence-view .btn-cancel{background:var(--color-bg-secondary);color:var(--color-text-primary)}.sequence-view .btn-cancel:hover{background:var(--color-bg-tertiary)}.sequence-view .header-actions{align-items:center;gap:.75rem;display:flex}.sequence-view .btn-prompt-edit{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.sequence-view .btn-prompt-edit:hover{background:var(--color-bg-tertiary,#e5e7eb);border-color:var(--color-border-strong)}.sequence-view .btn-generate{color:#fff;border-radius:var(--radius-full);cursor:pointer;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;transition:transform .15s,box-shadow .15s;display:inline-flex}.sequence-view .btn-generate:hover{transform:scale(1.02);box-shadow:0 4px 12px #6366f14d}.sequence-view .btn-generate:disabled{opacity:.6;cursor:not-allowed;transform:none}.sequence-view .modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.sequence-view .modal-content{background:var(--color-surface);border-radius:var(--radius-xl);width:90%;max-width:480px;padding:2rem;box-shadow:0 20px 60px #0006}.sequence-view .prompt-editor-modal{max-width:700px;max-height:85vh;overflow-y:auto}.sequence-view .modal-content h2{color:var(--color-text-primary);margin:0 0 .5rem;font-size:1.25rem}.sequence-view .modal-subtitle{color:var(--color-text-secondary);margin:0 0 1.5rem;font-size:.9rem}.sequence-view .context-options{margin-bottom:1.5rem}.sequence-view .context-options h3{color:var(--color-text-secondary);margin:0 0 .75rem;font-size:.85rem;font-weight:500}.sequence-view .context-options label{cursor:pointer;color:var(--color-text-primary);align-items:center;gap:.5rem;padding:.5rem 0;font-size:.9rem;display:flex}.sequence-view .context-options input[type=checkbox]{accent-color:#6366f1;width:18px;height:18px}.sequence-view .prompt-section{margin-bottom:1.5rem}.sequence-view .prompt-section h3{color:var(--color-text-secondary);margin:0 0 .75rem;font-size:.85rem;font-weight:500}.sequence-view .prompt-textarea{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);resize:vertical;padding:.75rem;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.85rem;line-height:1.5}.sequence-view .prompt-textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #0071e326}.sequence-view .prompt-hint{color:var(--color-text-tertiary);margin:.5rem 0 0;font-size:.75rem;font-style:italic}.sequence-view .modal-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.75rem;padding-top:1rem;display:flex}.sequence-view .btn-reset{border-radius:var(--radius-full);cursor:pointer;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);justify-content:center;align-items:center;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;transition:background .15s;display:inline-flex}.sequence-view .btn-reset:hover{background:var(--color-bg-secondary)}.sequence-view .field-tags{flex-wrap:wrap;gap:.5rem;display:flex}.sequence-view .tag{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:.25rem .75rem;font-size:.8rem;font-weight:500}.sequence-view .blocking-table{margin-top:1rem}.sequence-view .blocking-table h4{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.85rem}.sequence-view .blocking-table table{border-collapse:collapse;width:100%;font-size:.85rem}.sequence-view .blocking-table th,.sequence-view .blocking-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:.5rem .75rem}.sequence-view .blocking-table th{background:var(--color-bg-secondary);color:var(--color-text-secondary);font-weight:600}.sequence-view .blocking-table tbody tr:hover{background:var(--color-bg-hover)}.sequence-view .blocking-rules{margin-top:1rem}.sequence-view .blocking-rules h4{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.85rem}.sequence-view .blocking-rules ul{margin:0;padding-left:1.25rem;list-style:outside}.sequence-view .blocking-rules li{color:var(--color-text-primary);margin-bottom:.25rem;font-size:.85rem}.sequence-view .empty-state{color:var(--color-text-muted);font-size:.85rem;font-style:italic}.sequence-view .btn-upload-video{color:#fff;border-radius:var(--radius-full);cursor:pointer;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;transition:transform .15s,box-shadow .15s;display:inline-flex}.sequence-view .btn-upload-video:hover{transform:scale(1.02);box-shadow:0 4px 12px #6366f14d}.sequence-view .btn-upload-video:disabled{opacity:.6;cursor:not-allowed;transform:none}.sequence-view .seq-video-list{flex-direction:column;gap:1rem;display:flex}.sequence-view .seq-video-item{background:var(--color-bg-secondary);border-radius:var(--radius-md);overflow:hidden}.sequence-view .seq-video-player{background:#000;width:100%;max-height:300px;display:block}.sequence-view .seq-video-actions{justify-content:space-between;padding:.5rem .75rem;display:flex}.sequence-view .btn-review-submit{background:var(--color-surface);border:1px solid var(--color-accent);border-radius:var(--radius-full);color:var(--color-accent);cursor:pointer;padding:.35rem .75rem;font-size:.8rem;transition:all .15s}.sequence-view .btn-review-submit:hover{background:var(--color-accent);color:#fff}.sequence-view .btn-danger-small{border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-tertiary);cursor:pointer;background:0 0;padding:.35rem .6rem;font-size:.85rem;transition:all .15s}.sequence-view .btn-danger-small:hover{color:#ff3b30;background:#ff3b301a;border-color:#ff3b304d}.sequence-view .seq-assignment-row{gap:1.5rem;margin-bottom:1rem;display:flex}.sequence-view .assignment-field{flex:1}.sequence-view .assignment-field label{color:var(--color-text-tertiary);margin-bottom:.25rem;font-size:.75rem;display:block}.sequence-view .assignment-field select,.sequence-view .assignment-field input[type=date]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);padding:.5rem .75rem;font-size:.85rem}.sequence-view .assignment-display{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.sequence-view .assignee-badge{background:var(--color-bg-secondary);border-radius:var(--radius-full);color:var(--color-text-primary);padding:.35rem .75rem;font-size:.85rem}.sequence-view .deadline-badge{border-radius:var(--radius-full);color:#34c759;background:#34c7591a;padding:.35rem .75rem;font-size:.8rem}.sequence-view .deadline-badge.overdue{color:#ff3b30;background:#ff3b301a}.sequence-view .seq-review-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;margin-bottom:.5rem;padding:.75rem 1rem;transition:border-color .15s,background .15s}.sequence-view .seq-review-card:hover{background:var(--color-bg-hover,var(--color-bg-secondary))}.sequence-view .seq-review-card.active{border-color:var(--color-accent)}.sequence-view .review-header{align-items:center;gap:.75rem;display:flex}.sequence-view .review-status-badge{border-radius:var(--radius-full);padding:.2rem .6rem;font-size:.75rem;font-weight:600}.sequence-view .status-in_review{color:#ff9f0a;background:#ff9f0a26}.sequence-view .status-approved{color:#34c759;background:#34c75926}.sequence-view .status-revision_requested{color:#ff453a;background:#ff453a26}.sequence-view .review-version{color:var(--color-text-tertiary);font-size:.8rem}.sequence-view .review-by{color:var(--color-text-secondary);margin-left:auto;font-size:.8rem}.sequence-view .review-actions{border-top:1px solid var(--color-divider);gap:.5rem;margin-top:.75rem;padding-top:.5rem;display:flex}.sequence-view .btn-approve{border-radius:var(--radius-full);color:#34c759;cursor:pointer;background:#34c75926;border:1px solid #34c7594d;padding:.35rem .75rem;font-size:.8rem}.sequence-view .btn-approve:hover{color:#fff;background:#34c759}.sequence-view .btn-revision{border-radius:var(--radius-full);color:#ff9f0a;cursor:pointer;background:#ff9f0a1a;border:1px solid #ff9f0a4d;padding:.35rem .75rem;font-size:.8rem}.sequence-view .btn-revision:hover{color:#fff;background:#ff9f0a}.sequence-view .seq-review-comments{margin-top:1rem}.sequence-view .seq-review-comments h3{color:var(--color-text-secondary);margin:0 0 .75rem;font-size:.85rem}.sequence-view .comments-list{flex-direction:column;gap:.5rem;max-height:250px;margin-bottom:.75rem;display:flex;overflow-y:auto}.sequence-view .comment-item{background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:.5rem .75rem}.sequence-view .comment-item.system{opacity:.6;font-style:italic}.sequence-view .comment-author{color:var(--color-accent);font-size:.8rem;font-weight:600}.sequence-view .comment-timecode{background:var(--color-accent);color:#fff;border-radius:var(--radius-full);margin-left:.5rem;padding:.1rem .4rem;font-size:.7rem}.sequence-view .comment-text{color:var(--color-text-primary);margin:.25rem 0 0;font-size:.85rem}.sequence-view .comment-input-row{gap:.5rem;display:flex}.sequence-view .comment-input-row input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-primary);flex:1;padding:.5rem .75rem;font-size:.85rem}.sequence-view .comment-input-row input:focus{border-color:var(--color-accent);outline:none}.sequence-view .btn-send-comment{background:var(--color-accent);color:#fff;border-radius:var(--radius-full);cursor:pointer;border:none;padding:.5rem .75rem;font-size:1rem}.sequence-view .btn-send-comment:disabled{opacity:.4;cursor:not-allowed}.file-drop-spinner{border:3px solid #ffffff4d;border-top-color:var(--color-accent,#0071e3);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite fds-spin}@keyframes fds-spin{to{transform:rotate(360deg)}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@keyframes spin{to{transform:rotate(360deg)}}:root{--color-bg: #ffffff;--color-bg-secondary: #f5f5f7;--color-bg-tertiary: #fbfbfd;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-text-primary: #1d1d1f;--color-text-secondary: #86868b;--color-text-tertiary: #a1a1a6;--color-accent: #0071e3;--color-accent-hover: #0077ed;--color-accent-active: #006edb;--color-success: #34c759;--color-warning: #ff9500;--color-error: #ff3b30;--color-border: rgba(0, 0, 0, .08);--color-border-strong: rgba(0, 0, 0, .12);--color-divider: rgba(0, 0, 0, .06);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .16);--font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", sans-serif;--font-mono: "SF Mono", ui-monospace, monospace;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .9375rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-size-4xl: 3rem;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.1;--line-height-snug: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--letter-spacing-tight: -.022em;--letter-spacing-normal: -.016em;--letter-spacing-wide: .02em;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--ease-out: cubic-bezier(.25, .1, .25, 1);--ease-in-out: cubic-bezier(.45, 0, .55, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--max-width: 1200px;--header-height: 56px;--sidebar-width: 260px}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--color-bg: #000000;--color-bg-secondary: #1c1c1e;--color-bg-tertiary: #2c2c2e;--color-surface: #1c1c1e;--color-surface-elevated: #2c2c2e;--color-text-primary: #f5f5f7;--color-text-secondary: #a1a1a6;--color-text-tertiary: #86868b;--color-border: rgba(255, 255, 255, .1);--color-border-strong: rgba(255, 255, 255, .16);--color-divider: rgba(255, 255, 255, .08);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .5)}}:root[data-theme=dark]{--color-bg: #000000;--color-bg-secondary: #1c1c1e;--color-bg-tertiary: #2c2c2e;--color-surface: #1c1c1e;--color-surface-elevated: #2c2c2e;--color-text-primary: #f5f5f7;--color-text-secondary: #a1a1a6;--color-text-tertiary: #86868b;--color-border: rgba(255, 255, 255, .1);--color-border-strong: rgba(255, 255, 255, .16);--color-divider: rgba(255, 255, 255, .08);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .5)}:root[data-theme=light]{--color-bg: #ffffff;--color-bg-secondary: #f5f5f7;--color-bg-tertiary: #fbfbfd;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-text-primary: #1d1d1f;--color-text-secondary: #86868b;--color-text-tertiary: #a1a1a6;--color-border: rgba(0, 0, 0, .08);--color-border-strong: rgba(0, 0, 0, .12);--color-divider: rgba(0, 0, 0, .06);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .12)}@layer base{*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);letter-spacing:var(--letter-spacing-normal);color:var(--color-text-primary);background-color:var(--color-bg);min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-tight)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-md)}p{color:var(--color-text-secondary)}a{color:var(--color-accent);text-decoration:none;transition:color var(--duration-fast) var(--ease-out)}a:hover{color:var(--color-accent-hover)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}::selection{background:#0071e333}}@layer components{.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:1;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);white-space:nowrap}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:var(--color-accent-hover);transform:scale(1.02)}.btn-primary:active{background:var(--color-accent-active);transform:scale(.98)}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text-primary)}.btn-secondary:hover{background:var(--color-border-strong)}.btn-ghost{background:transparent;color:var(--color-accent)}.btn-ghost:hover{background:#0071e31a}.btn-lg,.btn-large{padding:var(--space-4) var(--space-6);font-size:var(--font-size-md)}.btn-sm,.btn-small{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid transparent;border-radius:var(--radius-md);outline:none;transition:all var(--duration-fast) var(--ease-out)}.input:focus{background:var(--color-surface);border-color:var(--color-accent);box-shadow:0 0 0 3px #0071e326}.input::placeholder{color:var(--color-text-tertiary)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--duration-normal) var(--ease-out)}.card-elevated{box-shadow:var(--shadow-md);border:none}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);background:var(--color-bg-secondary);color:var(--color-text-secondary)}.badge-accent{background:#0071e31f;color:var(--color-accent)}.badge-success{background:#34c7591f;color:var(--color-success)}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6)}.app-footer{position:relative;bottom:auto;left:auto;right:auto;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--color-bg-secondary);border-top:1px solid var(--color-border);margin-top:auto}.app-footer__version{font-size:10px;color:var(--color-text-tertiary);-webkit-user-select:none;user-select:none}.app-footer__feedback-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:500;font-family:var(--font-family);color:var(--color-accent);background:transparent;border:1px solid var(--color-accent);border-radius:var(--radius-full);cursor:pointer;transition:all .15s}.app-footer__feedback-btn:hover{background:var(--color-accent);color:#fff;transform:scale(1.03)}.app-footer__feedback-btn:active{transform:scale(.97)}}.analytics-dashboard{display:flex;flex-direction:column;gap:20px}.analytics-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.analytics-tabs{display:flex;gap:4px;background:var(--color-bg-secondary);border-radius:var(--radius-lg, 14px);padding:4px}.analytics-tab{padding:8px 16px;border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-md, 10px);cursor:pointer;font-size:var(--font-size-sm, 13px);font-weight:var(--font-weight-medium, 500);font-family:var(--font-family);transition:all var(--duration-fast, .15s) var(--ease-out);display:flex;align-items:center;gap:6px}.analytics-tab:hover{color:var(--color-text-primary);background:var(--color-border)}.analytics-tab.active{background:var(--color-accent);color:#fff;box-shadow:0 2px 8px #0071e340}.analytics-filters{display:flex;align-items:center;gap:8px}.analytics-select{height:32px;padding:0 28px 0 10px;border:1px solid var(--color-border);border-radius:var(--radius-md, 10px);background:var(--color-surface);color:var(--color-text-primary);font-size:var(--font-size-xs, 12px);font-family:var(--font-family);font-weight:var(--font-weight-medium, 500);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color var(--duration-fast) var(--ease-out);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-select:hover{border-color:var(--color-accent)}.analytics-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #0071e326}.analytics-period{display:flex;gap:4px;background:var(--color-bg-secondary);border-radius:var(--radius-md, 10px);padding:3px}.period-btn{padding:5px 12px;border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-sm, 6px);cursor:pointer;font-size:var(--font-size-xs, 12px);font-weight:var(--font-weight-semibold, 600);font-family:var(--font-family);transition:all var(--duration-fast, .15s) var(--ease-out)}.period-btn:hover{color:var(--color-text-primary)}.period-btn.active{background:#0071e31f;color:var(--color-accent)}.analytics-period__sep{color:var(--color-text-tertiary);font-size:12px;padding:0 2px;align-self:center;opacity:.3}.analytics-period__dash{color:var(--color-text-tertiary);font-size:12px;align-self:center}.analytics-date-input{height:28px;padding:0 6px;border:1px solid var(--color-border);border-radius:var(--radius-sm, 6px);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:11px;font-family:var(--font-family);outline:none;cursor:pointer;transition:border-color .15s}.analytics-date-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px #6366f126}.analytics-date-input.active{border-color:var(--color-accent);background:#0071e30f}.user-sparkline{display:flex;align-items:flex-end;gap:1px;height:24px;min-width:60px;max-width:120px}.sparkline-bar{flex:1;min-width:2px;max-width:5px;background:linear-gradient(to top,#0071e399,#0071e333);border-radius:1px;transition:background var(--duration-fast) var(--ease-out)}.sparkline-bar:hover{background:linear-gradient(to top,#0071e3e6,#0071e366)}.analytics-loading{display:flex;align-items:center;justify-content:center;min-height:200px}.analytics-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:analytics-spin .8s linear infinite}@keyframes analytics-spin{to{transform:rotate(360deg)}}.analytics-empty{text-align:center;padding:40px;color:var(--color-text-secondary);font-size:var(--font-size-sm, 13px)}.analytics-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.analytics-kpi-grid--small{grid-template-columns:repeat(auto-fit,minmax(140px,200px))}.stat-card{background:var(--color-surface);border-radius:var(--radius-lg, 14px);padding:20px;display:flex;flex-direction:column;align-items:center;gap:6px;border:1px solid var(--color-border);transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card__icon{font-size:24px}.stat-card__value{font-size:28px;font-weight:var(--font-weight-bold, 700);color:var(--color-text-primary);line-height:1}.stat-card__sub{font-size:var(--font-size-sm, 14px);font-weight:var(--font-weight-regular, 400);color:var(--color-text-secondary);margin-left:2px}.stat-card__label{font-size:var(--font-size-xs, 12px);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:var(--font-weight-medium, 500)}.stat-card--primary{border-color:#0071e340}.stat-card--primary .stat-card__value{color:var(--color-accent)}.stat-card--success{border-color:#34c75940}.stat-card--success .stat-card__value{color:var(--color-success)}.stat-card--danger{border-color:#ff3b3040}.stat-card--danger .stat-card__value{color:var(--color-error)}.stat-card--cost{border-color:#ff950040}.stat-card--cost .stat-card__value{color:var(--color-warning)}.stat-card--users{border-color:#0071e326}.stat-card--users .stat-card__value{color:var(--color-accent)}.analytics-timeline{background:var(--color-surface);border-radius:var(--radius-lg, 14px);padding:20px;border:1px solid var(--color-border)}.timeline-header{font-size:var(--font-size-sm, 13px);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.recharts-default-tooltip{background:#0f172af2!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:8px!important;box-shadow:0 8px 32px #0006!important}.recharts-tooltip-label{color:#e2e8f0!important;font-weight:600!important;margin-bottom:4px!important}.recharts-tooltip-item{color:#cbd5e1!important}.recharts-legend-item-text{color:var(--color-text-secondary)!important;font-size:12px!important}.analytics-table-wrap{background:var(--color-surface);border-radius:var(--radius-lg, 14px);padding:16px;border:1px solid var(--color-border);overflow-x:auto}.analytics-table-wrap h4{font-size:var(--font-size-sm, 13px);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-secondary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.analytics-table{width:100%;border-collapse:collapse}.analytics-table th{text-align:left;padding:8px 12px;font-size:var(--font-size-xs, 11px);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-divider)}.analytics-table td{padding:10px 12px;font-size:var(--font-size-sm, 13px);color:var(--color-text-primary);border-bottom:1px solid var(--color-divider)}.analytics-table tbody tr:hover{background:var(--color-bg-secondary)}.user-cell{display:flex;flex-direction:column;gap:2px}.user-name{font-weight:var(--font-weight-semibold, 600);color:var(--color-text-primary)}.user-email{font-size:var(--font-size-xs, 11px);color:var(--color-text-secondary)}.cell-badge{background:#0071e31a;color:var(--color-accent);padding:2px 8px;border-radius:var(--radius-full, 999px);font-weight:var(--font-weight-semibold, 600);font-size:var(--font-size-xs, 12px)}.model-badge{background:var(--color-bg-secondary);padding:2px 8px;border-radius:var(--radius-sm, 6px);font-size:var(--font-size-xs, 11px);font-family:var(--font-mono);color:var(--color-text-secondary)}.cell-mono{font-family:var(--font-mono);font-size:var(--font-size-xs, 11px)}.analytics-providers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}.provider-card{background:var(--color-surface);border-radius:var(--radius-lg, 14px);padding:18px;border:1px solid var(--color-border);transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.provider-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.provider-card__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.provider-card__title-group{display:flex;flex-direction:column;gap:2px}.provider-card__name{font-size:var(--font-size-md, 16px);font-weight:var(--font-weight-bold, 700);color:var(--color-text-primary)}.provider-card__desc{font-size:var(--font-size-xs, 11px);color:var(--color-text-tertiary);line-height:1.3}.provider-card__balance{background:var(--color-bg-secondary);border-radius:var(--radius-md, 10px);padding:10px 12px;margin-bottom:12px;display:flex;align-items:center;gap:10px}.provider-balance{display:flex;align-items:baseline;gap:6px;flex-shrink:0}.provider-balance__val{font-size:20px;font-weight:var(--font-weight-bold, 700);font-family:var(--font-mono)}.provider-balance__val.good{color:var(--color-success)}.provider-balance__val.warn{color:var(--color-warning)}.provider-balance__val.bad{color:var(--color-error)}.provider-balance__label{font-size:10px;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px}.provider-balance__bar{flex:1;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden;min-width:40px}.provider-balance__fill{height:100%;border-radius:3px;transition:width .5s ease}.provider-balance__fill.good{background:linear-gradient(to right,#22c55e,#4ade80)}.provider-balance__fill.warn{background:linear-gradient(to right,#f59e0b,#fbbf24)}.provider-balance__fill.bad{background:linear-gradient(to right,#ef4444,#f87171)}.provider-balance__initial{font-size:10px;color:var(--color-text-tertiary);flex-shrink:0;white-space:nowrap}.provider-balance__add-btn{margin-left:auto;padding:3px 10px;border:1px solid var(--color-accent);border-radius:var(--radius-full, 999px);background:#0071e314;color:var(--color-accent);font-size:10px;font-weight:var(--font-weight-semibold, 600);font-family:var(--font-family);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);white-space:nowrap;flex-shrink:0}.provider-balance__add-btn:hover{background:var(--color-accent);color:#fff}.provider-card__rate{font-size:var(--font-size-sm, 14px);font-weight:var(--font-weight-bold, 700);padding:2px 10px;border-radius:var(--radius-full, 999px)}.provider-card__rate.good{background:#34c7591f;color:var(--color-success)}.provider-card__rate.warn{background:#ff95001f;color:var(--color-warning)}.provider-card__rate.bad{background:#ff3b301f;color:var(--color-error)}.provider-card__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}.provider-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.provider-stat__val{font-size:var(--font-size-md, 16px);font-weight:var(--font-weight-bold, 700);color:var(--color-text-primary)}.provider-stat--error .provider-stat__val{color:var(--color-error)}.provider-stat__label{font-size:10px;color:var(--color-text-secondary);text-transform:uppercase}.provider-card__models{display:flex;flex-wrap:wrap;gap:4px;padding-top:8px;border-top:1px solid var(--color-divider)}.model-tag{background:var(--color-bg-secondary);padding:3px 8px;border-radius:var(--radius-sm, 6px);font-size:var(--font-size-xs, 11px);color:var(--color-text-secondary);font-family:var(--font-mono)}.error-by-model{background:var(--color-surface);border-radius:var(--radius-lg, 14px);padding:18px;border:1px solid var(--color-border)}.error-by-model h4{font-size:var(--font-size-sm, 13px);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-secondary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.error-model-bars{display:flex;flex-direction:column;gap:6px}.error-model-row{display:flex;align-items:center;gap:10px}.error-model-name{width:140px;font-size:var(--font-size-xs, 12px);color:var(--color-text-secondary);font-family:var(--font-mono);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.error-model-bar-bg{flex:1;height:16px;background:var(--color-bg-secondary);border-radius:4px;overflow:hidden}.error-model-bar-fill{height:100%;background:linear-gradient(to right,var(--color-error),rgba(255,59,48,.6));border-radius:4px;transition:width .4s ease}.error-model-count{width:32px;font-size:var(--font-size-sm, 13px);font-weight:var(--font-weight-semibold, 600);color:var(--color-error);text-align:right}.admin-top-tabs{display:flex;gap:4px;margin-left:16px;background:var(--color-bg-secondary);border-radius:var(--radius-md, 10px);padding:3px}.admin-top-tab{padding:6px 14px;border:none;border-radius:7px;cursor:pointer;font-size:var(--font-size-sm, 13px);font-weight:var(--font-weight-medium, 500);font-family:var(--font-family);background:transparent;color:var(--color-text-secondary);transition:all var(--duration-fast, .15s) var(--ease-out);display:flex;align-items:center;gap:5px}.admin-top-tab:hover{color:var(--color-text-primary)}.admin-top-tab.active{background:var(--color-accent);color:#fff}.error-row{transition:background var(--duration-fast, .15s) var(--ease-out)}.error-row:hover{background:var(--color-bg-secondary)!important}.error-row--expanded{background:#ef44440f!important}.error-detail-row{background:#ef444408}.error-detail-row td{padding:0 12px 12px!important;border-bottom:2px solid rgba(239,68,68,.15)!important}.error-detail-content{background:var(--color-bg-secondary);border-radius:var(--radius-md, 10px);padding:14px 16px;border-left:3px solid var(--color-error, #ef4444)}.error-detail-text{color:var(--color-text-primary);font-size:var(--font-size-sm, 13px);font-family:var(--font-mono);line-height:1.6;white-space:pre-wrap;word-break:break-word;margin:0}.error-detail-raw{margin-top:10px;border-top:1px solid var(--color-divider);padding-top:8px}.error-detail-raw summary{font-size:var(--font-size-xs, 11px);color:var(--color-text-tertiary);cursor:pointer;-webkit-user-select:none;user-select:none}.error-detail-raw summary:hover{color:var(--color-text-secondary)}.error-detail-raw pre{font-size:var(--font-size-xs, 11px);color:var(--color-text-secondary);font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;margin:6px 0 0;max-height:200px;overflow-y:auto}.cell-error-detail{max-width:400px;color:var(--color-text-secondary);font-size:var(--font-size-xs, 12px)}.rate-badge{padding:2px 8px;border-radius:var(--radius-full, 999px);font-size:var(--font-size-xs, 12px);font-weight:var(--font-weight-semibold, 600);display:inline-block;min-width:48px;text-align:center}.rate-badge--good{background:#34c7591f;color:var(--color-success)}.rate-badge--warn{background:#ff95001f;color:var(--color-warning)}.rate-badge--bad{background:#ff3b301f;color:var(--color-error)}.analytics-models{display:flex;flex-direction:column;gap:16px}.analytics-table--models td{white-space:nowrap}.analytics-table--models .model-badge{font-size:var(--font-size-xs, 11px);max-width:220px;overflow:hidden;text-overflow:ellipsis;display:inline-block}.model-group-start td{border-top:2px solid var(--color-accent)!important}.speed-unit{font-size:10px;color:var(--color-text-tertiary);margin-left:2px}.gen-log{display:flex;flex-direction:column;gap:16px}.gen-log__header{display:flex;align-items:center;gap:12px}.gen-log__header h3{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.gen-log__total{font-size:13px;color:var(--color-text-tertiary);background:var(--color-bg-secondary);padding:2px 8px;border-radius:8px}.gen-log__filters{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.gen-filters__row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.gen-filter{display:flex;flex-direction:column;gap:3px}.gen-filter label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-tertiary)}.gen-filter select,.gen-filter input{height:30px;padding:0 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-primary);color:var(--color-text-primary);font-size:12px;outline:none;min-width:100px}.gen-filter select:focus,.gen-filter input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px #6366f126}.gen-filter--search{flex:1;min-width:180px}.gen-search-wrap{display:flex;gap:4px}.gen-search-wrap input{flex:1}.gen-search-wrap button{height:30px;width:30px;border-radius:6px;background:var(--color-accent, #6366f1);color:#fff;border:none;cursor:pointer;font-size:14px}.gen-filter__pills{display:flex;gap:2px}.gen-pill{padding:4px 10px;font-size:11px;font-weight:500;border:1px solid var(--color-border);background:var(--color-bg-primary);color:var(--color-text-secondary);border-radius:6px;cursor:pointer;transition:all .15s}.gen-pill:hover{background:var(--color-bg-secondary);border-color:var(--color-text-tertiary)}.gen-pill.active{background:var(--color-accent, #6366f1);color:#fff;border-color:var(--color-accent, #6366f1)}.gen-log__summary{display:flex;gap:8px;flex-wrap:wrap}.gen-summary__item{padding:5px 12px;border-radius:8px;font-size:12px;font-weight:600;white-space:nowrap}.gen-summary__item--img{background:#3b82f61f;color:#3b82f6}.gen-summary__item--vid{background:#8b5cf61f;color:#8b5cf6}.gen-summary__item--txt{background:#22c55e1f;color:#22c55e}.gen-summary__item--chat{background:#06b6d41f;color:#06b6d4}.gen-summary__item--err{background:#ef44441f;color:#ef4444}.gen-summary__item--cost{background:#eab3081f;color:#eab308}.gen-log__loading{display:flex;justify-content:center;padding:48px}.gen-log__table-wrap{overflow-x:auto;border:1px solid var(--color-border);border-radius:10px}.gen-table{width:100%;border-collapse:collapse;font-size:13px}.gen-table thead th{padding:8px 10px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-tertiary);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:1}.gen-row{cursor:pointer;transition:background .12s}.gen-row:hover{background:var(--color-bg-secondary)}.gen-row td{padding:7px 10px;border-bottom:1px solid var(--color-border-subtle, rgba(255,255,255,.04));vertical-align:middle}.gen-row--error td{border-left:3px solid transparent}.gen-row--error td:first-child{border-left:3px solid #ef4444}.gen-row--expanded{background:var(--color-bg-secondary)}.gen-row--expanded td{border-bottom-color:transparent}.gen-cell-num{font-size:11px;color:var(--color-text-tertiary);width:40px;text-align:center}.gen-cell-time{font-size:12px;white-space:nowrap;font-family:JetBrains Mono,monospace;color:var(--color-text-secondary)}.gen-cell-user{display:flex;align-items:center;gap:6px;white-space:nowrap}.gen-user-dot{width:6px;height:6px;border-radius:50%;background:var(--color-accent, #6366f1);flex-shrink:0}.gen-type-badge{padding:2px 7px;border-radius:5px;background:var(--color-bg-secondary);font-size:11px;white-space:nowrap}.gen-cell-label{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:var(--color-text-secondary)}.gen-cell-duration{font-size:11px;white-space:nowrap;font-family:JetBrains Mono,monospace;color:var(--color-text-tertiary)}.gen-cell-provider{font-size:12px;color:var(--color-text-secondary)}.gen-cell-model{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.cost-badge{padding:2px 7px;border-radius:5px;font-size:11px;font-weight:500;white-space:nowrap}.cost-badge--ok{background:#22c55e1f;color:#22c55e}.cost-badge--error{background:#ef444414;color:#a3a3a3;text-decoration:line-through}.cost-badge--pending{color:var(--color-text-tertiary)}.cost-badge--warn{background:#eab3081f;color:#eab308}.gen-cell-status{display:flex;align-items:center;gap:4px;width:60px}.gen-status{font-size:14px}.gen-error-type-mini{font-size:12px;opacity:.7}.gen-row-detail td{padding:0 10px 12px;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary)}.gen-detail{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:8px 0}.gen-detail__section{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;padding:10px}.gen-detail__title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-tertiary);margin-bottom:8px}.gen-detail__prompt{margin:0;padding:8px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;font-size:12px;color:var(--color-text-primary);line-height:1.4;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow:auto;font-family:JetBrains Mono,monospace}.gen-detail__empty{font-size:12px;color:var(--color-text-tertiary);font-style:italic}.gen-detail__tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.gen-tag{padding:2px 7px;border-radius:4px;background:var(--color-bg-secondary);font-size:10px;color:var(--color-text-secondary);border:1px solid var(--color-border)}.gen-detail__error{border:1px solid #ef4444;border-radius:8px;padding:10px;background:#ef44440f}.gen-error__header{font-size:13px;font-weight:600;margin-bottom:4px}.gen-error__message{font-size:12px;color:var(--color-text-secondary);word-break:break-word;line-height:1.4}.gen-error__full{margin-top:8px}.gen-error__full summary{font-size:11px;cursor:pointer;color:var(--color-text-tertiary)}.gen-error__full pre{margin:4px 0 0;padding:6px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;font-size:10px;max-height:200px;overflow:auto;white-space:pre-wrap;word-break:break-word}.gen-detail__media{max-width:100%;margin-bottom:8px}.gen-detail__image{max-width:100%;max-height:240px;border-radius:8px;object-fit:contain}.gen-detail__video{max-width:100%;max-height:240px;border-radius:8px}.gen-detail__output-text{margin:0;padding:8px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;font-size:12px;line-height:1.4;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow:auto}.gen-detail__result{font-size:12px;color:var(--color-text-secondary);word-break:break-word;max-height:100px;overflow:auto}.gen-detail__footer{grid-column:1 / -1;display:flex;gap:16px;align-items:center;font-size:12px;color:var(--color-text-secondary)}.gen-detail__label{opacity:.6}.gen-log__pagination{display:flex;align-items:center;gap:10px;justify-content:center;padding:8px 0}.gen-log__pagination button{width:32px;height:32px;border-radius:6px;border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .12s}.gen-log__pagination button:hover:not(:disabled){background:var(--color-accent, #6366f1);color:#fff;border-color:var(--color-accent)}.gen-log__pagination button:disabled{opacity:.3;cursor:default}.gen-log__pagination span{font-size:13px;color:var(--color-text-secondary)}.gen-page-size{height:30px;padding:0 6px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-primary);color:var(--color-text-primary);font-size:12px;cursor:pointer}.gen-empty{text-align:center;padding:32px!important;color:var(--color-text-tertiary);font-style:italic}.gen-detail__refs{margin-top:10px}.gen-detail__refs-label{font-size:11px;font-weight:600;color:var(--color-text-tertiary);margin-bottom:6px}.gen-detail__refs-grid{display:flex;gap:6px;flex-wrap:wrap}.gen-detail__ref-thumb{width:64px;height:64px;object-fit:cover;border-radius:6px;border:1px solid var(--color-border);cursor:pointer;transition:transform .15s,box-shadow .15s}.gen-detail__ref-thumb:hover{transform:scale(1.08);box-shadow:0 0 0 2px var(--color-accent, #6366f1)}.gen-detail__media-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.gen-detail__media-clickable:hover{transform:scale(1.02);box-shadow:0 4px 20px #0006}.gen-modal-overlay{position:fixed;inset:0;z-index:9999;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;animation:genModalIn .2s ease-out}@keyframes genModalIn{0%{opacity:0}to{opacity:1}}.gen-modal-close{position:fixed;top:16px;right:16px;z-index:10000;width:40px;height:40px;border-radius:50%;border:none;background:#ffffff1f;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.gen-modal-close:hover{background:#ffffff40}.gen-modal-content{max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.gen-modal-image{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px;cursor:pointer}.gen-modal-video{max-width:90vw;max-height:90vh;border-radius:8px;cursor:pointer}.ugen-log{display:flex;flex-direction:column;gap:12px;padding:0;height:100%}.ugen-log__header{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.ugen-log__header h4{margin:0;font-size:1rem;font-weight:700;color:var(--color-text-primary)}.ugen-log__total{font-size:.78rem;color:var(--color-text-tertiary);background:var(--color-bg-tertiary);padding:3px 10px;border-radius:12px;font-weight:500}.ugen-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end;padding:8px 12px;background:var(--color-bg-secondary);border-radius:8px;border:1px solid var(--color-border)}.ugen-filter{display:flex;flex-direction:column;gap:3px;min-width:0}.ugen-filter label{font-size:.68rem;color:var(--color-text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.ugen-filter select,.ugen-filter input{font-size:.78rem;padding:4px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text-primary);min-width:100px;max-width:160px}.ugen-filter__pills{display:flex;gap:4px}.ugen-pill{font-size:.72rem;padding:3px 10px;border:1px solid var(--color-border);border-radius:12px;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.ugen-pill:hover{background:#6366f114;border-color:var(--color-accent)}.ugen-pill.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.ugen-search-wrap{display:flex;gap:4px}.ugen-search-wrap input{min-width:160px}.ugen-search-wrap button{padding:4px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary);cursor:pointer;font-size:.82rem}.ugen-log__summary{display:flex;gap:12px;padding:6px 12px;background:var(--color-bg-secondary);border-radius:8px;border:1px solid var(--color-border);flex-wrap:wrap}.ugen-summary__item{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.ugen-summary__item--img{color:#a78bfa}.ugen-summary__item--vid{color:#f472b6}.ugen-summary__item--txt{color:#60a5fa}.ugen-summary__item--chat{color:#34d399}.ugen-summary__item--err{color:#ef4444}.ugen-log__table-wrap{overflow-x:auto;overflow-y:auto;flex:1;border:1px solid var(--color-border);border-radius:8px}.ugen-table{width:100%;border-collapse:collapse;font-size:.78rem}.ugen-table thead{position:sticky;top:0;z-index:2}.ugen-table th{background:var(--color-bg-tertiary);color:var(--color-text-secondary);font-weight:600;padding:8px 10px;text-align:left;border-bottom:2px solid var(--color-border);white-space:nowrap;font-size:.72rem;text-transform:uppercase;letter-spacing:.03em}.ugen-table td{padding:7px 10px;border-bottom:1px solid var(--color-border);color:var(--color-text-primary);white-space:nowrap}.ugen-row{cursor:pointer;transition:background .15s}.ugen-row:hover{background:#6366f10a}.ugen-row--expanded{background:#6366f10f!important}.ugen-row--error td{color:var(--color-text-secondary)}.ugen-row--running{animation:ugen-pulse 2s infinite}@keyframes ugen-pulse{0%,to{background:transparent}50%{background:#6366f10a}}.ugen-cell-num{color:var(--color-text-tertiary)!important;font-family:JetBrains Mono,monospace;font-size:.7rem;width:36px;text-align:center}.ugen-cell-preview{width:130px;padding:4px 6px!important}.ugen-thumb{width:120px;max-height:100px;border-radius:6px;overflow:hidden;position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);border:1px solid var(--color-border);flex-shrink:0}.ugen-thumb__media{width:120px;height:auto;max-height:100px;object-fit:contain;border-radius:6px;display:block}.ugen-thumb--video{position:relative}.ugen-thumb__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;text-shadow:0 1px 4px rgba(0,0,0,.7);pointer-events:none}.ugen-thumb--loading{animation:ugen-pulse 1.5s infinite;font-size:16px}.ugen-thumb--error{font-size:14px;opacity:.6}.ugen-thumb--empty{font-size:12px;color:var(--color-text-tertiary);opacity:.4}.ugen-thumb:hover{transform:scale(1.08);transition:transform .15s}.ugen-cell-time{font-family:JetBrains Mono,monospace;font-size:.72rem;color:var(--color-text-secondary)!important}.ugen-cell-duration{font-family:JetBrains Mono,monospace;font-size:.72rem;color:var(--color-text-tertiary)!important}.ugen-type-badge{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;padding:2px 8px;border-radius:10px;background:#6366f114;color:var(--color-accent);font-weight:500;white-space:nowrap}.ugen-status{font-size:1rem}.ugen-error-type-mini{font-size:.75rem;margin-left:2px}.ugen-detail{padding:12px 16px;background:var(--color-bg-secondary);border-radius:8px;margin:4px 8px 8px;border:1px solid var(--color-border)}.ugen-detail__columns{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ugen-detail__section{display:flex;flex-direction:column;gap:8px}.ugen-detail__title{font-size:.72rem;font-weight:700;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.ugen-detail__empty{font-size:.75rem;color:var(--color-text-tertiary);font-style:italic}.ugen-detail__prompt{font-size:.75rem;color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;padding:8px 10px;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto;line-height:1.5;font-family:JetBrains Mono,monospace;font-size:.72rem;margin:0}.ugen-detail__refs{display:flex;flex-direction:column;gap:4px}.ugen-detail__refs-label{font-size:.72rem;color:var(--color-text-tertiary);font-weight:600}.ugen-detail__refs-grid{display:flex;gap:6px;flex-wrap:wrap}.ugen-detail__ref-thumb{width:64px;height:64px;border-radius:6px;object-fit:cover;border:1px solid var(--color-border);cursor:pointer;transition:transform .15s}.ugen-detail__ref-thumb:hover{transform:scale(1.1);box-shadow:0 2px 8px #0000004d}.ugen-detail__tags{display:flex;gap:4px;flex-wrap:wrap}.ugen-tag{font-size:.68rem;padding:2px 8px;border-radius:10px;background:#6366f114;color:var(--color-accent);font-weight:500;white-space:nowrap}.ugen-detail__error{background:#ef444414;border:1px solid rgba(239,68,68,.3);border-left:3px solid #ef4444;border-radius:6px;padding:8px 10px;font-size:.75rem;color:#fca5a5}.ugen-detail__error-header{font-weight:700;margin-bottom:4px}.ugen-detail__error-msg{white-space:pre-wrap;word-break:break-word;max-height:120px;overflow-y:auto;font-size:.72rem;line-height:1.4}.ugen-detail__error-full{margin-top:8px;font-size:.68rem}.ugen-detail__error-full summary{cursor:pointer;color:var(--color-text-tertiary);font-weight:600}.ugen-detail__error-full pre{margin:4px 0 0;font-size:.65rem;max-height:200px;overflow-y:auto;background:var(--color-bg);padding:6px;border-radius:4px}.ugen-detail__media{max-width:100%}.ugen-detail__image,.ugen-detail__video{max-width:100%;max-height:280px;border-radius:6px;object-fit:contain}.ugen-detail__media-clickable{cursor:pointer;transition:transform .2s}.ugen-detail__media-clickable:hover{transform:scale(1.02)}.ugen-detail__output-text{font-size:.75rem;color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;padding:8px 10px;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto;margin:0}.ugen-detail__result{font-size:.75rem;color:var(--color-text-tertiary);padding:4px 0}.ugen-detail__footer{display:flex;gap:12px;align-items:center;font-size:.72rem;color:var(--color-text-tertiary);padding-top:8px;margin-top:8px;border-top:1px solid var(--color-border);flex-wrap:wrap}.ugen-detail__label{background:#6366f114;padding:2px 8px;border-radius:10px;font-weight:500}.ugen-log__pagination{display:flex;align-items:center;gap:8px;justify-content:center;padding:8px 0;font-size:.78rem;color:var(--color-text-secondary)}.ugen-log__pagination button{padding:4px 12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary);cursor:pointer;transition:all .15s}.ugen-log__pagination button:hover:not(:disabled){background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.ugen-log__pagination button:disabled{opacity:.4;cursor:not-allowed}.ugen-page-size{font-size:.72rem;padding:3px 6px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text-primary);margin-left:8px}.ugen-log__loading{display:flex;justify-content:center;align-items:center;padding:48px 0;flex:1}.ugen-empty{text-align:center;padding:32px 16px!important;color:var(--color-text-tertiary)!important;font-style:italic}.ugen-modal-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;cursor:pointer}.ugen-modal-close{position:fixed;top:16px;right:20px;z-index:10000;background:#0009;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.5rem;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.ugen-modal-close:hover{background:#ffffff26}.ugen-modal-content{cursor:default;max-width:90vw;max-height:90vh}.ugen-modal-image{max-width:90vw;max-height:90vh;border-radius:8px;object-fit:contain;cursor:pointer}.ugen-modal-video{max-width:90vw;max-height:90vh;border-radius:8px;cursor:pointer}.ugen-broken-media{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:var(--color-bg-tertiary);border:1px dashed var(--color-border);border-radius:6px;color:var(--color-text-tertiary);opacity:.6}.ugen-broken-media svg{opacity:.4}.ugen-broken-media span{font-size:.62rem;font-weight:500;letter-spacing:.02em}.ugen-broken-media--thumb{width:120px;height:68px}.ugen-broken-media--normal{width:100%;max-width:320px;height:180px}.ugen-broken-media--ref{width:64px;height:64px;font-size:1.2rem}.ugen-broken-media--ref span{font-size:.55rem}.pb-container{display:flex;flex-direction:column;gap:12px}.pb-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;flex-wrap:wrap;padding-left:4px}.pb-preset-bar{display:flex;align-items:center;gap:4px}.pb-preset-select{padding:4px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:11px;min-width:120px}.pb-source-selectors select{padding:4px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:11px}.pb-preset-save-btn,.pb-preset-new-btn,.pb-preset-delete-btn{padding:3px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:13px;cursor:pointer;transition:all .15s;line-height:1}.pb-preset-save-btn:hover:not(:disabled),.pb-preset-new-btn:hover:not(:disabled){border-color:var(--color-accent)}.pb-preset-delete-btn:hover{border-color:#ef4444;color:#ef4444}.pb-preset-save-btn:disabled,.pb-preset-new-btn:disabled{opacity:.3;cursor:not-allowed}.pb-mode-toggle{display:flex;gap:2px;background:var(--color-bg-secondary);border-radius:20px;padding:2px;width:fit-content}.pb-mode-toggle button{padding:4px 14px;border:none;border-radius:18px;font-size:12px;font-weight:500;cursor:pointer;background:transparent;color:var(--color-text-secondary);transition:all .15s}.pb-mode-toggle button.active{background:var(--color-surface-elevated);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.pb-code-textarea{width:100%;min-height:200px;padding:12px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg);color:var(--color-text-primary);font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;line-height:1.5;resize:vertical;box-sizing:border-box}.pb-code-textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #0071e326}.pb-layout{display:flex;gap:12px;min-height:400px;max-height:85vh;align-items:stretch;background:#0000000a;border:1px solid var(--color-border);border-radius:10px;padding:12px}.pb-canvas{flex:6;display:flex;flex-direction:column;gap:8px;overflow-y:auto}.pb-palette{flex:4;display:flex;flex-direction:column;gap:4px;overflow-y:auto;padding-right:4px}.pb-canvas-header{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:4px 0}.pb-clear-canvas-btn{padding:2px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-tertiary);font-size:11px;cursor:pointer;transition:all .15s;text-transform:none;letter-spacing:0;font-weight:400}.pb-clear-canvas-btn:hover{border-color:#ef4444;color:#ef4444}.pb-canvas-count{font-size:11px;font-weight:400;color:var(--color-text-tertiary)}.pb-canvas-empty{padding:40px 20px;text-align:center;color:var(--color-text-tertiary);font-size:13px;border:2px dashed var(--color-border);border-radius:8px}.pb-canvas-group{border-radius:8px;overflow:hidden;border:1px solid var(--color-border);background:var(--color-bg-secondary)}.pb-canvas-group-header{padding:6px 10px;font-size:12px;font-weight:600;color:var(--color-text-primary);background:var(--color-divider);border-left:3px solid var(--group-color, #666)}.pb-brick{padding:8px 10px;border:1px solid var(--color-border);border-left:3px solid;border-radius:6px;margin-bottom:6px;background:var(--color-surface);transition:all .15s;cursor:grab}.pb-brick:hover{background:var(--color-bg-secondary)}.pb-brick-cross{border-style:dashed;background:var(--color-bg-tertiary)}.pb-brick-dragging{opacity:.3;transform:scale(.97)}.pb-brick-drop-target{border-top:2px solid var(--color-accent);padding-top:7px}.pb-brick-header{display:flex;align-items:center;gap:6px;margin-bottom:3px}.pb-brick-field{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--color-text-tertiary)}.pb-brick-group-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.pb-brick-badge{font-size:9px;padding:1px 5px;border-radius:8px;background:#06b6d426;color:#06b6d4;font-weight:600}.pb-brick-drag{color:var(--color-text-tertiary);cursor:grab;font-size:14px;-webkit-user-select:none;user-select:none;margin-right:2px}.pb-brick-remove{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;font-size:12px;padding:0 2px;transition:color .15s}.pb-brick-remove:hover{color:#ef4444}.pb-brick-chars{margin-left:auto;font-size:10px;font-variant-numeric:tabular-nums;color:var(--color-text-tertiary, #999);opacity:.6;white-space:nowrap;padding-right:2px}.pb-brick-value{font-size:13px;color:var(--color-text-primary);line-height:1.4;word-break:break-word;padding-left:20px}.pb-brick-value:hover{background:var(--color-bg-secondary, rgba(0,0,0,.03));border-radius:4px}.pb-brick-edit{width:100%;margin-top:4px;padding:6px 8px 6px 20px;font-size:13px;line-height:1.4;font-family:inherit;border:1px solid var(--color-accent, #3B82F6);border-radius:6px;background:var(--color-surface, var(--color-bg-secondary, #1e1e1e));color:var(--color-text-primary, #e0e0e0);resize:vertical;outline:none;box-shadow:0 0 0 2px #3b82f626}.pb-char-counter{text-align:right;font-size:11px;color:var(--color-text-tertiary);padding:4px 0;font-variant-numeric:tabular-nums}.pb-char-counter--over{color:#ef4444;font-weight:600}.pb-palette-header{font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:4px 0}.pb-source-section{margin-bottom:8px}.pb-source-header{display:flex;align-items:center;gap:6px;padding:6px 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);background:var(--color-divider);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.pb-source-badge{font-size:9px;padding:1px 6px;border-radius:8px;background:#f59e0b26;color:#f59e0b;font-weight:600}.pb-source-selectors{display:flex;gap:6px;padding:6px 8px}.pb-source-selectors select{flex:1;padding:4px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:11px}.pb-palette-group{margin:2px 0}.pb-palette-group>summary{display:flex;align-items:center;gap:4px;padding:5px 8px;font-size:12px;font-weight:600;color:var(--color-text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;border-left:3px solid;list-style:none;transition:background .1s}.pb-palette-group>summary:hover{background:var(--color-divider)}.pb-palette-group>summary::-webkit-details-marker{display:none}.pb-palette-group>summary:before{content:"▶";font-size:8px;transition:transform .15s}.pb-palette-group[open]>summary:before{transform:rotate(90deg)}.pb-palette-count{margin-left:auto;font-size:10px;color:var(--color-text-tertiary);font-weight:400}.pb-palette-group-items{display:flex;flex-direction:column;gap:1px;padding:2px 0 2px 11px}.pb-palette-item{padding:6px 8px;border-left:2px solid;border-radius:0 4px 4px 0;cursor:pointer;transition:all .12s;background:var(--color-bg-tertiary)}.pb-palette-item:hover{background:var(--color-bg-secondary)}.pb-palette-muted{opacity:.35;cursor:pointer}.pb-palette-muted:hover{opacity:.5}.pb-palette-empty{opacity:.2;cursor:default;pointer-events:none}.pb-palette-item-header{display:flex;align-items:center;gap:4px}.pb-palette-item-field{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.2px;color:var(--color-text-tertiary)}.pb-palette-item-check{color:#34c759;font-size:11px;margin-left:auto}.pb-palette-item-badge{font-size:9px;padding:0 5px;border-radius:8px;background:#06b6d426;color:#06b6d4;font-weight:600;margin-left:auto}.pb-palette-item-value{font-size:12px;color:var(--color-text-primary);line-height:1.3;margin-top:1px;word-break:break-word}.pb-palette-muted .pb-palette-item-value{color:var(--color-text-tertiary)}.pb-add-custom-btn{width:100%;padding:6px;border:1px dashed var(--color-border-strong);border-radius:6px;background:transparent;color:var(--color-text-secondary);font-size:12px;cursor:pointer;transition:all .15s;margin:4px 0}.pb-add-custom-btn:hover{border-color:#ec4899;color:#ec4899}.pb-custom-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.pb-custom-dialog{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:12px;padding:20px;width:400px;max-width:90vw}.pb-custom-dialog h3{margin:0 0 16px;font-size:15px;color:var(--color-text-primary)}.pb-custom-dialog label{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;font-size:12px;color:var(--color-text-secondary)}.pb-custom-dialog input,.pb-custom-dialog textarea{padding:8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text-primary);font-size:13px;font-family:inherit}.pb-custom-dialog textarea{resize:vertical}.pb-custom-dialog-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.pb-custom-dialog-actions button{padding:6px 16px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:12px;cursor:pointer;transition:all .15s}.pb-custom-dialog-actions button.primary{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.pb-custom-dialog-actions button:disabled{opacity:.4;cursor:not-allowed}.pb-palette::-webkit-scrollbar{width:4px}.pb-palette::-webkit-scrollbar-track{background:transparent}.pb-palette::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:2px}.pb-canvas::-webkit-scrollbar{width:4px}.pb-canvas::-webkit-scrollbar-track{background:transparent}.pb-canvas::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:2px}
