*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--ds-font-family-base);background-color:var(--ds-color-background);color:var(--ds-color-text-primary);overflow:hidden}.app-container{position:relative;width:100vw;height:100vh}#canvas{display:block;background-color:var(--ds-color-surface-2);border:1px solid var(--ds-color-border-subtle);cursor:grab;width:100%;height:100%}#canvas:active{cursor:grabbing}.return-chat-btn{position:fixed;top:20px;right:32px;z-index:var(--ds-elevation-overlay);padding:10px 18px;border-radius:var(--ds-radius-pill);border:1px solid var(--ds-color-border-subtle);background:rgba(13,17,27,.82);color:var(--ds-color-text-primary);font-size:var(--ds-font-size-sm);font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:background .2s ease,border-color .2s ease}.return-chat-btn:hover{background:rgba(25,32,48,.88);border-color:var(--ds-color-border-strong)}.chat-view{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;--chat-view-padding-y: clamp(20px, 4vw, 32px);--chat-sidebar-offset: var(--chat-view-padding-y);padding:var(--chat-view-padding-y) 32px;gap:var(--ds-space-16);background:var(--ds-color-surface-0);color:var(--ds-color-text-primary);overflow:hidden;z-index:1200}.chat-branch-nav{display:none;align-items:center;justify-content:center;gap:var(--ds-space-12);background:rgba(18,24,37,.6);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-pill);padding:var(--ds-space-8) var(--ds-space-16);min-height:38px}.chat-content{display:flex;flex:1;gap:24px;align-items:stretch;overflow:visible;min-height:0}.chat-content.sidebar-collapsed{gap:12px}.chat-main{flex:1;display:flex;flex-direction:column;gap:16px;overflow:hidden;min-width:0;min-height:0}.chat-main-toolbar{display:flex;align-items:center;justify-content:flex-start}.chat-sidebar{width:280px;background:var(--ds-color-surface-1);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-lg);padding:var(--ds-space-16);display:flex;flex-direction:column;gap:var(--ds-space-16);position:sticky;top:var(--chat-sidebar-offset);height:calc(100vh - (var(--chat-sidebar-offset) * 2));max-height:calc(100vh - (var(--chat-sidebar-offset) * 2));align-self:flex-start;overflow-x:hidden;overflow-y:auto;scrollbar-gutter:stable both-edges;min-height:0;transition:transform .2s ease,opacity .2s ease}.chat-sidebar.is-collapsed{display:none}.chat-sidebar-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;position:sticky;top:0;z-index:2;padding-bottom:var(--ds-space-8);margin-bottom:calc(var(--ds-space-16) - var(--ds-space-8));background:linear-gradient(180deg,var(--ds-color-surface-1) 0%,rgba(15,23,42,0) 100%)}.chat-sidebar-copy{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.chat-sidebar-title{font-size:var(--ds-font-size-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ds-color-text-secondary)}.chat-sidebar-subtitle{font-size:12px;color:#e2e8f0b3;line-height:1.5}.chat-sidebar-collapse-btn{background:transparent;color:var(--ds-color-text-secondary);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-pill);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1;transition:background .2s ease,border-color .2s ease,color .2s ease}.chat-sidebar-collapse-btn:hover,.chat-sidebar-collapse-btn:focus-visible{background:var(--ds-color-surface-highlight);border-color:var(--ds-color-border-strong);color:var(--ds-color-text-primary);outline:none}.chat-sidebar-show-btn{display:none;align-self:flex-start;position:sticky;top:var(--chat-sidebar-offset);background:var(--ds-color-surface-1);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-lg);color:var(--ds-color-text-secondary);padding:10px 14px;cursor:pointer;align-items:center;justify-content:center;box-shadow:var(--ds-shadow-md);z-index:10;transition:background .2s ease,border-color .2s ease,color .2s ease}.chat-sidebar-show-btn.is-visible{display:inline-flex}.chat-sidebar-show-btn:hover,.chat-sidebar-show-btn:focus-visible{background:var(--ds-color-surface-highlight);border-color:var(--ds-color-border-strong);color:var(--ds-color-text-primary);outline:none}.chat-tree{flex:1 0 auto;display:flex;flex-direction:column;gap:12px;padding-right:4px}.chat-thread{display:flex;flex-direction:column;border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-lg);background:rgba(15,23,42,.45);overflow:hidden;transition:border-color .2s ease,background .2s ease}.chat-thread.is-active{border-color:#7c5cff73;background:rgba(124,92,255,.1)}.chat-thread-toggle{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;color:var(--ds-color-text-secondary);font-size:13px;font-weight:600;cursor:pointer;text-align:left;transition:background .2s ease,color .2s ease}.chat-thread-toggle:hover,.chat-thread-toggle:focus-visible{background:rgba(124,92,255,.12);color:var(--ds-color-text-primary);outline:none}.chat-thread-toggle.is-expanded{border-bottom:1px solid rgba(148,163,184,.18)}.chat-thread-caret{display:inline-flex;align-items:center;justify-content:center;width:16px;font-size:14px;line-height:1;transform-origin:center;transition:transform .2s ease}.chat-thread-toggle.is-expanded .chat-thread-caret{transform:rotate(90deg)}.chat-thread-title{flex:1;min-width:0;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-thread-meta{font-size:11px;color:#e2e8f0a6;white-space:nowrap}.chat-thread-delete{display:flex;align-items:center;justify-content:center;width:20px;height:20px;margin-left:8px;padding:0;background:transparent;border:none;border-radius:4px;color:#e2e8f080;font-size:18px;line-height:1;cursor:pointer;flex-shrink:0;transition:all .15s ease;opacity:0}.chat-thread-toggle:hover .chat-thread-delete,.chat-thread-toggle:focus-within .chat-thread-delete{opacity:1}.chat-thread-delete:hover{background:rgba(239,68,68,.15);color:#f87171f2;transform:scale(1.1)}.chat-thread-delete:active{transform:scale(.95)}.chat-thread-body{display:flex;flex-direction:column;gap:6px;padding:10px 12px 14px;background:rgba(15,23,42,.35)}.chat-thread-body[hidden]{display:none}.chat-thread-empty{font-size:12px;color:#e2e8f0b3;padding:6px 8px}.chat-tree-empty{font-size:12px;color:#e2e8f0b3}.chat-tree-item{--indent-level: 0;display:flex;align-items:flex-start;gap:10px;width:100%;border:1px solid transparent;background:transparent;color:var(--ds-color-text-secondary);font-size:13px;text-align:left;padding:10px 12px;padding-left:calc(16px + (var(--indent-level) * 16px));border-radius:12px;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}.chat-tree-item:hover{background:var(--ds-color-surface-highlight);color:var(--ds-color-text-primary)}.chat-tree-item:focus-visible{outline:2px solid var(--ds-color-accent);outline-offset:2px}.chat-tree-item.is-active{background:rgba(124,92,255,.12);border-color:#7c5cff52;color:var(--ds-color-text-primary)}.chat-tree-item.is-focused{border-color:#7c5cff99;background:rgba(124,92,255,.18);color:var(--ds-color-accent-contrast)}.chat-tree-item.is-thread{color:var(--ds-color-text-primary);font-weight:600}.chat-tree-item-icon{flex-shrink:0;font-size:14px;line-height:1.2;margin-top:2px}.chat-tree-item-body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.chat-tree-item-title{font-size:13px;font-weight:500;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-tree-item-meta{font-size:11px;color:#e2e8f099;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-config-btn,.chat-config-toolbar-btn{background:transparent;color:var(--ds-color-text-secondary);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-pill);width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--ds-font-size-sm);transition:background .2s ease,border-color .2s ease}.chat-config-toolbar-btn{margin-left:12px}.chat-config-btn:hover,.chat-config-toolbar-btn:hover{background:var(--ds-color-surface-highlight);border-color:var(--ds-color-border-strong)}.chat-new-btn{background:var(--ds-color-surface-2);color:var(--ds-color-text-primary);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-pill);padding:10px 18px;font-size:var(--ds-font-size-sm);font-weight:600;cursor:pointer;box-shadow:none;transition:background-color .2s ease,border-color .2s ease;flex-shrink:0}.chat-new-btn:hover{background:var(--ds-color-surface-3);border-color:var(--ds-color-border-strong)}.chat-model-stack-btn{background:rgba(124,92,255,.14);color:var(--ds-color-accent-muted);border:1px solid rgba(124,92,255,.38);border-radius:var(--ds-radius-pill);padding:10px 18px;font-size:var(--ds-font-size-sm);font-weight:600;cursor:pointer;transition:background-color .2s ease,border-color .2s ease;margin-left:10px}.chat-model-stack-btn:hover{background:rgba(124,92,255,.24);border-color:#7c5cff99}.chat-canvas-mode-btn{background:rgba(14,165,233,.14);color:#bae6fde6;border:1px solid rgba(14,165,233,.45);border-radius:var(--ds-radius-pill);padding:10px 18px;font-size:var(--ds-font-size-sm);font-weight:600;cursor:pointer;transition:background-color .2s ease,border-color .2s ease;margin-left:10px}.chat-canvas-mode-btn:hover{background:rgba(14,165,233,.28);border-color:#0ea5e9ad}.chat-model-info{display:flex;flex-direction:column;gap:8px;align-items:flex-start;justify-content:flex-start}.chat-model-pill{background:rgba(148,163,184,.16);color:#e2e8f0;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:500;border:1px solid rgba(148,163,184,.25)}.chat-model-toggle-list{display:flex;flex-direction:column;gap:10px;background:rgba(15,23,42,.55);border:1px solid rgba(148,163,184,.18);border-radius:12px;padding:12px;overflow-y:auto;flex:1;min-height:0;max-height:320px}.chat-model-toggle-empty{font-size:12px;color:#e2e8f0b3}.chat-model-toggle{display:flex;align-items:center;justify-content:flex-start;gap:8px;font-size:12px;color:#e2e8f0;background:rgba(148,163,184,.12);border:1px solid rgba(148,163,184,.22);border-radius:10px;padding:8px 10px}.chat-model-toggle input{accent-color:#ffffff;flex-shrink:0}.chat-model-order{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:rgba(148,163,184,.25);color:#f8fafc;font-weight:600;font-size:11px;flex-shrink:0}@media (max-width: 960px){.chat-content{flex-direction:column;align-items:stretch}.chat-sidebar{width:100%;position:static;max-height:none;height:auto;order:-1}.chat-sidebar-show-btn{position:static;width:100%;justify-content:center}.chat-model-toggle-list{max-height:220px}}.branch-label{font-size:12px;color:#cbd5f5;text-transform:uppercase;letter-spacing:.08em}.branch-nav-btn{background:rgba(255,255,255,.06);border:none;color:#f3f4f6;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:background .2s ease}.branch-nav-btn:hover{background:rgba(255,255,255,.16)}.branch-nav-btn:disabled{opacity:.35;cursor:default}.chat-header{display:flex;flex-direction:column;gap:4px}.chat-title{font-size:20px;font-weight:600}.chat-subtitle{font-size:13px;color:#9ca3af}.chat-messages{flex:1;background:#1c1c1c;border:1px solid #333333;border-radius:20px;padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:14px;box-shadow:none}.chat-message{max-width:78%;padding:16px 22px;border-radius:20px;line-height:1.65;font-size:16px;word-break:break-word;box-shadow:0 6px 18px #0f172a40;display:flex;flex-direction:column;gap:8px;position:relative}.chat-message-streaming{opacity:.92}.chat-message-streaming:after{content:"streaming";position:absolute;top:10px;right:18px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#94a3b899;animation:chat-stream-pulse 1.4s ease-in-out infinite}.chat-message-error{border:1px solid rgba(248,113,113,.45);box-shadow:0 6px 20px #b91c1c59}.chat-message-text{white-space:normal}.chat-message-text p{margin:0}.chat-message-text p+p,.chat-message-text ul,.chat-message-text ol{margin-top:8px}.chat-message-text ul,.chat-message-text ol{padding-left:20px}.chat-message-text ul{list-style:disc}.chat-message-text ol{list-style:decimal}.chat-message-text li{margin-bottom:4px}.chat-message-text code{background:rgba(148,163,184,.15);color:#f8fafc;padding:2px 6px;border-radius:4px;font-family:Source Code Pro,Fira Code,monospace;font-size:14px}.chat-message-text pre{background:rgba(15,23,42,.85);color:#e2e8f0;padding:12px 14px;border-radius:12px;overflow-x:auto;font-family:Source Code Pro,Fira Code,monospace;font-size:14px;line-height:1.6}.chat-message-actions{display:flex;gap:8px;margin-top:4px;flex-wrap:wrap;align-items:center}.chat-message.user .chat-message-actions{justify-content:flex-end}.chat-message.assistant .chat-message-actions{justify-content:flex-start}.chat-message-action-btn{background:transparent;border:1px solid rgba(148,163,184,.35);color:#cbd5f5;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s ease,color .2s ease,border-color .2s ease}.chat-message-action-btn:hover{background:rgba(148,163,184,.18);color:#fff;border-color:#94a3b88c}.chat-message-action-btn.branch-nav-inline{padding:4px 10px;min-width:32px;display:flex;align-items:center;justify-content:center}.chat-message-nav-label{font-size:11px;color:#cbd5f5;text-transform:uppercase;letter-spacing:.08em;padding:0 4px;white-space:nowrap}.chat-message.editing{border-color:#94a3b873}.chat-message-editor{display:flex;flex-direction:column;gap:10px}.chat-message-editor-input{width:100%;min-height:96px;max-height:240px;padding:12px 14px;border-radius:12px;border:1px solid #555555;background:rgba(17,24,39,.95);color:#f8fafc;font-size:15px;line-height:1.6;resize:none;overflow-y:auto;outline:none}.chat-message-editor-input:focus{border-color:#737373}.chat-message-editor-actions{display:flex;justify-content:flex-end;gap:10px}.chat-message-editor-save,.chat-message-editor-cancel{padding:6px 16px;border-radius:999px;border:1px solid transparent;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s ease,color .2s ease,border-color .2s ease}.chat-message-editor-save{background:#38bdf8;border-color:#38bdf8;color:#032334}.chat-message-editor-save:hover{background:#0ea5e9;border-color:#0ea5e9;color:#02121c}.chat-message-editor-cancel{background:transparent;border-color:#94a3b859;color:#cbd5f5}.chat-message-editor-cancel:hover{background:rgba(148,163,184,.18);border-color:#94a3b88c;color:#fff}.chat-message-model{font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px;opacity:.7}.chat-message.user{align-self:flex-end;background:#333333;color:#fff;border-bottom-right-radius:4px}.chat-message.assistant{align-self:flex-start;background:#222222;color:#e0e0e0;border-bottom-left-radius:4px;border:1px solid #444444}.chat-message.typing-indicator{opacity:.75;font-style:italic;background:rgba(226,232,240,.5);color:#1e293b}.chat-message.system{align-self:center;background:transparent;color:#cbd5f5;font-style:normal;font-size:12px;letter-spacing:.08em;text-transform:uppercase;box-shadow:none}@keyframes chat-stream-pulse{0%,to{opacity:.35}50%{opacity:1}}.chat-input-area{display:flex;flex-direction:column;gap:8px}.chat-input{width:100%;resize:none;min-height:64px;max-height:220px;padding:16px 18px;border-radius:16px;border:1px solid #444444;background:#222222;color:#f8fafc;font-size:16px;line-height:1.6;outline:none;transition:border-color .2s ease;overflow-y:auto}.chat-input::placeholder{color:#e2e8f08c}.chat-input:focus{border-color:#555;box-shadow:none}.chat-actions{display:flex;justify-content:flex-end;gap:8px}.chat-primary-btn{padding:12px 26px;border-radius:999px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s ease;background:#ffffff;color:#000;box-shadow:none}.chat-primary-btn:hover{background:#dddddd}body.chat-mode #canvas,body.chat-mode .canvas-controls,body.chat-mode .navigation-help,body.chat-mode #selectionStatus,body.chat-mode #generateIdeasTooltip,body.chat-mode #aspectRatioSelector,body.chat-mode .model-selector-panel{display:none!important}body.chat-mode .chat-view{display:flex}.toolbar-btn{background:#0d7377;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.toolbar-btn:hover{background:#14a085}.toolbar-btn:active{transform:translateY(1px)}.toolbar-btn:disabled{background:#555555;cursor:not-allowed;opacity:.7}.canvas-controls{position:fixed;bottom:20px;right:20px;background:#333333;border:1px solid #505050;border-radius:8px;box-shadow:0 4px 12px #0006;padding:8px;display:flex;flex-direction:column;gap:4px;z-index:1000}.control-btn{background:#444444;color:#e0e0e0;border:1px solid #666666;border-radius:4px;width:36px;height:36px;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0}.control-icon{width:20px;height:20px;filter:brightness(0) saturate(100%) invert(88%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(88%) contrast(88%);transition:filter .2s ease}.control-btn:hover{background:#555555;border-color:#777}.control-btn:hover .control-icon{filter:brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%)}.control-btn:active{transform:translateY(1px)}.control-separator{height:1px;background-color:#666;margin:4px 0}.control-btn:disabled{background-color:#2a2a2a;color:#666;cursor:not-allowed;opacity:.6}.control-btn:disabled .control-icon{filter:brightness(0) saturate(100%) invert(40%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(40%) contrast(40%)}.control-btn:disabled:hover{background-color:#2a2a2a;border-color:#444}.control-btn:disabled:hover .control-icon{filter:brightness(0) saturate(100%) invert(40%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(40%) contrast(40%)}.node-input{position:absolute;border:2px solid #0d7377;border-radius:4px;padding:8px;font-family:inherit;background:#2a2a2a;color:#e0e0e0;outline:none;z-index:2000}.generate-ideas-tooltip{position:absolute;z-index:2000;pointer-events:none;transition:opacity .2s ease;display:flex;gap:8px}.generate-ideas-tooltip.hidden{display:none}.generate-ideas-btn,.expand-content-btn{background:#0d7377;color:#fff;border:none;border-radius:6px;padding:8px 12px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #0006;pointer-events:auto;position:relative;min-width:40px;height:40px;display:flex;align-items:center;justify-content:center}.expand-content-btn{background:#6c5ce7}.generate-ideas-btn:hover{background:#14a085;transform:translateY(-2px);box-shadow:0 6px 16px #00000080}.expand-content-btn:hover{background:#a29bfe;transform:translateY(-2px);box-shadow:0 6px 16px #00000080}.generate-ideas-btn:active,.expand-content-btn:active{transform:translateY(0)}.generate-ideas-btn:disabled{background:#555555;cursor:not-allowed;opacity:.7}.generate-ideas-btn:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #0d7377}.generate-ideas-btn:hover:after{border-top-color:#14a085}.content-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:3000;display:flex;align-items:center;justify-content:center}.content-modal.hidden{display:none}.chat-model-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:3500}.chat-model-modal.hidden{display:none}.chat-model-modal-container{position:relative;background:#1f1f1f;border-radius:16px;border:1px solid #333333;width:min(520px,92vw);max-height:80vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #000000a6;overflow:hidden}.chat-model-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #333333;background:#262626}.chat-model-modal-header h3{margin:0;font-size:18px;font-weight:600;color:#fff}.chat-model-modal-actions{display:flex;align-items:center;gap:10px}.chat-model-modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:16px;overflow:hidden}.chat-model-modal-body .chat-model-toggle-list{max-height:320px}.chat-model-modal-body .chat-model-info{border-top:1px solid rgba(148,163,184,.18);padding-top:12px}.model-prompt-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:4000}.model-prompt-modal.hidden{display:none}.model-prompt-modal .modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.75);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:0}.model-prompt-modal-container{position:relative;background:#1f1f1f;border-radius:16px;box-shadow:0 28px 80px #000000bf;width:min(540px,92vw);max-height:90vh;display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(148,163,184,.2);z-index:1}.model-prompt-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(148,163,184,.18);background:linear-gradient(135deg,rgba(30,64,175,.45),rgba(23,37,84,.45))}.model-prompt-modal-header h3{margin:0;font-size:18px;font-weight:600;color:#f8fafc}.model-prompt-modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;background:#1a1a1a}.model-prompt-description{margin:0;font-size:13px;line-height:1.5;color:#e2e8f0d1}.model-prompt-preview{display:flex;flex-direction:column;gap:6px}.model-prompt-preview-box{background:rgba(30,41,59,.55);border:1px solid rgba(148,163,184,.25);border-radius:10px;padding:12px;font-size:12px;color:#e2e8f0;line-height:1.5;white-space:pre-wrap;word-break:break-word;max-height:160px;overflow-y:auto}.model-prompt-preview-box.is-empty{color:#e2e8f099;font-style:italic}.model-prompt-modal-footer{display:flex;align-items:center;gap:12px;padding:16px 24px;border-top:1px solid rgba(148,163,184,.18);background:#1f2937}.model-prompt-footer-spacer{flex:1}.model-prompt-modal-footer .ds-btn{min-width:100px}.modal-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container{position:relative;background:#2a2a2a;border-radius:12px;box-shadow:0 20px 60px #000c;max-width:80vw;max-height:80vh;width:800px;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:0 0 var(--ds-space-16) 0;border-bottom:1px solid var(--ds-color-border-subtle);gap:var(--ds-space-16)}.modal-header-buttons{display:flex;gap:8px;align-items:center}.modal-header h3{margin:0;color:var(--ds-color-text-primary);font-size:var(--ds-font-size-lg);font-weight:600}.edit-modal-btn{background:#0d7377;border:none;color:#fff;font-size:16px;cursor:pointer;padding:6px 10px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.edit-modal-btn:hover{background:#14a085;transform:translateY(-1px)}.edit-modal-btn:active{transform:translateY(0)}.modal-header-content{display:flex;flex-direction:column;gap:var(--ds-space-8)}.close-modal-btn{font-size:22px;line-height:1;padding:0}.modal-body{flex:1;overflow:auto;padding:24px}.modal-content-text{color:#fff;font-size:16px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.modal-content-text h1,.modal-content-text h2,.modal-content-text h3{color:#fff;margin:0 0 16px;font-weight:700}.modal-content-text h1{font-size:24px}.modal-content-text h2{font-size:20px}.modal-content-text h3{font-size:18px}.modal-content-text p{margin:0 0 12px;color:#fff}.modal-content-text ul{margin:0 0 12px;padding-left:20px}.modal-content-text li{margin:4px 0;color:#fff}.modal-content-text strong{font-weight:700;color:#fff}.modal-content-text em{font-style:italic;color:#fff}.modal-content-text code{background:#444;color:gold;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:14px}.modal-edit-textarea{width:100%;min-height:200px;max-height:400px;background:#1a1a1a;color:#fff;border:2px solid #0d7377;border-radius:6px;padding:16px;font-family:inherit;font-size:16px;line-height:1.6;resize:vertical;outline:none;transition:border-color .2s ease}.modal-edit-textarea:focus{border-color:#14a085;box-shadow:0 0 0 3px #0d73771a}.modal-edit-controls{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:16px;border-top:1px solid #444}.modal-save-btn,.modal-cancel-btn{background:#0d7377;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.modal-cancel-btn{background:#666}.modal-save-btn:hover{background:#14a085}.modal-cancel-btn:hover{background:#777}.modal-save-btn:active,.modal-cancel-btn:active{transform:translateY(1px)}.selection-status{position:fixed;top:20px;right:20px;background:rgba(0,0,0,.8);color:#fff;padding:8px 12px;border-radius:6px;font-size:14px;font-weight:500;z-index:1500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:all .2s ease}.selection-status.hidden{display:none}.selection-hint{display:block;margin-top:4px;font-size:12px;color:#9ca3af;font-weight:400}.navigation-help{position:fixed;bottom:20px;left:20px;background:rgba(0,0,0,.8);color:#fff;padding:12px 16px;border-radius:8px;font-size:12px;z-index:1500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:opacity .3s ease}.help-item{margin:4px 0;display:flex;align-items:center;gap:8px}.navigation-help:hover{opacity:.7}.hidden{display:none}.no-select{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.api-key-modal{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;background:var(--ds-color-overlay);display:none;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:4500}.modal-content{background:var(--ds-color-surface-1);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-xl);padding:var(--ds-space-24);max-width:560px;width:min(90vw,560px);max-height:80vh;overflow-y:auto;box-shadow:var(--ds-shadow-md);display:flex;flex-direction:column;gap:var(--ds-space-20)}.modal-content h3{color:var(--ds-color-text-primary);margin-bottom:var(--ds-space-12);font-size:var(--ds-font-size-lg);font-weight:600}.modal-content p{color:var(--ds-color-text-muted);margin-bottom:var(--ds-space-16);font-size:var(--ds-font-size-sm);line-height:var(--ds-line-height-loose)}.modal-content label{color:var(--ds-color-text-secondary);font-size:var(--ds-font-size-sm);font-weight:600;margin-bottom:var(--ds-space-6);margin-top:var(--ds-space-12);display:block}.modal-content label:first-of-type{margin-top:0}.modal-content input{width:100%;padding:var(--ds-space-8) var(--ds-space-12);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-md);background:var(--ds-color-surface-2);color:var(--ds-color-text-primary);font-size:var(--ds-font-size-md);margin-bottom:var(--ds-space-12);outline:none;transition:border-color .2s ease,box-shadow .2s ease}.modal-content input:focus{border-color:var(--ds-color-accent);box-shadow:0 0 0 3px #7c5cff59}.modal-buttons{display:flex;gap:var(--ds-space-12);margin-bottom:var(--ds-space-12)}.modal-buttons button{flex:1;padding:var(--ds-space-8) var(--ds-space-16);border:1px solid transparent;border-radius:var(--ds-radius-pill);font-size:var(--ds-font-size-sm);font-weight:600;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease}.modal-buttons button:first-child{background:linear-gradient(135deg,var(--ds-color-accent),var(--ds-color-accent-muted));color:var(--ds-color-accent-contrast);box-shadow:var(--ds-shadow-sm)}.modal-buttons button:first-child:hover{box-shadow:var(--ds-shadow-md)}.modal-buttons button:last-child{background:transparent;color:var(--ds-color-text-secondary);border-color:var(--ds-color-border-subtle)}.modal-buttons button:last-child:hover{background:var(--ds-color-surface-highlight)}.modal-content small{color:var(--ds-color-text-muted);font-size:var(--ds-font-size-xs)}.mode-toggle-container{margin-bottom:var(--ds-space-20)}.mode-toggle-options{display:flex;flex-direction:column;gap:var(--ds-space-12)}.mode-toggle-option{background:rgba(15,23,42,.45);border:2px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-lg);padding:var(--ds-space-16);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.mode-toggle-option:hover{background:rgba(15,23,42,.65);border-color:var(--ds-color-border-strong);transform:translateY(-1px)}.mode-toggle-option.active{background:rgba(124,92,255,.12);border-color:#7c5cff99;box-shadow:0 4px 12px #7c5cff33}.mode-toggle-option.active:hover{background:rgba(124,92,255,.18);border-color:#7c5cffcc}.mode-toggle-option-content{display:flex;flex-direction:column;gap:var(--ds-space-8)}.mode-toggle-option-header{display:flex;align-items:center;gap:var(--ds-space-10)}.mode-toggle-icon{font-size:20px;line-height:1}.mode-toggle-title{font-size:var(--ds-font-size-md);font-weight:600;color:var(--ds-color-text-primary);flex:1}.mode-toggle-badge{font-size:var(--ds-font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:var(--ds-radius-pill);background:rgba(56,189,248,.15);color:#bae6fde6;border:1px solid rgba(56,189,248,.35)}.mode-toggle-option.active .mode-toggle-badge{background:rgba(124,92,255,.25);color:var(--ds-color-accent-muted);border-color:#7c5cff80}.mode-toggle-description{font-size:var(--ds-font-size-sm);color:var(--ds-color-text-muted);margin:0;line-height:var(--ds-line-height-loose)}.request-limit-info{font-size:var(--ds-font-size-sm);color:var(--ds-color-text-secondary);margin-top:var(--ds-space-6);padding:var(--ds-space-8);background:rgba(56,189,248,.08);border-radius:var(--ds-radius-md);border:1px solid rgba(56,189,248,.25)}.automanaged-model-summary{margin-top:var(--ds-space-6);padding:var(--ds-space-8);background:rgba(124,92,255,.08);border-radius:var(--ds-radius-md);border:1px solid rgba(124,92,255,.25);font-family:SFMono-Regular,Menlo,Consolas,monospace;font-size:var(--ds-font-size-sm);color:var(--ds-color-text-secondary);white-space:pre-wrap;line-height:var(--ds-line-height-relaxed)}.demo-mode-section{background:rgba(56,189,248,.06);border:1px solid rgba(56,189,248,.25);border-radius:var(--ds-radius-lg);padding:var(--ds-space-16);margin-bottom:var(--ds-space-20)}.demo-toggle{display:flex;align-items:center;cursor:pointer;margin-bottom:8px}.demo-toggle input[type=checkbox]{margin-right:10px;transform:scale(1.2)}.demo-toggle-text{color:var(--ds-color-text-primary);font-weight:600;font-size:var(--ds-font-size-sm)}.demo-description{color:var(--ds-color-text-muted);font-size:var(--ds-font-size-sm);margin:0;line-height:var(--ds-line-height-loose)}#apiConfigSection{transition:opacity .3s ease}#apiConfigSection[style*=none]{opacity:0}.notification{position:fixed;top:20px;right:20px;padding:12px 16px;border-radius:6px;font-size:14px;font-weight:500;z-index:10000;max-width:300px;box-shadow:0 4px 12px #0006;animation:slideIn .3s ease-out}.notification-success{background:#0d7377;color:#fff}.notification-error{background:#dc3545;color:#fff}.notification-warning{background:#ffc107;color:#000}.notification-info{background:#17a2b8;color:#fff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.model-selector-panel{position:fixed;top:20px;left:20px;width:300px;background:#333333;border:1px solid #505050;border-radius:8px;box-shadow:0 4px 12px #0006;z-index:1000;color:#e0e0e0;transition:all .3s ease;animation:slideInLeft .4s ease-out}.model-selector-panel.dragging{box-shadow:0 8px 24px #0009;transform:scale(1.02);z-index:1001}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.model-selector-panel .panel-header{padding:12px 16px;display:flex;justify-content:space-between;align-items:center;background:#404040;border-top-left-radius:8px;border-top-right-radius:8px;border-bottom:1px solid #505050;-webkit-user-select:none;user-select:none;position:relative;cursor:pointer}.drag-handle{position:absolute;left:8px;top:50%;transform:translateY(-50%);cursor:grab;padding:4px;border-radius:3px;transition:all .2s ease;opacity:.6}.drag-handle:hover{background:rgba(255,255,255,.1);opacity:1}.drag-handle:active{cursor:grabbing;background:rgba(255,255,255,.2)}.drag-icon{font-size:14px;color:#e0e0e0;font-weight:700;line-height:1;letter-spacing:-2px}.model-selector-panel .header-controls{display:flex;align-items:center;gap:10px}.model-selector-panel .active-count{font-size:11px;color:#4ade80;font-weight:500;background:rgba(74,222,128,.1);padding:2px 6px;border-radius:10px;border:1px solid rgba(74,222,128,.3)}.model-selector-panel .panel-header:hover{background:#454545}.model-selector-panel .panel-header h5{margin:0 0 0 32px;font-size:14px;font-weight:600;color:#fff;display:flex;align-items:center;gap:8px;flex:1}.model-selector-panel .toggle-btn{background:none;border:none;color:#e0e0e0;font-size:12px;cursor:pointer;padding:2px 6px;border-radius:3px;transition:all .2s ease}.model-selector-panel .toggle-btn:hover{background:#555555;color:#fff}.model-selector-panel .panel-content{padding:12px;max-height:220px;overflow-y:auto;transition:all .3s ease}.model-selector-panel .panel-content.collapsed{max-height:0;padding:0 12px;overflow:hidden}.model-selector-panel .panel-footer{padding:12px;border-top:1px solid #505050;background:#3a3a3a;border-bottom-left-radius:8px;border-bottom-right-radius:8px;display:flex;justify-content:center}.model-selector-panel .manage-btn{padding:6px 12px;background:#0d7377;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.model-selector-panel .manage-btn:hover{background:#0a5d61;transform:translateY(-1px)}.section-header{display:flex;align-items:center;gap:8px;padding:8px 0;margin:8px 0 6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #505050}.section-header.active-section{color:#4ade80}.section-header.inactive-section{color:#9ca3af}.section-header .section-icon{font-size:14px}.model-checkbox-item{display:flex;align-items:center;margin-bottom:8px;padding:8px 10px;border-radius:6px;transition:all .2s ease;border:1px solid transparent}.model-checkbox-item.active{background:rgba(74,222,128,.1);border-color:#4ade804d}.model-checkbox-item.inactive{background:rgba(156,163,175,.05);border-color:#9ca3af33}.model-checkbox-item:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0003}.model-checkbox-item.active:hover{background:rgba(74,222,128,.15);border-color:#4ade8066}.model-checkbox-item.inactive:hover{background:rgba(156,163,175,.1);border-color:#9ca3af4d}.model-checkbox-item:last-child{margin-bottom:6px}.model-checkbox-item input[type=checkbox]{margin:0 10px 0 0;transform:scale(1.1);cursor:pointer}.model-checkbox-item label{cursor:pointer;flex:1;font-size:13px;color:#e0e0e0;display:flex;align-items:center;gap:8px;line-height:1.3}.model-checkbox-item.has-custom-prompt{background:rgba(59,130,246,.16);border-color:#60a5fa73}.model-prompt-badge,.chat-model-prompt-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:rgba(59,130,246,.22);color:#bfdbfe;border-radius:999px;padding:2px 8px;line-height:1.2;white-space:nowrap}.model-config-btn,.chat-model-config-btn{background:rgba(148,163,184,.18);border:1px solid rgba(148,163,184,.35);color:#e2e8f0;border-radius:8px;padding:6px 10px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1}.model-config-btn:hover,.chat-model-config-btn:hover{background:rgba(148,163,184,.3);border-color:#94a3b880;transform:translateY(-1px)}.model-config-btn.has-custom-prompt,.chat-model-config-btn.has-custom-prompt{background:rgba(96,165,250,.25);border-color:#60a5fa99;color:#dbeafe}.model-config-btn.has-custom-prompt:hover,.chat-model-config-btn.has-custom-prompt:hover{background:rgba(96,165,250,.35);border-color:#60a5fad9}.chat-model-toggle-row{display:flex;align-items:stretch;gap:8px}.chat-model-toggle-row .chat-model-toggle{flex:1}.chat-model-toggle-row.has-custom-prompt .chat-model-toggle{border-color:#60a5fa8c;background:rgba(59,130,246,.18)}.chat-model-config-btn{min-width:44px;height:auto;align-self:center}.model-name{font-weight:500;color:#fff}.model-tag{font-size:10px;padding:2px 6px;border-radius:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.model-tag.thinking{background:#ffc107;color:#000}.model-tag.free{background:#28a745;color:#fff}.model-panel-actions{margin-top:12px;padding-top:12px;border-top:1px solid #505050;display:flex;gap:8px}.model-panel-btn{flex:1;padding:8px 12px;border:none;border-radius:5px;cursor:pointer;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease}.model-panel-btn.primary{background:#4ade80;color:#000}.model-panel-btn.primary:hover{background:#22c55e;transform:translateY(-1px);box-shadow:0 2px 8px #4ade804d}.model-panel-btn.secondary{background:#6b7280;color:#fff}.model-panel-btn.secondary:hover{background:#4b5563;transform:translateY(-1px);box-shadow:0 2px 8px #6b72804d}@media (max-width: 768px){.model-selector-panel{width:280px;left:10px;top:10px}.model-selector-panel .panel-content{max-height:180px}}.modal-section{margin-bottom:var(--ds-space-20);padding:var(--ds-space-16);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-lg);background:var(--ds-color-surface-2);display:flex;flex-direction:column;gap:var(--ds-space-12)}.modal-section h4{margin:0;color:var(--ds-color-text-primary);font-size:var(--ds-font-size-md);font-weight:600}.config-subsection{margin-top:var(--ds-space-20);padding:var(--ds-space-16);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-md);background:var(--ds-color-surface-1);display:flex;flex-direction:column;gap:var(--ds-space-12)}.config-section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--ds-space-12);margin-bottom:var(--ds-space-8)}.config-subsection h5{margin:0;color:var(--ds-color-text-secondary);font-size:var(--ds-font-size-sm);font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding-bottom:var(--ds-space-6);border-bottom:2px solid rgba(124,92,255,.32);display:inline-flex}.readonly-badge{display:inline-flex;align-items:center;gap:var(--ds-space-6);padding:var(--ds-space-4) var(--ds-space-10);background:rgba(56,189,248,.12);border:1px solid rgba(56,189,248,.35);border-radius:var(--ds-radius-pill);font-size:var(--ds-font-size-xs);font-weight:600;color:#bae6fde6;text-transform:uppercase;letter-spacing:.05em}.readonly-badge-icon{font-size:14px;line-height:1}.readonly-badge-text{line-height:1}.modal-section:first-of-type{border-left:4px solid rgba(124,92,255,.55);background:linear-gradient(135deg,rgba(18,24,37,.88) 0%,rgba(28,36,58,.88) 100%)}.modal-section:nth-of-type(2){border-left:4px solid rgba(56,189,248,.45);background:linear-gradient(135deg,rgba(18,28,40,.88) 0%,rgba(17,32,42,.88) 100%)}.modal-action-buttons{display:flex;gap:var(--ds-space-12);flex-wrap:wrap}.modal-action-btn{flex:1;justify-content:center;transition:transform .1s ease}.modal-action-btn:hover{transform:translateY(-1px)}.provider-config-grid{display:grid;gap:var(--ds-space-16);grid-template-columns:1fr;max-width:400px}.provider-config-card{background:var(--ds-color-surface-1);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-md);padding:var(--ds-space-16);display:flex;flex-direction:column;gap:var(--ds-space-8)}.provider-config-card h6{margin:0;font-size:var(--ds-font-size-sm);font-weight:600;color:var(--ds-color-text-secondary)}.modal-small-print{color:var(--ds-color-text-muted);font-size:var(--ds-font-size-xs);line-height:var(--ds-line-height-loose);display:block}.modal-empty-state{color:var(--ds-color-text-muted);font-size:var(--ds-font-size-sm);font-style:italic;margin:0}.modal-model-row{margin-bottom:var(--ds-space-8);display:flex;align-items:center;gap:var(--ds-space-8)}.modal-model-reorder{display:flex;flex-direction:column;gap:var(--ds-space-4)}.modal-model-order-btn{width:28px;height:24px;font-size:var(--ds-font-size-xs);line-height:1;background:var(--ds-color-surface-2);color:var(--ds-color-text-secondary);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-sm);cursor:pointer;padding:0;transition:background .2s ease,color .2s ease}.modal-model-order-btn:disabled{opacity:.35;cursor:default}.modal-model-order-btn:not(:disabled):hover{background:var(--ds-color-surface-highlight);color:var(--ds-color-text-primary)}.modal-model-checkbox{margin:0}.modal-model-label{color:var(--ds-color-text-primary);cursor:pointer;flex:1;font-size:var(--ds-font-size-sm)}.modal-model-actions{margin-top:var(--ds-space-12);display:flex;gap:var(--ds-space-8);flex-wrap:wrap}.modal-model-action-btn{padding:var(--ds-space-4) var(--ds-space-12);background:transparent;color:var(--ds-color-text-secondary);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-pill);cursor:pointer;font-size:var(--ds-font-size-xs);transition:background .2s ease,border-color .2s ease}.modal-model-action-btn:hover{background:var(--ds-color-surface-highlight);border-color:var(--ds-color-border-strong)}.modal-action-btn:active{transform:translateY(0)}.generate-ideas-btn:hover:after{opacity:1}.aspect-ratio-selector{position:absolute;z-index:2001;background:#333333;border:1px solid #555555;border-radius:8px;padding:8px;box-shadow:0 4px 12px #0006;min-width:120px;transition:opacity .2s ease}.aspect-ratio-selector:before{content:"";position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;z-index:-1}.aspect-ratio-selector.hidden{display:none}.aspect-ratio-header{font-size:12px;font-weight:600;color:#bbb;margin-bottom:6px;text-align:center}.aspect-ratio-options{display:flex;gap:4px}.aspect-ratio-option{background:#444444;color:#e0e0e0;border:1px solid #666666;border-radius:4px;padding:6px 10px;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;flex:1;text-align:center}.aspect-ratio-option:hover{background:#555555;border-color:#777}.aspect-ratio-option.active{background:#0d7377;border-color:#0d7377;color:#fff}.aspect-ratio-option.active:hover{background:#14a085;border-color:#14a085}.auth-header-container{position:fixed;top:20px;right:28px;display:flex;align-items:center;gap:12px;z-index:9999}.auth-sign-in-btn{padding:8px 20px;background:linear-gradient(135deg,rgba(13,117,119,.15),rgba(20,160,133,.15));border:1px solid rgba(13,117,119,.4);border-radius:8px;color:#14a085;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.auth-sign-in-btn:hover{background:linear-gradient(135deg,rgba(13,117,119,.25),rgba(20,160,133,.25));border-color:#14a08599;transform:translateY(-1px);box-shadow:0 4px 12px #0d757733}.auth-user-menu{position:relative}.auth-user-btn{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:24px;color:#e0e0e0;font-size:14px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #00000026}.auth-user-btn:hover{background:rgba(255,255,255,.12);border-color:#ffffff40;box-shadow:0 4px 12px #0003}.auth-user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#0d7377,#14a085);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}.auth-user-name{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.auth-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:rgba(18,24,37,.98);border:1px solid rgba(255,255,255,.15);border-radius:12px;box-shadow:0 8px 32px #00000080;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden;z-index:10000}.auth-dropdown-user-info{padding:16px;background:rgba(255,255,255,.03)}.auth-dropdown-name{font-size:15px;font-weight:600;color:#e0e0e0;margin-bottom:4px}.auth-dropdown-email{font-size:13px;color:#999;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-dropdown-divider{height:1px;background:rgba(255,255,255,.1);margin:0}.auth-dropdown-item{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;background:transparent;border:none;color:#e0e0e0;font-size:14px;font-weight:500;text-align:center;cursor:pointer;transition:all .2s ease}.auth-dropdown-item:hover{background:rgba(239,68,68,.1);color:#ef4444}.auth-dropdown-item span{display:flex;align-items:center;gap:6px}.auth-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100000;align-items:center;justify-content:center}.auth-modal.active{display:flex}.auth-modal-content{position:relative;width:90%;max-width:440px;background:rgba(18,24,37,.98);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:32px;box-shadow:0 20px 60px #00000080;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.auth-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;background:transparent;border:none;color:#999;font-size:28px;line-height:1;cursor:pointer;transition:color .2s ease}.auth-modal-close:hover{color:#e0e0e0}.auth-modal-header{margin-bottom:28px}.auth-modal-header h2{font-size:24px;font-weight:700;color:#e0e0e0;margin-bottom:6px}.auth-modal-header p{font-size:14px;color:#999}.auth-social-buttons{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.auth-social-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e0e0e0;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.auth-social-btn:hover{background:rgba(255,255,255,.08);border-color:#ffffff26}.auth-social-btn-google:hover{background:rgba(66,133,244,.1);border-color:#4285f44d}.auth-social-btn-github:hover{background:rgba(255,255,255,.1);border-color:#fff3}.auth-divider{display:flex;align-items:center;margin:20px 0;color:#666;font-size:13px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:rgba(255,255,255,.1)}.auth-divider span{padding:0 12px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-form-group{display:flex;flex-direction:column;gap:6px}.auth-form-group label{font-size:13px;font-weight:600;color:#bbb}.auth-form-group input{padding:12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#e0e0e0;font-size:14px;transition:all .2s ease}.auth-form-group input:focus{outline:none;border-color:#0d757780;background:rgba(255,255,255,.08)}.auth-form-group input::placeholder{color:#666}.auth-error{display:none;padding:10px 12px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#ef4444;font-size:13px}.auth-submit-btn{padding:12px;background:linear-gradient(135deg,#0d7377,#14a085);border:none;border-radius:6px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.auth-submit-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0d75774d}.auth-submit-btn:active{transform:translateY(0)}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-toggle{margin-top:16px;text-align:center;font-size:14px;color:#999}.auth-toggle-btn{background:none;border:none;color:#0d7377;font-weight:600;cursor:pointer;text-decoration:underline;margin-left:4px;transition:color .2s ease}.auth-toggle-btn:hover{color:#14a085}.guest-prompt-banner{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:90000;background:linear-gradient(135deg,rgba(13,117,119,.95),rgba(20,160,133,.95));border:1px solid rgba(255,255,255,.2);border-radius:8px;box-shadow:0 4px 20px #0000004d;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.guest-prompt-banner.hidden{display:none}.guest-prompt-content{display:flex;align-items:center;gap:16px;padding:12px 20px}.guest-prompt-text{color:#fff;font-size:14px;font-weight:500}.guest-prompt-btn{padding:8px 16px;background:white;border:none;border-radius:6px;color:#0d7377;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap}.guest-prompt-btn:hover{transform:scale(1.05);box-shadow:0 2px 8px #0003}.guest-prompt-close{width:24px;height:24px;background:rgba(255,255,255,.2);border:none;border-radius:4px;color:#fff;font-size:18px;line-height:1;cursor:pointer;transition:background .2s ease}.guest-prompt-close:hover{background:rgba(255,255,255,.3)}.hidden{display:none!important}.model-nav-menu{position:fixed;background:#333333;border:1px solid #505050;border-radius:8px;box-shadow:0 4px 12px #0006;z-index:1001;width:200px;padding:8px 0}.model-nav-arrow{position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid #333333}.model-nav-content{display:flex;flex-direction:column}.model-nav-item{padding:10px 16px;color:#e0e0e0;cursor:pointer;transition:background-color .2s ease;font-size:14px}.model-nav-item:hover{background:#444444}.model-nav-divider{height:1px;background:#505050;margin:4px 0}:root{color-scheme:dark;--ds-color-background: #080b12;--ds-color-surface-0: #0d111b;--ds-color-surface-1: #121828;--ds-color-surface-2: #192133;--ds-color-surface-3: #1f2a40;--ds-color-surface-highlight: rgba(148, 163, 184, .16);--ds-color-border-subtle: rgba(148, 163, 184, .18);--ds-color-border-strong: rgba(148, 163, 184, .32);--ds-color-text-primary: #f8fafc;--ds-color-text-secondary: #cbd5f5;--ds-color-text-muted: #94a3b8;--ds-color-accent: #7c5cff;--ds-color-accent-muted: #a28dff;--ds-color-accent-contrast: #05070c;--ds-color-focus: #38bdf8;--ds-color-success: #22d3ee;--ds-color-warning: #f97316;--ds-color-danger: #f87171;--ds-color-overlay: rgba(8, 11, 18, .78);--ds-font-family-base: "Inter", "Segoe UI", -apple-system, BlinkMacSystemFont, sans-serif;--ds-font-size-xs: 12px;--ds-font-size-sm: 13px;--ds-font-size-md: 15px;--ds-font-size-lg: 17px;--ds-font-size-xl: 20px;--ds-line-height-tight: 1.2;--ds-line-height-default: 1.45;--ds-line-height-loose: 1.6;--ds-space-none: 0px;--ds-space-2: 2px;--ds-space-4: 4px;--ds-space-6: 6px;--ds-space-8: 8px;--ds-space-12: 12px;--ds-space-16: 16px;--ds-space-20: 20px;--ds-space-24: 24px;--ds-space-32: 32px;--ds-space-40: 40px;--ds-radius-sm: 6px;--ds-radius-md: 10px;--ds-radius-lg: 16px;--ds-radius-xl: 24px;--ds-radius-pill: 999px;--ds-shadow-sm: 0 4px 16px rgba(2, 6, 23, .18);--ds-shadow-md: 0 16px 40px rgba(2, 6, 23, .32);--ds-elevation-overlay: 1600;--ds-elevation-modal: 2000;--ds-elevation-toast: 2100}@media (prefers-color-scheme: light){:root{--ds-color-background: #f5f7fb;--ds-color-surface-0: #ffffff;--ds-color-surface-1: #f2f4f9;--ds-color-surface-2: #e7ebf4;--ds-color-surface-3: #dfe5f2;--ds-color-surface-highlight: rgba(15, 23, 42, .08);--ds-color-border-subtle: rgba(15, 23, 42, .12);--ds-color-border-strong: rgba(15, 23, 42, .22);--ds-color-text-primary: #0f172a;--ds-color-text-secondary: #1e293b;--ds-color-text-muted: #475569;--ds-color-accent: #4f46e5;--ds-color-accent-muted: #6366f1;--ds-color-accent-contrast: #ffffff;--ds-color-focus: #0ea5e9;--ds-color-success: #0ea5e9;--ds-color-warning: #ea580c;--ds-color-danger: #dc2626;--ds-color-overlay: rgba(15, 23, 42, .62);--ds-shadow-sm: 0 4px 12px rgba(15, 23, 42, .14);--ds-shadow-md: 0 18px 38px rgba(15, 23, 42, .18)}}body{font-family:var(--ds-font-family-base);background-color:var(--ds-color-background);color:var(--ds-color-text-primary)}.ds-surface-raised{background:var(--ds-color-surface-1);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm)}.ds-surface-subtle{background:var(--ds-color-surface-2);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-md)}.ds-panel-border{border:1px solid var(--ds-color-border-strong)}.ds-stack-sm{display:flex;flex-direction:column;gap:var(--ds-space-8)}.ds-stack-md{display:flex;flex-direction:column;gap:var(--ds-space-12)}.ds-stack-lg{display:flex;flex-direction:column;gap:var(--ds-space-16)}.ds-grid-responsive{display:grid;gap:var(--ds-space-16);grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.ds-text-muted{color:var(--ds-color-text-muted);font-size:var(--ds-font-size-sm);line-height:var(--ds-line-height-loose)}.ds-field-label{font-size:var(--ds-font-size-sm);font-weight:600;color:var(--ds-color-text-secondary)}.ds-input,.ds-textarea,.ds-select{width:100%;background:var(--ds-color-surface-2);color:var(--ds-color-text-primary);border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-md);padding:var(--ds-space-8) var(--ds-space-12);font-family:inherit;font-size:var(--ds-font-size-md);transition:border-color .2s ease,box-shadow .2s ease}.ds-input:focus,.ds-textarea:focus,.ds-select:focus{outline:none;border-color:var(--ds-color-accent);box-shadow:0 0 0 3px #7c5cff59}.ds-textarea{min-height:96px;resize:vertical}.ds-helper-text{display:block;margin-top:var(--ds-space-6);color:var(--ds-color-text-muted);font-size:var(--ds-font-size-sm)}.ds-section-title{text-transform:uppercase;letter-spacing:.08em;font-size:var(--ds-font-size-xs);font-weight:600;color:var(--ds-color-text-secondary)}.ds-divider{height:1px;width:100%;background:var(--ds-color-border-subtle)}.ds-btn{border:none;border-radius:var(--ds-radius-pill);font-size:var(--ds-font-size-sm);font-weight:600;padding:var(--ds-space-8) var(--ds-space-16);cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease,transform .1s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--ds-space-8);text-decoration:none}.ds-btn:focus-visible{outline:2px solid var(--ds-color-focus);outline-offset:2px}.ds-btn--primary{background:linear-gradient(135deg,var(--ds-color-accent),var(--ds-color-accent-muted));color:var(--ds-color-accent-contrast);box-shadow:var(--ds-shadow-sm)}.ds-btn--primary:hover{transform:translateY(-1px);box-shadow:var(--ds-shadow-md)}.ds-btn--ghost{background:transparent;color:var(--ds-color-text-secondary);border:1px solid var(--ds-color-border-subtle)}.ds-btn--ghost:hover{background:var(--ds-color-surface-highlight)}.ds-btn--tonal{background:rgba(124,92,255,.14);color:var(--ds-color-accent-muted)}.ds-badge{display:inline-flex;align-items:center;padding:0 var(--ds-space-8);height:24px;border-radius:var(--ds-radius-pill);background:var(--ds-color-surface-highlight);color:var(--ds-color-text-secondary);font-size:var(--ds-font-size-xs);letter-spacing:.04em;text-transform:uppercase}.ds-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--ds-color-overlay);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:var(--ds-elevation-overlay)}.ds-modal{background:var(--ds-color-surface-1);border-radius:var(--ds-radius-xl);border:1px solid var(--ds-color-border-subtle);box-shadow:var(--ds-shadow-md);width:min(640px,90vw);margin:var(--ds-space-40) auto;padding:var(--ds-space-24);display:flex;flex-direction:column;gap:var(--ds-space-20);position:relative;z-index:var(--ds-elevation-modal)}.ds-modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--ds-space-12)}.ds-modal-title{font-size:var(--ds-font-size-lg);font-weight:600;line-height:var(--ds-line-height-tight)}.ds-icon-button{width:32px;height:32px;border-radius:var(--ds-radius-pill);border:1px solid var(--ds-color-border-subtle);background:transparent;color:var(--ds-color-text-secondary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.ds-icon-button:hover{background:var(--ds-color-surface-highlight);border-color:var(--ds-color-border-strong)}.ds-icon-button:focus-visible{outline:2px solid var(--ds-color-focus);outline-offset:2px}.ds-chip-group{display:flex;flex-wrap:wrap;gap:var(--ds-space-8)}.ds-chip{padding:var(--ds-space-4) var(--ds-space-12);border-radius:var(--ds-radius-pill);border:1px solid var(--ds-color-border-subtle);background:var(--ds-color-surface-0);color:var(--ds-color-text-secondary);font-size:var(--ds-font-size-xs)}.ds-scroll-container{max-height:240px;overflow-y:auto;border:1px solid var(--ds-color-border-subtle);border-radius:var(--ds-radius-md);padding:var(--ds-space-12);background:var(--ds-color-surface-0)}.ds-inline-link{color:var(--ds-color-text-secondary);text-decoration:underline;text-decoration-color:#94a3b866}.ds-inline-link:hover{color:var(--ds-color-accent);text-decoration-color:var(--ds-color-accent)}
