html,body,#root{height:100%;min-height:100%}body{margin:0}.auth-manager-wrapper{box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffd6;border:1px solid #ffffffb8;border-radius:12px;margin-top:auto;padding:8px}.auth-toggle-btn{text-align:left;width:100%;color:var(--text-main);background:0 0;border:none;border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:14px;transition:background-color .2s;display:flex}.auth-toggle-btn:hover{background:#0000000d}.auth-toggle-left{align-items:center;gap:8px;min-width:0;display:flex}.auth-toggle-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.auth-status-tag{color:var(--text-soft);align-items:center;gap:4px;font-size:11px;display:inline-flex}.auth-status-tag.success{color:#10b981}.auth-status-tag.error{color:#ef4444}.auth-username{color:var(--text-soft);white-space:nowrap;text-overflow:ellipsis;max-width:110px;font-size:11px;overflow:hidden}.auth-version{color:var(--text-faint);-webkit-user-select:none;user-select:none;font-size:10px}.auth-modal-overlay{z-index:9995;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.auth-modal-content{width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border);background:#fff;border-radius:16px;flex-direction:column;gap:16px;max-height:85vh;padding:20px;display:flex;overflow-y:auto}.auth-modal-header{justify-content:space-between;align-items:center;display:flex}.auth-modal-header h3{color:var(--text-main);margin:0;font-size:18px;font-weight:600}.auth-modal-close{color:var(--text-soft);background:0 0;border:none;font-size:14px}.auth-modal-close:hover{color:var(--text-main)}.auth-form-group{flex-direction:column;gap:12px;display:flex}.auth-label{color:var(--text-main);flex-direction:column;gap:6px;font-size:14px;font-weight:500;display:flex}.auth-label span{align-items:center;gap:8px;display:flex}.auth-input{border:1px solid var(--border-strong);border-radius:8px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:box-shadow .2s,border-color .2s}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.auth-btn-primary{background:var(--text-main);color:#fff;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px;font-size:14px;font-weight:500;transition:transform .1s,background-color .2s,opacity .2s;display:flex}.auth-btn-primary:hover:not(:disabled){background:#000;transform:scale(1.01)}.auth-btn-primary:active:not(:disabled){transform:scale(.98)}.auth-btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-btn-secondary{background:var(--bg-soft);color:var(--text-main);border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:500;transition:transform .1s,background-color .2s;display:flex}.auth-btn-secondary:hover{background:var(--border);transform:scale(1.02)}.auth-btn-secondary:active{transform:scale(.98)}.auth-account-info{background:var(--bg-muted);border:1px solid var(--border);color:var(--text-soft);border-radius:12px;padding:12px;font-size:14px}.auth-account-info strong{color:var(--text-main)}.auth-hint{color:var(--text-faint);margin-top:4px;font-size:12px}.auth-actions-row{gap:8px;margin-top:8px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight: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-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-ease:initial}}}@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-red-50:oklch(97.1% .013 17.38);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-zinc-50:oklch(98.5% 0 0);--color-zinc-100:oklch(96.7% .001 286.375);--color-zinc-200:oklch(92% .004 286.32);--color-zinc-400:oklch(70.5% .015 286.067);--color-zinc-500:oklch(55.2% .016 285.938);--color-zinc-700:oklch(37% .013 285.805);--color-zinc-800:oklch(27.4% .006 286.033);--color-zinc-900:oklch(21% .006 285.885);--color-black:#000;--color-white:#fff;--spacing:.25rem;--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:calc(1.5 / 1);--font-weight-medium:500;--font-weight-semibold:600;--radius-md:.375rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--ease-out:cubic-bezier(0, 0, .2, 1);--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--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)}}@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;-webkit-text-decoration:inherit;-webkit-text-decoration: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-none{pointer-events:none}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.top-0{top:calc(var(--spacing) * 0)}.top-2{top:calc(var(--spacing) * 2)}.left-2{left:calc(var(--spacing) * 2)}.z-10{z-index:10}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.flex{display:flex}.hidden{display:none}.table{display:table}.aspect-video{aspect-ratio:var(--aspect-video)}.h-4{height:calc(var(--spacing) * 4)}.h-4\.5{height:calc(var(--spacing) * 4.5)}.h-full{height:100%}.w-4{width:calc(var(--spacing) * 4)}.w-4\.5{width:calc(var(--spacing) * 4.5)}.w-full{width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.cursor-pointer{cursor:pointer}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.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-zinc-100{border-color:var(--color-zinc-100)}.border-zinc-200{border-color:var(--color-zinc-200)}.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\/65{background-color:#000000a6}@supports (color:color-mix(in lab, red, red)){.bg-black\/65{background-color:color-mix(in oklab, var(--color-black) 65%, transparent)}}.bg-white{background-color:var(--color-white)}.bg-zinc-50{background-color:var(--color-zinc-50)}.bg-zinc-100{background-color:var(--color-zinc-100)}.bg-zinc-200{background-color:var(--color-zinc-200)}.object-cover{object-fit:cover}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-8{padding-block:calc(var(--spacing) * 8)}.pt-3{padding-top:calc(var(--spacing) * 3)}.text-center{text-align:center}.font-mono{font-family:var(--font-mono)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[11px\]{font-size:11px}.leading-4{--tw-leading:calc(var(--spacing) * 4);line-height:calc(var(--spacing) * 4)}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.whitespace-nowrap{white-space:nowrap}.text-red-600{color:var(--color-red-600)}.text-white{color:var(--color-white)}.text-zinc-400{color:var(--color-zinc-400)}.text-zinc-500{color:var(--color-zinc-500)}.text-zinc-700{color:var(--color-zinc-700)}.text-zinc-800{color:var(--color-zinc-800)}.opacity-0{opacity:0}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px 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)}.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,)}.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-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))}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}@media (hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}.hover\:bg-red-50:hover{background-color:var(--color-red-50)}.hover\:bg-zinc-100:hover{background-color:var(--color-zinc-100)}.hover\:text-red-600:hover{color:var(--color-red-600)}.hover\:text-red-700:hover{color:var(--color-red-700)}.hover\:text-zinc-800:hover{color:var(--color-zinc-800)}.hover\:text-zinc-900:hover{color:var(--color-zinc-900)}}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-60:disabled{opacity:.6}}:root{--bg-page:#f4f7fb;--bg-panel:#fff;--bg-soft:#eef3f8;--bg-muted:#f8fafc;--border:#d9e3ef;--border-strong:#bfd0e2;--text-main:#162033;--text-soft:#506176;--text-faint:#7b8aa1;--accent:#2060ff;--accent-strong:#1748c7;--accent-soft:#2060ff1a;--danger-soft:#fff2f0;--danger:#cf3a2b;--shadow-lg:0 22px 70px #1d33541f;--shadow-md:0 14px 30px #1d335414;--shadow-sm:0 8px 18px #1d33540f}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%}body{color:var(--text-main);background:radial-gradient(circle at 0 0,#2060ff14,#0000 28%),linear-gradient(#f7f9fc 0%,#eef3f8 100%);margin:0;font-family:Avenir Next,SF Pro Display,Segoe UI,sans-serif;overflow:hidden}button,input,textarea,select{font:inherit}button{cursor:pointer}.workspace{grid-template-columns:248px minmax(0,1fr) 308px;gap:12px;width:100vw;height:100dvh;padding:12px;display:grid;overflow:hidden}.studio-main,.history-sidebar,.details-sidebar{min-height:0;overflow:hidden}.studio-main{flex-direction:column;gap:10px;min-height:0;display:flex;position:relative;overflow:hidden}.history-sidebar,.details-sidebar{flex-direction:column;flex:1;gap:12px;min-width:0;display:flex}.history-panel{flex-direction:column;flex:1;display:flex;overflow:hidden}.history-list{flex:1;padding:0 4px;overflow-y:auto}.topbar,.canvas-stage,.dock-card,.rail-card,.login-card{box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffd6;border:1px solid #ffffffb8;border-radius:12px}.login-card{padding:8px}.topbar{z-index:15;border-radius:12px;flex:none;justify-content:space-between;align-items:center;gap:8px;max-width:260px;padding:6px 8px;animation:.45s ease-out rise-in;display:flex;position:absolute;top:10px;right:10px}.brand-block{align-items:center;gap:6px;display:flex}.brand-mark{width:24px;height:24px;color:var(--accent);background:linear-gradient(135deg,#dce9ff 0%,#eef3ff 100%);border-radius:8px;place-items:center;display:grid}.brand-mark svg{width:14px;height:14px}.brand-kicker,.section-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);margin:0 0 4px;font-size:.62rem;font-weight:700}.brand-block h1,.section-header h2{margin:0;font-size:1rem;line-height:1.05}.topbar .brand-kicker{display:none}.topbar .brand-block h1{white-space:nowrap;font-size:.72rem}.topbar-actions{align-items:center;gap:4px;display:flex}.topbar-pill,.info-tag,.stat-pill{background:var(--bg-soft);color:var(--text-soft);border-radius:999px;justify-content:center;align-items:center;padding:6px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.settings-toggle{border:1px solid var(--border);color:var(--text-soft);background:#fff;border-radius:999px;align-items:center;gap:4px;padding:5px 7px;font-size:.66rem;transition:all .2s;display:inline-flex}.topbar .topbar-pill{padding:4px 7px;font-size:.62rem}.settings-toggle svg{width:13px;height:13px}.settings-toggle:hover,.settings-toggle.active{border-color:var(--accent);color:var(--accent);background:#fffffffa}.canvas-stage{border-radius:24px;flex-direction:column;flex:1;gap:10px;min-height:0;padding:14px;animation:.52s ease-out rise-in;display:flex;overflow:hidden}.canvas-stage>.section-header{padding-right:250px}.section-header{flex:none;justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.section-header.compact{align-items:center}.stage-stats{flex-wrap:wrap;gap:6px;display:flex}.status-banner{background:var(--danger-soft);color:var(--danger);border:1px solid #cf3a2b24;border-radius:14px;flex:none;align-items:center;gap:10px;padding:10px 12px;font-size:.82rem;display:flex}.stage-surface{border:1px solid var(--border);background:linear-gradient(#ffffffa8,#f1f6fcfa),radial-gradient(circle at top,#2060ff14,#0000 45%);border-radius:22px;flex:1;justify-content:center;align-items:center;min-height:0;padding:12px;display:flex;position:relative;overflow:hidden}.ratio-container-outer{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.ratio-page-canvas{border:1px solid var(--border);width:min(100%,860px);min-width:min(100%,280px);max-height:100%;box-shadow:var(--shadow-lg);background:linear-gradient(#fff 0%,#f4f7fb 100%);border-radius:20px;flex-direction:column;transition:transform .28s,box-shadow .28s;display:flex;position:relative;overflow:hidden}.ratio-page-canvas:hover{transform:translateY(-2px);box-shadow:0 28px 80px #1d335424}.internal-grid{background:var(--border);gap:2px;width:100%;height:100%;display:grid}.count-1{grid-template-columns:1fr}.count-2{grid-template-columns:1fr 1fr}.count-4{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.canvas-box-item{background:linear-gradient(#fbfdff 0%,#eef3f8 100%);justify-content:center;align-items:center;transition:transform .24s,box-shadow .24s,outline-color .24s;display:flex;position:relative;overflow:hidden}.canvas-box-item.success{cursor:pointer}.canvas-box-item.success:hover{transform:scale(.995)}.canvas-box-item.active{outline:3px solid var(--accent);outline-offset:-3px;z-index:1}.canvas-box-item img{object-fit:contain;background:#fff;width:100%;height:100%}.zoom-overlay{color:#fff;opacity:0;background:#121f31b3;border:none;border-radius:999px;place-items:center;width:38px;height:38px;transition:all .2s;display:grid;position:absolute;top:14px;right:14px;transform:translateY(6px)}.canvas-box-item:hover .zoom-overlay{opacity:1;transform:translateY(0)}.canvas-loader-box{place-items:center;width:100%;height:100%;padding:12px;display:grid}.slot-message{text-align:center;flex-direction:column;align-items:center;gap:8px;max-width:160px;font-size:.76rem;line-height:1.35;display:flex}.loading-state{color:var(--text-soft)}.error-state{color:var(--danger)}.canvas-empty{text-align:center;width:100%;max-width:440px;color:var(--text-soft);flex-direction:column;align-items:center;gap:10px;animation:.4s ease-out soft-fade;display:flex}.empty-mark{width:64px;height:64px;color:var(--accent);box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#fff 0%,#eaf1fb 100%);border-radius:20px;place-items:center;display:grid}.canvas-empty h3{color:var(--text-main);margin:0;font-size:1rem}.canvas-empty p{margin:0;font-size:.86rem;line-height:1.45}.control-dock{flex:none;grid-template-columns:minmax(220px,.78fr) minmax(0,1.72fr);gap:10px;min-height:170px;max-height:200px;display:grid}.dock-card{border-radius:22px;flex-direction:column;gap:8px;min-height:0;padding:10px 12px;animation:.58s ease-out rise-in;display:flex;overflow:hidden}.control-dock .section-header{gap:8px}.control-dock .section-eyebrow{margin-bottom:2px;font-size:.54rem}.control-dock .section-header h2{font-size:.82rem}.control-dock .info-tag{flex:none;padding:4px 8px;font-size:.62rem}.reference-workbench{grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:6px;height:100%;min-height:0;display:grid}.reference-gallery{border:1px dashed var(--border-strong);scrollbar-width:thin;background:linear-gradient(#fcfdff 0%,#f3f7fb 100%);border-radius:14px;align-items:center;gap:6px;min-height:0;max-height:none;padding:5px;display:flex;overflow:auto hidden}.reference-gallery.empty{justify-content:center;align-items:center;display:flex}.reference-gallery.many{display:flex}.reference-empty{text-align:center;max-width:none;color:var(--text-faint);white-space:nowrap;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:0 6px;font-size:.62rem;line-height:1.15;display:flex}.reference-thumb{border:1px solid var(--border);width:60px;min-height:60px;box-shadow:var(--shadow-sm);background:#f8fafc;border-radius:10px;flex:0 0 60px;transition:transform .2s;position:relative;overflow:hidden}.reference-thumb:hover{transform:translateY(-2px)}.reference-thumb img{object-fit:contain;cursor:zoom-in;width:100%;height:100%;display:block}.reference-add-tile{border:1px dashed var(--border-strong);width:60px;height:60px;color:var(--accent);white-space:nowrap;background:#fff;border-radius:10px;flex-direction:column;flex:0 0 60px;justify-content:center;align-items:center;gap:3px;font-size:.6rem;font-weight:700;display:flex}.reference-add-tile:disabled{cursor:not-allowed;opacity:.62}.upload-action-stack{flex-direction:column;justify-content:center;gap:6px;min-width:42px;display:flex}.upload-cta,.generate-btn,.d-btn.primary{background:linear-gradient(135deg, var(--accent) 0%, #3b78ff 100%);color:#fff;border:none;box-shadow:0 16px 30px #2060ff38}.upload-cta,.ghost-action,.generate-btn,.icon-btn,.copy-action-btn,.d-btn{border-radius:14px;justify-content:center;align-items:center;gap:6px;padding:6px 8px;text-decoration:none;transition:all .2s;display:inline-flex}.upload-cta,.generate-btn{min-height:30px;font-size:.66rem;font-weight:700}.ghost-action{min-height:30px;font-size:.62rem}.upload-cta:hover,.generate-btn:hover,.d-btn.primary:hover{background:linear-gradient(135deg, var(--accent-strong) 0%, #245cf0 100%);transform:translateY(-1px)}.upload-cta:disabled,.ghost-action:disabled,.generate-btn:disabled,.up-del:disabled,.prompt-form textarea:disabled,.config-field select:disabled{cursor:not-allowed;opacity:.62}.ghost-action,.icon-btn,.copy-action-btn,.d-btn{border:1px solid var(--border);color:var(--text-soft);background:#fff}.ghost-action:hover,.icon-btn:hover,.copy-action-btn:hover,.d-btn:hover{border-color:var(--accent);color:var(--accent)}.prompt-form{grid-template-rows:auto auto;gap:6px;height:100%;min-height:0;display:grid}.prompt-form textarea{border:1px solid var(--border);height:60px;min-height:0;max-height:60px;color:var(--text-main);resize:none;background:linear-gradient(#fff 0%,#f8fbff 100%);border-radius:14px;outline:none;padding:10px 12px;font-size:.76rem;line-height:1.4;transition:border-color .2s,box-shadow .2s}.prompt-form textarea:focus,.inline-settings input:focus,.inline-settings select:focus,.config-field select:focus{border-color:#2060ff5c;box-shadow:0 0 0 4px #2060ff14}.prompt-footer{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;min-height:0;display:grid}.config-row{grid-template-columns:minmax(100px,1fr) minmax(120px,1.2fr) minmax(70px,.6fr) minmax(60px,.5fr);gap:8px;min-width:0;display:grid}.config-field{flex-direction:column;gap:3px;min-width:0;display:flex}.config-field span{color:var(--text-faint);font-size:.56rem;font-weight:800}.config-field select{border:1px solid var(--border);width:100%;height:34px;color:var(--text-main);background:#fff;border-radius:8px;outline:none;padding:0 8px;font-size:.68rem;font-weight:700}.config-field.compact select{text-align:center}.generate-btn{white-space:nowrap;min-width:88px;height:34px}.generate-btn:disabled{transform:none}.inline-settings{border:1px solid var(--border);background:linear-gradient(#f9fbfe 0%,#f2f6fb 100%);border-radius:16px;grid-template-columns:minmax(0,1fr);gap:10px;padding:12px;display:grid}.s-group{flex-direction:column;gap:6px;display:flex}.s-group label{color:var(--text-faint);font-size:.7rem;font-weight:700}.s-group input,.s-group select{border:1px solid var(--border);width:100%;min-width:0;color:var(--text-main);background:#fff;border-radius:12px;outline:none;padding:9px 10px}.rail-card{border-radius:22px;flex-direction:column;gap:10px;width:100%;min-width:0;height:100%;min-height:0;padding:14px;animation:.64s ease-out rise-in;display:flex;overflow:hidden}.history-panel{flex:1}.details-scroller{flex-direction:column;gap:10px;min-height:0;display:flex;overflow:auto}.image-preview-card{cursor:zoom-in;box-shadow:var(--shadow-sm);background:linear-gradient(#f8fbff 0%,#edf3f9 100%);border-radius:16px;position:relative;overflow:hidden}.image-preview-card img{object-fit:contain;width:100%;max-height:170px;display:block}.zoom-hint{color:#fff;background:#142033b8;border-radius:999px;padding:5px 8px;font-size:.66rem;position:absolute;bottom:12px;right:12px}.info-group,.info-section,.detail-footer-btns{flex-direction:column;gap:10px;display:flex}.info-row{border-bottom:1px solid var(--border);justify-content:space-between;gap:12px;padding-bottom:8px;display:flex}.info-row label,.info-section label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);font-size:.66rem;font-weight:800}.info-row span{color:var(--text-main);font-size:.76rem}.prompt-copy-wrapper{background:var(--bg-muted);border:1px solid var(--border);border-radius:16px;padding:10px}.prompt-copy-wrapper p{color:var(--text-soft);max-height:96px;margin:0;font-size:.8rem;line-height:1.45;overflow:auto}.details-empty,.history-empty{border:1px dashed var(--border-strong);text-align:center;min-height:120px;color:var(--text-faint);border-radius:18px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:.82rem;display:flex}.history-list{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex;overflow:auto}.history-item{background:var(--bg-muted);cursor:pointer;border:1px solid #0000;border-radius:16px;grid-template-columns:46px minmax(0,1fr);gap:8px;padding:8px;transition:all .2s;display:grid}.history-item:hover{box-shadow:var(--shadow-sm);border-color:#2060ff2e;transform:translateY(-1px)}.history-item.active{background:var(--accent-soft);border-color:#2060ff3d}.history-item img{object-fit:cover;background:#fff;border-radius:12px;width:46px;height:46px}.history-info{flex-direction:column;justify-content:center;gap:6px;min-width:0;display:flex}.history-meta-line{color:var(--text-faint);align-items:center;gap:4px;font-size:.66rem;display:flex}.history-info p{-webkit-line-clamp:2;color:var(--text-main);-webkit-box-orient:vertical;margin:0;font-size:.78rem;line-height:1.35;display:-webkit-box;overflow:hidden}.up-del{color:#fff;background:#142033c7;border:none;border-radius:999px;place-items:center;width:22px;height:22px;display:grid;position:absolute;top:6px;right:6px}.icon-btn{width:32px;height:32px;padding:0}.spin{animation:1s linear infinite spin}.spin-slow{animation:2s linear infinite spin}.fullscreen-viewer{z-index:1000;background:#080e18f0;flex-direction:column;display:flex;position:fixed;inset:0}.viewer-toolbar{z-index:2;pointer-events:none;justify-content:space-between;align-items:center;gap:16px;padding:14px 18px;display:flex;position:absolute;inset:0 0 auto}.viewer-controls{color:#fff;pointer-events:auto;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff29;border-radius:999px;align-items:center;gap:8px;padding:8px 12px;display:inline-flex}.viewer-controls button,.close-viewer{color:inherit;background:0 0;border:none;place-items:center;display:grid}.viewer-canvas{flex:1;justify-content:center;align-items:center;padding:70px 24px 24px;display:flex;overflow:hidden}.viewer-canvas img{object-fit:contain;-webkit-user-select:none;user-select:none;max-width:min(96vw,1600px);max-height:calc(100dvh - 110px);box-shadow:0 24px 80px #00000052}.close-viewer{color:#fff;pointer-events:auto;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff2e;border-radius:999px;width:38px;height:38px}.close-viewer:hover,.viewer-controls button:hover{background:#ffffff3d}.context-menu-overlay{z-index:500;position:fixed;inset:0}.context-menu{z-index:501;border:1px solid var(--border);box-shadow:var(--shadow-lg);background:#fffffffa;border-radius:16px;flex-direction:column;gap:8px;min-width:240px;padding:10px;animation:.15s ease-out context-menu-in;display:flex;position:fixed}.context-menu-preview{align-items:center;gap:8px;padding:4px;display:flex}.context-menu-preview img{object-fit:cover;border:1px solid var(--border);background:var(--bg-muted);border-radius:8px;width:48px;height:48px}.context-menu-preview span{color:var(--text-soft);font-size:.72rem;font-weight:700}.context-menu-input{border:1px solid var(--border);background:var(--bg-muted);width:100%;min-height:60px;max-height:100px;color:var(--text-main);resize:none;border-radius:10px;outline:none;padding:8px 10px;font-size:.74rem;line-height:1.4;transition:border-color .2s}.context-menu-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2060ff1a}.context-menu-btn{background:linear-gradient(135deg, var(--accent) 0%, #3b78ff 100%);color:#fff;border:none;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;padding:8px 12px;font-size:.72rem;font-weight:700;transition:all .2s;display:flex}.context-menu-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #2060ff40}.context-menu-btn:disabled{cursor:not-allowed;opacity:.62}@keyframes context-menu-in{0%{opacity:0;transform:scale(.95)translateY(-5px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes rise-in{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes soft-fade{0%{opacity:0}to{opacity:1}}@media (width<=1280px){.workspace{grid-template-columns:220px minmax(0,1fr) 280px;height:auto;overflow:visible}body{overflow:auto}}@media (width<=980px){.workspace{grid-template-columns:1fr;gap:14px;height:auto;padding:14px;overflow:visible}.topbar,.canvas-stage,.dock-card,.rail-card{border-radius:24px}.control-dock,.reference-workbench,.inline-settings{grid-template-rows:none;grid-template-columns:1fr}.history-sidebar,.details-sidebar{display:block}.control-dock{min-height:auto;max-height:none}.prompt-footer{grid-template-columns:1fr}.upload-action-stack{flex-flow:wrap}.generate-btn{width:100%}}@media (width<=640px){body{overflow:auto}.topbar,.canvas-stage,.dock-card,.rail-card{padding:16px}.topbar{width:100%;max-width:none;position:static}.topbar-actions,.section-header,.prompt-footer{width:100%}.canvas-stage>.section-header{padding-right:0}.section-header,.prompt-footer{align-items:flex-start}.prompt-footer{grid-template-columns:1fr;justify-items:stretch}.stage-surface{padding:16px}.reference-gallery{display:flex}.history-item{grid-template-columns:56px minmax(0,1fr)}.history-item img{width:56px;height:56px}}@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-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{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-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-ease{syntax:"*";inherits:false}@keyframes pulse{50%{opacity:.5}}
