@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@300;400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{color-scheme:light;--bg: #f5f7fb;--text: #0f172a;--muted: #64748b;--panel: #ffffff;--surface: #f0f4f8;--border: #d7dee7;--accent: #111827;--accent-soft: #eef2f6;--shadow: 0 10px 22px rgba(15, 23, 42, .12)}[data-theme=dark]{color-scheme:dark;--bg: #0b1220;--text: #f1f5f9;--muted: #94a3b8;--panel: #111827;--surface: #151f2e;--border: #334155;--accent: #f8fafc;--accent-soft: #0f1a2b;--shadow: 0 0 0 rgba(0, 0, 0, 0)}*{box-sizing:border-box}body{margin:0;font-family:IBM Plex Sans,sans-serif;color:var(--text);background:var(--bg);min-height:100vh}#root{min-height:100vh}.page{height:100vh;display:flex;flex-direction:column}.container{width:100%;height:100%;padding:16px;display:flex;flex-direction:column;gap:16px}.card{background:var(--panel);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow)}.header-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;position:relative}.header-title{display:flex;align-items:center;gap:12px}.header-card h1{font-family:Space Grotesk,sans-serif;font-size:20px;margin:0}.lang-switch{display:inline-flex;gap:6px;background:var(--accent-soft);border:1px solid var(--border);border-radius:999px;padding:4px}[data-theme=dark] .lang-switch{background:#0f172a;border-color:#ffffff1a}.lang-switch button{border:none;background:transparent;padding:4px 10px;border-radius:999px;cursor:pointer;font-size:12px;color:var(--muted);transition:color .2s ease,background .2s ease}.lang-switch button.active{background:var(--accent);color:#fff}[data-theme=dark] .lang-switch button{color:#cbd5f5}[data-theme=dark] .lang-switch button:hover{background:#1e293b}[data-theme=dark] .lang-switch button.active{background:#33415599;color:#f1f5f9}.grid{flex:1;display:grid;grid-template-columns:320px 1fr;gap:16px;overflow:hidden}.sidebar-card{display:flex;flex-direction:column;height:100%;overflow:hidden}.sidebar-body{padding:16px;display:flex;flex-direction:column;gap:12px;flex:1;overflow-y:auto}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}.sidebar-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.tab{border:1px solid var(--border);background:var(--accent-soft);color:var(--text);padding:6px 12px;border-radius:999px;font-size:13px;cursor:pointer;width:100%;text-align:center}.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}[data-theme=dark] .tab{background:#0f172a;color:#cbd5f5;border-color:#ffffff1a}[data-theme=dark] .tab:hover{background:#1e293b}[data-theme=dark] .tab.active{background:#33415599;color:#f1f5f9;border-color:#ffffff1a;box-shadow:0 0 0 1px #ffffff1a}.textarea-label{font-size:13px;font-weight:600}.prompt-input{border:1px solid var(--border);border-radius:14px;padding:10px 12px;font-family:inherit;font-size:14px;background:var(--panel);color:var(--text);outline:none;min-height:120px;resize:vertical}.accordion{display:grid;gap:8px}.accordion-header{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:8px 12px;font-size:13px;font-weight:600;cursor:pointer}.accordion-left{display:inline-flex;align-items:center;gap:8px}.accordion-icon{width:10px;height:10px;border-radius:999px;background:var(--accent)}.accordion-chevron{color:var(--muted);font-size:12px}.accordion-body{display:grid;gap:12px}.role-card{border:1px solid var(--border);border-radius:16px;background:var(--panel);padding:12px;display:grid;gap:12px}.role-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.role-title{font-size:13px;font-weight:600}.role-action{border:1px solid var(--border);background:var(--accent-soft);color:var(--text);border-radius:999px;padding:4px 12px;font-size:12px;cursor:pointer}.role-body{display:grid;gap:10px}.role-empty{font-size:12px;color:var(--muted)}.role-list{display:grid;gap:8px}.role-item{border:1px solid var(--border);border-radius:12px;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--surface)}.role-item-main{display:grid;gap:4px}.role-item-title{font-size:13px;font-weight:600}.role-item-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12px;color:var(--muted)}.role-chip{border-radius:999px;padding:2px 8px;border:1px solid var(--border);background:var(--panel);font-size:11px;color:var(--text)}.role-muted{color:var(--muted)}.role-item-actions{display:flex;gap:8px}.role-link{border:none;background:transparent;color:var(--text);font-size:12px;cursor:pointer}.role-link.danger{color:#b91c1c}.role-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:grid;place-items:center;z-index:60}.role-modal{background:var(--panel);border-radius:16px;padding:16px;width:min(420px,90vw);display:grid;gap:12px;border:1px solid var(--border);box-shadow:var(--shadow)}.role-modal-header{display:flex;align-items:center;justify-content:space-between;font-weight:600}.role-close{border:none;background:var(--accent);color:#fff;width:28px;height:28px;border-radius:999px;cursor:pointer}.role-modal-body{display:grid;gap:10px}.role-field{display:grid;gap:6px}.role-label{font-size:12px;color:var(--muted);font-weight:600}.role-position-row{display:flex;align-items:center;gap:8px}.role-grid{display:grid;gap:6px;margin-top:8px}.role-grid-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.role-grid-cell{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:8px;padding:6px 0;font-size:12px;cursor:pointer}.role-grid-cell.active{background:var(--accent);color:#fff;border-color:var(--accent)}.role-hint{margin:6px 0 0;font-size:12px;color:var(--muted)}.role-modal-actions{display:flex;justify-content:flex-end}.vibe-card{border:1px solid var(--border);border-radius:16px;background:var(--panel);padding:12px;display:grid;gap:12px}.vibe-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.vibe-title{font-size:13px;font-weight:600}.vibe-action{border:1px solid var(--border);background:var(--accent-soft);color:var(--text);border-radius:999px;padding:4px 12px;font-size:12px;cursor:pointer}.vibe-action:disabled{opacity:.6;cursor:not-allowed}.vibe-file{display:none}.vibe-body{display:grid;gap:10px}.vibe-count{font-size:12px;color:var(--muted)}.vibe-list{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start}.vibe-item{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:8px;display:grid;gap:8px;width:clamp(180px,24vw,260px);transition:transform .2s ease,box-shadow .2s ease}.vibe-item:hover{transform:scale(1.02);box-shadow:var(--shadow)}.vibe-item:hover .vibe-preview img{transform:scale(1.06)}.vibe-preview{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:var(--panel);width:100%;aspect-ratio:1 / 1}.vibe-preview img{width:100%;height:100%;display:block;border-radius:12px;object-fit:cover;transition:transform .2s ease;will-change:transform}.vibe-remove{position:absolute;top:8px;right:8px;border:none;background:#0f172ab3;color:#fff;width:24px;height:24px;border-radius:999px;cursor:pointer}.vibe-controls{display:grid;gap:8px}.vibe-slider{display:grid;gap:6px}.vibe-slider-label{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:600}.param-group{display:grid;gap:12px}.field{display:flex;flex-direction:column;gap:6px;font-size:13px}.field-label{font-size:12px;color:var(--muted);font-weight:500}.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.input{border:1px solid var(--border);border-radius:12px;height:40px;padding:0 12px;font-family:inherit;font-size:14px;background:var(--panel);color:var(--text);outline:none}.input::placeholder,.prompt-input::placeholder{color:#64748b}[data-theme=dark] .input::placeholder,[data-theme=dark] .prompt-input::placeholder{color:#64748b}.primary{border:none;border-radius:10px;padding:8px 12px;background:var(--accent);color:#fff;cursor:pointer;font-size:13px;font-weight:600}.primary:hover{filter:brightness(.95)}[data-theme=dark] .primary{background:#fff;color:#0f172a}.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.slider-field{display:grid;gap:6px}.slider-label{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600}.sidebar-footer{position:sticky;bottom:0;padding:12px 16px;border-top:1px solid var(--border);background:var(--panel);display:grid;gap:12px}.sidebar-footer .accordion-body{max-height:min(42vh,360px);overflow-y:auto;padding-right:4px}.generate-button{width:100%;border:none;border-radius:12px;padding:12px 16px;background:var(--accent);color:#fff;font-weight:600;font-size:14px;cursor:pointer}[data-theme=dark] .generate-button{background:#2563ebcc;color:#fff}.generate-button:hover{filter:brightness(.95)}.generate-button:disabled{background:#e2e8f0;color:#64748b;cursor:default;filter:none}[data-theme=dark] .generate-button:hover{background:#2563eb}[data-theme=dark] .generate-button:disabled{background:#1f2937;color:#64748b}.right-column{display:flex;flex-direction:column;gap:16px;height:100%;min-height:0}.result-card{padding:12px;flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.result-surface{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;flex:1;min-height:0;height:100%;overflow:auto}.result-stack{display:flex;flex-direction:column;gap:12px;min-height:0;height:100%;flex:1;align-items:center}.latest-preview{border:1px solid var(--border);border-radius:16px;overflow:hidden;padding:0;background:var(--panel);cursor:pointer;display:flex;align-items:center;justify-content:center;flex:0 0 auto;height:100%;min-height:100%;margin-bottom:16px}.latest-preview img{max-height:100%;width:auto;max-width:100%;object-fit:contain;display:block}.latest-preview:last-child{margin-bottom:0}.placeholder{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;color:var(--muted)}.placeholder h2{margin:0;color:var(--text);font-size:20px}.status-card{padding:12px 16px;display:grid;gap:8px}.status-card.compact{padding:8px 16px;min-height:56px;max-height:72px;flex:none}.status-toast{padding:12px 16px;border-radius:12px;font-size:13px;font-weight:600;border:1px solid var(--border);box-shadow:var(--shadow);background:var(--panel);max-width:min(360px,70vw)}.header-status{box-shadow:none}.header-toast{box-shadow:none;padding:8px 14px;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none}.status-toast.info{background:#e0efff;color:#1e40af}.status-toast.warn{background:#fef3c7;color:#b45309}.status-toast.error{background:#fee2e2;color:#b91c1c}.status-toast.success{background:#dcfce7;color:#15803d}.status-banner{padding:10px 12px;border-radius:12px;font-size:13px;font-weight:600;display:flex;align-items:center}.status-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.status-banner.info{background:#e0efff;color:#1e40af}.status-banner.warn{background:#fef3c7;color:#b45309}.status-banner.error{background:#fee2e2;color:#b91c1c}.status-banner.success{background:#dcfce7;color:#15803d}[data-theme=dark] .card{box-shadow:none;border-color:#334155}[data-theme=dark] .status-banner.info{background:#1e3a8a;color:#e2e8f0}[data-theme=dark] .status-banner.warn{background:#854d0e;color:#fef3c7}[data-theme=dark] .status-banner.error{background:#7f1d1d;color:#fee2e2}[data-theme=dark] .status-banner.success{background:#166534;color:#dcfce7}[data-theme=dark] .status-toast{border-color:#ffffff1f;box-shadow:none}[data-theme=dark] .status-toast.info{background:#1e3a8a;color:#e2e8f0}[data-theme=dark] .status-toast.warn{background:#854d0e;color:#fef3c7}[data-theme=dark] .status-toast.error{background:#7f1d1d;color:#fee2e2}[data-theme=dark] .status-toast.success{background:#166534;color:#dcfce7}.status-header{display:flex;align-items:center;justify-content:space-between}.status-header h3{margin:0;font-size:15px}.muted{color:var(--muted)}.error{color:#b91c1c}.gallery{display:flex;flex-direction:column;gap:12px;min-height:100%}.thumb{border:1px solid var(--border);border-radius:16px;overflow:hidden;cursor:pointer;padding:0;background:var(--panel);transition:transform .2s ease,box-shadow .2s ease;display:flex;align-items:center;justify-content:center}.thumb:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.thumb img{width:100%;height:auto;max-width:100%;object-fit:contain;display:block}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;display:grid;place-items:center;z-index:50}.modal{background:#fff;border-radius:20px;padding:20px;width:min(90vw,720px);max-height:90vh;box-shadow:var(--shadow);position:relative;display:grid;gap:12px;justify-items:center}.modal img{max-width:100%;max-height:calc(90vh - 140px);width:auto;height:auto;border-radius:16px}.announcement-modal{background:#fff;border-radius:20px;padding:24px;width:min(90vw,520px);box-shadow:var(--shadow);position:relative;display:grid;gap:16px;border:1px solid var(--border)}.announcement-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.announcement-title{font-size:18px;font-weight:700}.announcement-tag{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;background:#eef2ff;color:#4338ca}.announcement-content{white-space:pre-wrap;font-size:13px;line-height:1.6;color:var(--text)}.announcement-image{border-radius:14px;overflow:hidden;border:1px solid var(--border);background:var(--panel)}.announcement-image img{width:100%;display:block}.announcement-close{width:100%}.close{position:absolute;top:12px;right:12px;border:none;background:#111827;color:#fff;border-radius:999px;width:32px;height:32px;cursor:pointer}.download{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:999px;background:#111827;color:#fff;text-decoration:none;font-size:14px}@media (max-width: 1100px){.grid{grid-template-columns:1fr}.sidebar-body{max-height:none}.settings-row{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){*{transition:none!important}}.header-actions{display:flex;align-items:center;gap:8px}.points-wrap{position:relative}.points-button{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:999px;height:32px;padding:0 12px;font-size:12px;font-weight:600;cursor:pointer}.points-popover{position:absolute;right:0;top:calc(100% + 8px);width:min(320px,86vw);border:1px solid var(--border);border-radius:12px;background:var(--panel);box-shadow:var(--shadow);padding:12px;display:grid;gap:10px;z-index:40}.points-info-row{display:grid;gap:4px;font-size:12px}.icon-button{border:1px solid var(--border);background:var(--accent-soft);color:var(--text);border-radius:999px;height:32px;padding:0 12px;font-size:12px;cursor:pointer}.icon-button:disabled{cursor:not-allowed;opacity:.6}[data-theme=dark] .icon-button{border-color:#334155}.key-wrap{position:relative}.key-popover{position:absolute;right:0;top:calc(100% + 8px);background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:12px;width:220px;box-shadow:var(--shadow);display:grid;gap:10px;z-index:40}.settings-popover{width:min(360px,90vw);gap:12px}.settings-section{display:grid;gap:6px}.settings-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.settings-label{font-size:12px;font-weight:600;color:var(--muted)}.settings-control{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.settings-control .input{flex:0 1 140px;max-width:180px}.settings-popover .icon-button,.settings-popover .primary{height:36px;padding:0 12px}.settings-popover .lang-switch{height:36px;align-items:center}.settings-divider{height:1px;background:var(--border);opacity:.7}
