@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";@layer components;@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-border-style:solid;--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}}}@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-300:oklch(80.8% .114 19.571);--color-red-500:oklch(63.7% .237 25.331);--color-emerald-300:oklch(84.5% .143 164.978);--color-emerald-500:oklch(69.6% .17 162.48);--color-violet-300:oklch(81.1% .111 293.571);--color-violet-500:oklch(60.6% .25 292.717);--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--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);--blur-sm:8px;--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;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 utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.right-4{right:calc(var(--spacing) * 4)}.bottom-4{bottom:calc(var(--spacing) * 4)}.z-50{z-index:50}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.table{display:table}.translate-y-0{--tw-translate-y:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-2{--tw-translate-y:calc(var(--spacing) * 2);translate:var(--tw-translate-x) var(--tw-translate-y)}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.gap-2{gap:calc(var(--spacing) * 2)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-emerald-500\/30{border-color:#00bb7f4d}@supports (color:color-mix(in lab,red,red)){.border-emerald-500\/30{border-color:color-mix(in oklab,var(--color-emerald-500) 30%,transparent)}}.border-red-500\/30{border-color:#fb2c364d}@supports (color:color-mix(in lab,red,red)){.border-red-500\/30{border-color:color-mix(in oklab,var(--color-red-500) 30%,transparent)}}.border-violet-500\/30{border-color:#8d54ff4d}@supports (color:color-mix(in lab,red,red)){.border-violet-500\/30{border-color:color-mix(in oklab,var(--color-violet-500) 30%,transparent)}}.bg-emerald-500\/10{background-color:#00bb7f1a}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/10{background-color:color-mix(in oklab,var(--color-emerald-500) 10%,transparent)}}.bg-red-500\/10{background-color:#fb2c361a}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/10{background-color:color-mix(in oklab,var(--color-red-500) 10%,transparent)}}.bg-violet-500\/10{background-color:#8d54ff1a}@supports (color:color-mix(in lab,red,red)){.bg-violet-500\/10{background-color:color-mix(in oklab,var(--color-violet-500) 10%,transparent)}}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-3{padding-block:calc(var(--spacing) * 3)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-emerald-300{color:var(--color-emerald-300)}.text-red-300{color:var(--color-red-300)}.text-violet-300{color:var(--color-violet-300)}.uppercase{text-transform:uppercase}.opacity-0{opacity:0}.opacity-100{opacity:1}.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-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-300{--tw-duration:.3s;transition-duration:.3s}}:root{--surface-0:#08080c;--surface-1:#0e0e14;--surface-2:#141419;--surface-3:#1a1a22;--surface-4:#222230;--surface-hover:#2a2a38;--text-primary:#e8e8f0;--text-secondary:#9898a8;--text-muted:#5c5c6c;--text-ghost:#3a3a48;--accent:#8b46ff;--accent-dim:#6b2fd4;--accent-glow:#8b46ff1f;--accent-text:#b78aff;--accent-bright:#a66aff;--color-success:#22c55e;--color-error:#ef4444;--color-warning:#f59e0b;--border:#1e1e28;--border-active:#2e2e3c;--border-subtle:#18181e;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:40px;--space-2xl:64px;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 32px #0009;--shadow-glow:0 0 24px #8b46ff1a;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--font-display:"Space Grotesk", sans-serif;--font-mono:"JetBrains Mono", monospace;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.12s;--duration-normal:.2s;--duration-slow:.35s}*{box-sizing:border-box}body{background:var(--surface-0);color:var(--text-primary);font-family:var(--font-display);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-size:14px;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-4);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-glow);color:var(--accent-text)}:focus-visible{outline:1.5px solid var(--accent);outline-offset:2px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:1.8s ease-in-out infinite shimmer}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .25s var(--ease-out) forwards}@keyframes spin{to{transform:rotate(360deg)}}@keyframes dotPulse{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}@keyframes vinylSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.app-root{background:var(--surface-0);flex-direction:column;height:100vh;display:flex}.app-header{background:var(--surface-0);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 20px;display:flex}.app-header-left{align-items:center;gap:12px;display:flex}.app-logo{background:linear-gradient(135deg,var(--accent),var(--accent-dim));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex;box-shadow:0 0 12px #8b46ff33}.app-header-title{color:var(--text-secondary);letter-spacing:-.02em;font-size:13px;font-weight:600}.app-header-center{align-items:center;gap:6px;display:flex}.app-header-right{align-items:center;gap:8px;display:flex}.header-chip{border:1px solid var(--border);background:var(--surface-1);color:var(--text-muted);font-family:var(--font-display);cursor:pointer;transition:all var(--duration-fast) ease;white-space:nowrap;border-radius:100px;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:500;display:flex}.header-chip:hover{border-color:var(--border-active);color:var(--text-secondary);background:var(--surface-2)}.header-chip--active{background:var(--accent-glow);color:var(--accent-text);border-color:#8b46ff4d}.header-chip-icon{font-size:13px;line-height:1}.header-chip-count{font-family:var(--font-mono);background:var(--surface-3);color:var(--text-ghost);border-radius:8px;padding:0 5px;font-size:10px}.header-chip--active .header-chip-count{color:var(--accent-text);background:#8b46ff33}.project-banner{background:var(--surface-1);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 24px;display:flex}.project-banner-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.project-banner-title{color:var(--text-primary);letter-spacing:-.01em;font-size:14px;font-weight:600}.project-banner-meta{align-items:center;gap:8px;display:flex}.project-banner-tag{font-family:var(--font-mono);background:var(--accent-glow);color:var(--accent-text);border:1px solid #8b46ff1f;border-radius:100px;padding:2px 8px;font-size:10px}.project-banner-tag--muted{background:var(--surface-3);color:var(--text-muted);border-color:#0000}.project-banner-actions{align-items:center;gap:6px;display:flex}.project-banner-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast) ease;background:0 0;padding:5px 10px;font-size:12px}.project-banner-btn:hover{background:var(--surface-3);color:var(--text-secondary);border-color:var(--border-active)}.app-main,.app-content{flex-direction:column;flex:1;min-height:0;display:flex}.app-grid-area{flex:1;padding:20px 24px 200px;overflow-y:auto}.empty-state{-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;gap:8px;height:100%;display:flex}.empty-state-icon{background:var(--surface-2);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:8px;display:flex}.empty-state-vinyl{border:3px solid var(--surface-4);opacity:.3;border-radius:50%;width:36px;height:36px;position:relative}.empty-state-vinyl:after{content:"";background:var(--accent-dim);border-radius:50%;width:8px;height:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.empty-state-title{color:var(--text-muted);margin:0;font-size:15px;font-weight:500}.empty-state-hint{font-family:var(--font-mono);color:var(--text-ghost);text-align:center;margin:0;font-size:12px}.cover-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;display:grid}.cover-card{aspect-ratio:1;background:var(--surface-2);border-radius:var(--radius-lg);border:1px solid var(--border);cursor:pointer;transition:border-color var(--duration-normal) ease,box-shadow var(--duration-normal) ease,transform var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.cover-card:hover{border-color:var(--border-active);box-shadow:var(--shadow-md);transform:translateY(-2px)}.cover-card-img{object-fit:cover;width:100%;height:100%}.cover-overlay{opacity:0;transition:opacity var(--duration-normal) var(--ease-out);background:linear-gradient(#08080c80,#0000 35% 55%,#08080cd9);flex-direction:column;justify-content:space-between;padding:10px;display:flex;position:absolute;inset:0}.cover-card:hover .cover-overlay{opacity:1}.cover-actions-top{justify-content:flex-end;gap:4px;display:flex}.cover-action-btn{border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);width:30px;height:30px;color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) ease;background:#ffffff14;border:none;justify-content:center;align-items:center;font-size:14px;display:flex}.cover-action-btn:hover{background:#ffffff29;transform:scale(1.05)}.cover-action-btn--fav{color:#ff6b8a;background:#ff6b8a33}.cover-info{flex-direction:column;gap:4px;display:flex}.cover-model-tag{color:var(--accent-text);font-family:var(--font-mono);background:#8b46ff33;border-radius:4px;width:fit-content;padding:2px 6px;font-size:10px;display:inline-block}.cover-prompt-text{color:var(--text-primary);opacity:.9;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:11px;line-height:1.4;display:-webkit-box;overflow:hidden}.cover-drag-hint{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-muted);opacity:0;transition:opacity var(--duration-fast) ease;background:#0009;border-radius:4px;padding:2px 6px;font-size:9px;position:absolute;bottom:8px;left:8px}.cover-card:hover .cover-drag-hint{opacity:1}.cover-fav-badge{z-index:2;background:#ff6b8acc;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;display:flex;position:absolute;top:8px;right:8px}.prompt-bar-wrapper{background:linear-gradient(to bottom,transparent,var(--surface-0) 8px);flex-shrink:0;padding:12px 24px 20px;transition:outline .15s,outline-offset .15s}.prompt-bar-wrapper--dragover{outline:2px dashed var(--accent);outline-offset:-4px;border-radius:var(--radius-lg)}.prompt-bar-container{max-width:760px;margin:0 auto}.prompt-error{border-radius:var(--radius-sm);color:var(--color-error);font-family:var(--font-mono);background:#ef444414;border:1px solid #ef444426;margin-bottom:8px;padding:8px 12px;font-size:12px}.prompt-loading{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:10px;margin-bottom:10px;font-size:11px;display:flex}.prompt-loading-dots{gap:3px;display:flex}.prompt-loading-dot{background:var(--accent);border-radius:50%;width:4px;height:4px;animation:1.4s ease-in-out infinite dotPulse}.prompt-loading-dot:nth-child(2){animation-delay:.15s}.prompt-loading-dot:nth-child(3){animation-delay:.3s}.prompt-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-xl);transition:border-color var(--duration-normal) ease,box-shadow var(--duration-normal) ease;box-shadow:var(--shadow-sm);padding:14px 16px 10px;position:relative}.prompt-card:focus-within{border-color:var(--border-active);box-shadow:var(--shadow-md),var(--shadow-glow)}.prompt-context-row{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.prompt-context-pill{background:var(--accent-glow);color:var(--accent-text);font-family:var(--font-mono);border:1px solid #8b46ff1f;border-radius:100px;padding:2px 8px;font-size:10px}.prompt-textarea{resize:none;width:100%;color:var(--text-primary);font-family:var(--font-display);background:0 0;border:none;outline:none;padding:0 2px;font-size:14px;line-height:1.6}.prompt-textarea::placeholder{color:var(--text-ghost)}.prompt-toolbar{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;margin-top:8px;padding-top:10px;display:flex}.prompt-toolbar-left{align-items:center;gap:4px;display:flex}.prompt-tool-btn{border-radius:var(--radius-sm);color:var(--text-muted);font-size:12px;font-family:var(--font-display);cursor:pointer;transition:all var(--duration-fast) ease;background:0 0;border:none;align-items:center;gap:5px;padding:5px 10px;display:flex}.prompt-tool-btn:hover{background:var(--surface-3);color:var(--text-secondary)}.prompt-tool-select-wrapper{align-items:center;display:flex;position:relative}.prompt-tool-select{appearance:none;border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-mono);cursor:pointer;transition:all var(--duration-fast) ease;background:0 0;border:none;outline:none;padding:5px 22px 5px 10px;font-size:11px}.prompt-tool-select:hover{background:var(--surface-3);color:var(--text-secondary)}.prompt-tool-select option{background:var(--surface-2);color:var(--text-primary)}.prompt-tool-select-chevron{pointer-events:none;color:var(--text-ghost);position:absolute;right:6px}.prompt-count-group{background:var(--surface-2);border-radius:var(--radius-sm);gap:2px;padding:2px;display:flex}.prompt-count-btn{width:24px;height:24px;color:var(--text-muted);font-family:var(--font-mono);cursor:pointer;transition:all var(--duration-fast) ease;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:11px;font-weight:500;display:flex}.prompt-count-btn:hover{color:var(--text-secondary)}.prompt-count-btn--active{background:var(--accent);color:#fff}.prompt-toolbar-right{align-items:center;gap:8px;display:flex}.prompt-generate-btn{background:var(--accent);color:#fff;cursor:pointer;width:36px;height:36px;transition:all var(--duration-fast) ease;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.prompt-generate-btn:hover:not(:disabled){transform:scale(1.06);box-shadow:0 0 16px #8b46ff59}.prompt-generate-btn:disabled{background:var(--surface-3);color:var(--text-muted);cursor:not-allowed}.prompt-spinner{animation:.8s linear infinite spin}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--space-xl);animation:fadeIn .15s var(--ease-out);background:#08080ce0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-container{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:800px;max-height:85vh;box-shadow:var(--shadow-lg),0 0 80px #0006;animation:scaleIn .2s var(--ease-out);flex-direction:column;display:flex}.modal-header{padding:var(--space-lg) var(--space-lg) var(--space-md);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.modal-header-text{flex-direction:column;gap:2px;display:flex}.modal-title{color:var(--text-primary);letter-spacing:-.03em;margin:0;font-size:18px;font-weight:600}.modal-subtitle{color:var(--text-muted);margin:0;font-size:12px}.modal-close{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast) ease;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.modal-close:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-active)}.modal-body{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex;overflow-y:auto}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);flex-shrink:0;display:flex}.modal-input{border-radius:var(--radius-sm);border:1px solid var(--border-active);background:var(--surface-3);color:var(--text-primary);font-size:13px;font-family:var(--font-display);transition:border-color var(--duration-fast) ease;outline:none;width:100%;padding:9px 12px}.modal-input:focus{border-color:var(--accent-dim)}.modal-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:10px;font-weight:600;display:block}.modal-btn{border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-display);cursor:pointer;transition:all var(--duration-fast) ease;border:none;padding:8px 18px;font-weight:600}.modal-btn--primary{background:var(--accent);color:#fff}.modal-btn--primary:hover:not(:disabled){opacity:.85}.modal-btn--primary:disabled{opacity:.4;cursor:not-allowed}.modal-btn--ghost{color:var(--text-muted);background:0 0}.modal-btn--ghost:hover{color:var(--text-secondary)}.modal-btn--danger{color:var(--color-error);background:#ef44441a;border:1px solid #ef444433}.modal-btn--danger:hover{background:#ef444433}.item-card{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-2);transition:all var(--duration-fast) ease;cursor:pointer;align-items:center;gap:12px;padding:12px 14px;display:flex}.item-card:hover{border-color:var(--border-active);background:var(--surface-3)}.item-card--active{background:var(--accent-glow);border-color:#8b46ff4d}.item-card-icon{background:linear-gradient(135deg,#8b46ff26,#8b46ff0d);border:1px solid #8b46ff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.item-card-info{flex:1;min-width:0}.item-card-name{color:var(--text-primary);font-size:13px;font-weight:600}.item-card-meta{color:var(--text-muted);align-items:center;gap:6px;margin-top:1px;font-size:11px;display:flex}.item-card-actions{opacity:0;transition:opacity var(--duration-fast) ease;gap:4px;display:flex}.item-card:hover .item-card-actions{opacity:1}.item-action-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast) ease;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;font-size:13px;display:flex}.item-action-btn:hover{background:var(--surface-4);color:var(--text-primary)}.item-action-btn--danger:hover{color:var(--color-error);background:#ef44441a}.upload-zone{border:2px dashed var(--border-active);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-lg);align-items:center;gap:var(--space-sm);cursor:pointer;transition:all var(--duration-fast) ease;background:var(--surface-0);text-align:center;flex-direction:column;display:flex}.upload-zone:hover,.upload-zone--active{border-color:var(--accent);background:var(--accent-glow)}.upload-zone-text{color:var(--text-secondary);font-size:14px;font-weight:500}.upload-zone-hint{font-family:var(--font-mono);color:var(--text-ghost);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.chat-overlay{z-index:1500;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--space-lg);animation:fadeIn .15s var(--ease-out);background:#08080ce0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.chat-container{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:600px;height:80vh;box-shadow:var(--shadow-lg);animation:scaleIn .2s var(--ease-out);flex-direction:column;display:flex}.chat-header{padding:14px var(--space-lg);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.chat-messages{padding:var(--space-md) var(--space-lg);gap:var(--space-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-msg{display:flex}.chat-msg--user{justify-content:flex-end}.chat-msg--assistant{justify-content:flex-start}.chat-bubble{border-radius:var(--radius-lg);max-width:85%;padding:10px 14px;font-size:13px;line-height:1.5}.chat-bubble--user{color:#d4b8ff;background:#8b46ff26;border:1px solid #8b46ff33}.chat-bubble--assistant{background:var(--surface-3);color:var(--text-secondary);border:1px solid var(--border)}.chat-input-area{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);gap:var(--space-sm);flex-shrink:0;display:flex}.chat-input{border:1px solid var(--border-active);border-radius:var(--radius-md);background:var(--surface-2);color:var(--text-primary);font-family:var(--font-display);resize:none;transition:border-color var(--duration-fast) ease;outline:none;flex:1;padding:10px 12px;font-size:13px}.chat-input:focus{border-color:var(--accent-dim)}.chat-send-btn{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;width:36px;height:36px;transition:all var(--duration-fast) ease;border:none;flex-shrink:0;justify-content:center;align-self:flex-end;align-items:center;display:flex}.chat-send-btn:hover:not(:disabled){background:var(--accent-bright)}.chat-send-btn:disabled{background:var(--surface-3);color:var(--text-muted);cursor:not-allowed}.lyrics-section{padding:var(--space-md);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md)}.lyrics-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.lyrics-label{font-family:var(--font-mono);color:var(--text-ghost);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.lyrics-content{font-family:var(--font-mono);color:var(--text-muted);white-space:pre-wrap;max-height:120px;font-size:11px;line-height:1.6;overflow-y:auto}.vinyl-spinner{border:2px solid var(--surface-4);border-radius:50%;animation:2s linear infinite vinylSpin;position:relative}.vinyl-spinner:after{content:"";background:var(--accent);border-radius:50%;width:30%;height:30%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.asset-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));display:grid}.asset-thumb{aspect-ratio:1;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-3);position:relative;overflow:hidden}.asset-thumb img{object-fit:cover;width:100%;height:100%}.asset-thumb-remove{width:20px;height:20px;color:var(--color-error);cursor:pointer;opacity:0;transition:opacity var(--duration-fast) ease;background:#000000a6;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:11px;display:flex;position:absolute;top:4px;right:4px}.asset-thumb:hover .asset-thumb-remove{opacity:1}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;top:16px;right:16px}.toast{border-radius:var(--radius-md);font-size:13px;font-family:var(--font-display);animation:slideUp .25s var(--ease-out);box-shadow:var(--shadow-md);padding:10px 16px}.toast--success{color:var(--color-success);background:#22c55e26;border:1px solid #22c55e40}.toast--error{color:var(--color-error);background:#ef444426;border:1px solid #ef444440}@media(max-width:640px){.app-header{gap:6px;padding:0 12px}.app-header-center{display:none}.cover-grid{grid-template-columns:repeat(2,1fr);gap:8px}.modal-overlay{padding:var(--space-sm)}.modal-container{border-radius:var(--radius-lg);max-width:100%;max-height:92vh}}.lb-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.lb-shell{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-xl,16px);width:100%;max-width:1200px;max-height:calc(100vh - 48px);display:flex;position:relative;overflow:hidden;box-shadow:0 32px 64px #00000080}.lb-close{z-index:10;background:var(--surface-2);width:32px;height:32px;color:var(--text-muted);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .12s;display:flex;position:absolute;top:12px;right:12px}.lb-close:hover{background:var(--surface-3);color:var(--text-primary)}.lb-nav{z-index:10;border:1px solid var(--border);background:var(--surface-1);width:40px;height:40px;color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lb-nav:hover{background:var(--surface-2);color:var(--text-primary);border-color:var(--accent-dim)}.lb-nav--left{left:-56px}.lb-nav--right{right:-56px}@media(max-width:1350px){.lb-nav--left{left:12px}.lb-nav--right{right:12px}.lb-nav{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#141218cc}}.lb-image-pane{background:var(--surface-0,#0a0a0f);flex:1;justify-content:center;align-items:center;min-width:0;padding:24px;display:flex;position:relative}.lb-image{object-fit:contain;border-radius:var(--radius-md);aspect-ratio:1;max-width:100%;max-height:calc(100vh - 96px)}.lb-counter{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-muted);letter-spacing:.5px;background:#141218bf;border-radius:999px;padding:4px 14px;font-size:11px;font-weight:500;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.lb-info-pane{border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:12px;width:340px;padding:20px;display:flex;overflow-y:auto}.lb-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.lb-model-tag{border-radius:var(--radius-sm);background:var(--accent-dim);color:var(--accent-text);letter-spacing:.3px;padding:3px 10px;font-size:11px;font-weight:600}.lb-date{color:var(--text-ghost);font-size:11px}.lb-prompt{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.lb-actions{flex-wrap:wrap;gap:6px;display:flex}.lb-action{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);cursor:pointer;align-items:center;gap:5px;padding:6px 12px;font-size:12px;transition:all .12s;display:inline-flex}.lb-action:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-active)}.lb-action--fav{color:#f43f5e;border-color:#f43f5e4d}.lb-action--fav:hover{background:#f43f5e1a}.lb-sections{flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.lb-section{border-radius:var(--radius-sm);overflow:hidden}.lb-section-toggle{width:100%;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:8px;padding:8px 10px;font-size:12px;font-weight:500;transition:background .1s;display:flex}.lb-section-toggle:hover{background:var(--surface-2)}.lb-section-icon{flex-shrink:0;font-size:13px}.lb-section-title{text-align:left;flex:1}.lb-section-chevron{color:var(--text-ghost);transition:transform .15s}.lb-section-chevron--open{transform:rotate(180deg)}.lb-section-content{padding:4px 10px 12px}@media(max-width:768px){.lb-shell{flex-direction:column;max-height:95vh}.lb-image-pane{max-height:50vh;padding:16px}.lb-info-pane{border-left:none;border-top:1px solid var(--border);width:100%;max-height:45vh}.lb-nav--left{left:8px}.lb-nav--right{right:8px}}.prompt-ref-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:4px;padding-bottom:8px;display:flex}.prompt-ref-label{color:var(--text-ghost);white-space:nowrap;font-size:11px;font-weight:500}.prompt-ref-thumbs{flex-wrap:wrap;gap:6px;display:flex}.prompt-ref-thumb{border-radius:var(--radius-sm);border:1px solid var(--border);flex-shrink:0;width:40px;height:40px;position:relative;overflow:hidden}.prompt-ref-thumb img{object-fit:cover;width:100%;height:100%}.prompt-ref-remove{background:var(--surface-1);width:16px;height:16px;color:var(--text-muted);cursor:pointer;opacity:0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:8px;transition:opacity .1s;display:flex;position:absolute;top:-2px;right:-2px}.prompt-ref-thumb:hover .prompt-ref-remove{opacity:1}.prompt-drop-overlay{border-radius:var(--radius-md);color:var(--accent-text);pointer-events:none;z-index:5;background:#8b46ff14;justify-content:center;align-items:center;font-size:13px;font-weight:500;display:flex;position:absolute;inset:0}.cover-reuse-btn{border-radius:var(--radius-sm);color:#ffffffbf;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff14;border:1px solid #ffffff26;margin-top:6px;padding:3px 8px;font-size:10px;transition:all .12s}.cover-reuse-btn:hover{background:var(--accent-dim);color:var(--accent-text);border-color:var(--accent)}.prompt-preview-toggle{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-ghost);cursor:pointer;background:0 0;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:500;transition:all .12s;display:inline-flex}.prompt-preview-toggle:hover{border-color:var(--border-active);color:var(--text-muted)}.prompt-preview-toggle--active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent-text)}.prompt-preview-toggle--active:hover{background:var(--accent);color:#fff}.prompt-variants-panel{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:10px;padding:14px;animation:.2s fadeIn}.prompt-variants-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.prompt-variants-title{color:var(--text-primary);font-size:13px;font-weight:600}.prompt-variants-analysis-btn{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-ghost);cursor:pointer;background:0 0;padding:3px 8px;font-size:10px;transition:all .1s}.prompt-variants-analysis-btn:hover{border-color:var(--border-active);color:var(--text-muted)}.prompt-variants-analysis{background:var(--surface-2);border-radius:var(--radius-md);border:1px solid var(--border);max-height:200px;margin-bottom:12px;padding:10px 12px;overflow-y:auto}.prompt-variants-analysis pre{color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;margin:0;font-family:inherit;font-size:11px;line-height:1.5}.prompt-variants-grid{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.prompt-variant-card{border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--surface-2);cursor:pointer;text-align:left;align-items:flex-start;gap:10px;width:100%;padding:10px 12px;transition:all .12s;display:flex}.prompt-variant-card:hover{border-color:var(--border-active);background:var(--surface-3)}.prompt-variant-card--selected{border-color:var(--accent);background:#8b46ff0f}.prompt-variant-card--selected:hover{border-color:var(--accent)}.prompt-variant-num{background:var(--surface-3);width:24px;height:24px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:11px;font-weight:700;display:flex}.prompt-variant-card--selected .prompt-variant-num{background:var(--accent);color:#fff}.prompt-variant-content{flex:1;min-width:0}.prompt-variant-title{color:var(--text-primary);margin-bottom:4px;font-size:12px;font-weight:600}.prompt-variant-text{color:var(--text-muted);-webkit-line-clamp:4;-webkit-box-orient:vertical;font-size:11px;line-height:1.45;display:-webkit-box;overflow:hidden}.prompt-variant-card--selected .prompt-variant-text{-webkit-line-clamp:unset;color:var(--text-secondary)}.prompt-variant-check{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:2px;font-size:11px;font-weight:700;display:flex}.prompt-variants-actions{gap:8px;display:flex}.prompt-variants-generate{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;border:none;flex:1;padding:8px 16px;font-size:13px;font-weight:600;transition:all .12s}.prompt-variants-generate:hover:not(:disabled){filter:brightness(1.1)}.prompt-variants-generate:disabled{opacity:.5;cursor:not-allowed}.prompt-variants-refresh{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-2);width:36px;height:36px;color:var(--text-muted);cursor:pointer;justify-content:center;align-items:center;font-size:16px;transition:all .12s;display:flex}.prompt-variants-refresh:hover:not(:disabled){border-color:var(--accent);color:var(--accent-text)}.prompt-variants-refresh:disabled{opacity:.4;cursor:not-allowed}@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-border-style{syntax:"*";inherits:false;initial-value:solid}@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}
