.app{width:100%;height:100vh;height:100dvh;display:flex;flex-direction:column;background:var(--bg-secondary);overflow:hidden}.app-body{flex:1;display:flex;overflow:hidden;position:relative}.canvas-area{flex:1;display:flex;flex-direction:column;background:var(--bg-canvas);position:relative;overflow:hidden}.quick-edit-tab{position:absolute;bottom:var(--spacing-xl);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:10}.quick-edit-label{font-size:13px;color:var(--text-secondary);white-space:nowrap}.quick-edit-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.quick-edit-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.quick-edit-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.mobile-nav{display:none;height:var(--bottom-nav-height);background:var(--bg-primary);border-top:1px solid var(--border-light);padding:0 var(--spacing-sm);padding-bottom:env(safe-area-inset-bottom,0px);flex-shrink:0}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;background:transparent;color:var(--text-tertiary);font-size:11px;cursor:pointer;transition:color var(--transition-fast, .15s ease);-webkit-tap-highlight-color:transparent}.mobile-nav-item.active{color:var(--primary-color)}.mobile-nav-item:hover{color:var(--text-primary)}.mobile-nav-item svg{width:22px;height:22px}@media (min-width: 768px) and (max-width: 1199px){.quick-edit-tab{padding:var(--spacing-xs) var(--spacing-md);gap:var(--spacing-sm)}.quick-edit-label{font-size:12px}.quick-edit-btn{width:26px;height:26px}}@media (min-width: 600px) and (max-width: 767px){.quick-edit-tab{padding:var(--spacing-xs) var(--spacing-sm);gap:var(--spacing-xs);bottom:var(--spacing-lg)}.quick-edit-label{font-size:11px}.quick-edit-btn{width:24px;height:24px}}@media (max-width: 599px){.app{height:100dvh}.app-body{flex-direction:column;position:relative}.canvas-area{flex:1}.mobile-nav{display:flex}.quick-edit-tab{bottom:var(--spacing-md);padding:var(--spacing-xs) var(--spacing-md);gap:var(--spacing-sm)}.quick-edit-label{font-size:12px}.quick-edit-btn{width:32px;height:32px}}.gallery-view{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;z-index:100;background:var(--bg-primary)}@media (min-width: 600px) and (max-width: 1199px){.gallery-view{top:var(--header-height)}}@media (max-width: 599px){.gallery-view{top:var(--header-height);bottom:var(--bottom-nav-height)}}.view-transition{transition:opacity var(--transition-normal, .2s ease),transform var(--transition-normal, .2s ease)}.view-hidden{opacity:0;pointer-events:none}@media (max-width: 599px){.chat-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;top:var(--header-height);bottom:var(--bottom-nav-height);background:#0000004d;z-index:99;opacity:0;pointer-events:none;transition:opacity var(--transition-normal, .2s ease)}.chat-panel-overlay.visible{opacity:1;pointer-events:auto}}.loading-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-tertiary);gap:var(--spacing-sm)}.loading-fallback .loading-spinner{display:flex;align-items:center;justify-content:center}.loading-fallback .spinner{animation:spin 1s linear infinite;color:var(--primary-color)}.loading-fallback span{font-size:13px}.gallery-loading-fallback{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-primary)}.header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 var(--spacing-md);background:var(--bg-primary);border-bottom:1px solid var(--border-light);flex-shrink:0}.header-left{display:flex;align-items:center;gap:var(--spacing-md);min-width:200px}.header-logo{display:flex;align-items:center;justify-content:center;cursor:pointer}.project-name{font-size:14px;font-weight:500;color:var(--text-primary);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);transition:background .15s ease}.project-name:hover{background:var(--bg-tertiary)}.project-name-input{font-size:14px;font-weight:500;color:var(--text-primary);padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-focus);border-radius:var(--radius-sm);background:var(--bg-primary);outline:none;width:150px}.header-center{display:flex;align-items:center;justify-content:center}.zoom-controls{display:flex;align-items:center;gap:var(--spacing-xs);background:var(--bg-tertiary);border-radius:var(--radius-md);padding:2px}.zoom-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:16px;font-weight:500;cursor:pointer;transition:all .15s ease}.zoom-btn:hover:not(:disabled){background:var(--bg-primary);color:var(--text-primary)}.zoom-btn:disabled{opacity:.4;cursor:not-allowed}.zoom-value{min-width:48px;text-align:center;font-size:13px;font-weight:500;color:var(--text-primary)}.header-right{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);min-width:200px}.user-section{display:flex;align-items:center;gap:var(--spacing-sm)}.user-avatar{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary-light);color:var(--primary-color);font-size:12px;font-weight:600;cursor:pointer;transition:transform .15s ease}.user-avatar:hover{transform:scale(1.05)}.header-btn{padding:6px 14px;font-size:13px;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.header-btn.login{color:#fff;background:var(--primary-color);border:none}.header-btn.login:hover{background:var(--primary-hover)}.header-btn.logout{color:var(--text-secondary);background:transparent;border:1px solid var(--border-color)}.header-btn.logout:hover{color:var(--text-primary);border-color:var(--text-tertiary)}@media (min-width: 768px) and (max-width: 1199px){.header{height:var(--header-height)}.header-left,.header-right{min-width:140px}.project-name{font-size:13px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.zoom-btn{width:26px;height:26px}.zoom-value{min-width:42px;font-size:12px}.user-avatar{width:28px;height:28px;font-size:11px}.header-btn{padding:5px 12px;font-size:12px}}@media (min-width: 600px) and (max-width: 767px){.header{height:var(--header-height);padding:0 var(--spacing-sm)}.header-left,.header-right{min-width:100px}.header-logo svg{width:24px;height:24px}.project-name{font-size:12px;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.zoom-controls{padding:1px}.zoom-btn{width:24px;height:24px;font-size:14px}.zoom-value{min-width:36px;font-size:11px}.user-avatar{width:26px;height:26px;font-size:10px}.header-btn{padding:4px 10px;font-size:11px}}@media (max-width: 599px){.header{height:var(--header-height);padding:0 var(--spacing-sm);padding-top:env(safe-area-inset-top,0px)}.header-left,.header-right{min-width:auto;flex:1}.header-left{gap:var(--spacing-sm)}.header-logo svg{width:24px;height:24px}.header-center{display:none}.project-name{font-size:13px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-right{justify-content:flex-end}.user-avatar{width:30px;height:30px;font-size:11px}.header-btn{padding:6px 12px;font-size:12px}.header-btn.logout{display:none}}.left-toolbar{width:var(--toolbar-width);height:100%;display:flex;flex-direction:column;background:var(--bg-primary);border-right:1px solid var(--border-light);flex-shrink:0;transition:width var(--transition-normal, .2s ease)}.toolbar-tools{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm) 0;gap:var(--spacing-xs)}.toolbar-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.toolbar-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.toolbar-icon.active{color:var(--primary-color);background:var(--primary-light)}.toolbar-icon svg{width:var(--toolbar-icon-size);height:var(--toolbar-icon-size)}.toolbar-bottom{margin-top:auto;padding:var(--spacing-md) var(--spacing-sm);display:flex;flex-direction:column;align-items:center}.points-display{display:flex;align-items:center;gap:2px;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);background:var(--bg-tertiary);cursor:default}.points-icon{font-size:14px;color:var(--points-color)}.points-value{font-size:13px;font-weight:600;color:var(--text-primary)}@media (min-width: 768px) and (max-width: 1199px){.left-toolbar{width:var(--toolbar-width)}.toolbar-icon{width:32px;height:32px}.toolbar-icon svg{width:var(--toolbar-icon-size);height:var(--toolbar-icon-size)}.points-display{padding:var(--spacing-xs)}.points-value{font-size:12px}}@media (min-width: 600px) and (max-width: 767px){.left-toolbar{width:var(--toolbar-width)}.toolbar-icon{width:30px;height:30px}.toolbar-icon svg{width:var(--toolbar-icon-size);height:var(--toolbar-icon-size)}.points-display{padding:2px 4px}.points-value{font-size:11px}.points-icon{font-size:12px}}@media (max-width: 599px){.left-toolbar{display:none}}.canvas-wrapper{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-canvas);position:relative;overflow:hidden;cursor:default;-webkit-user-select:none;user-select:none}.canvas-wrapper.dragging{cursor:grabbing}.canvas-content{display:flex;align-items:center;justify-content:center;transition:transform .1s ease-out;will-change:transform}.canvas-wrapper.dragging .canvas-content{transition:none}.canvas-image-container{position:relative;display:inline-block;cursor:pointer;border-radius:var(--radius-md);transition:box-shadow .2s ease}.canvas-image-container.selected{box-shadow:0 0 0 3px var(--selection-color)}.canvas-main-image{display:block;max-width:80vw;max-height:calc(100vh - 160px);object-fit:contain;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}.selection-handle{position:absolute;width:10px;height:10px;background:var(--bg-primary);border:2px solid var(--selection-color);border-radius:2px;pointer-events:none}.selection-handle.top-left{top:-5px;left:-5px;cursor:nwse-resize}.selection-handle.top-right{top:-5px;right:-5px;cursor:nesw-resize}.selection-handle.bottom-left{bottom:-5px;left:-5px;cursor:nesw-resize}.selection-handle.bottom-right{bottom:-5px;right:-5px;cursor:nwse-resize}.selection-handle.top-center{top:-5px;left:50%;transform:translate(-50%);cursor:ns-resize}.selection-handle.bottom-center{bottom:-5px;left:50%;transform:translate(-50%);cursor:ns-resize}.selection-handle.left-center{left:-5px;top:50%;transform:translateY(-50%);cursor:ew-resize}.selection-handle.right-center{right:-5px;top:50%;transform:translateY(-50%);cursor:ew-resize}.canvas-size-label{position:absolute;bottom:-32px;left:50%;transform:translate(-50%);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-md);font-size:12px;color:var(--text-secondary);white-space:nowrap;box-shadow:var(--shadow-sm)}.canvas-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-xl)}.empty-icon{color:var(--text-tertiary);margin-bottom:var(--spacing-lg);opacity:.6}.empty-title{font-size:16px;color:var(--text-secondary);margin:0 0 var(--spacing-sm)}.empty-subtitle{font-size:14px;color:var(--text-tertiary);margin:0 0 var(--spacing-lg)}.empty-hint{font-size:12px;color:var(--text-tertiary);margin:0}.empty-hint kbd{display:inline-block;padding:2px 6px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:11px}.canvas-zoom-indicator{position:absolute;bottom:var(--spacing-lg);right:var(--spacing-lg);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-md);font-size:12px;color:var(--text-secondary);box-shadow:var(--shadow-sm);opacity:.8;pointer-events:none}.canvas-generating-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffffe6;z-index:10}.generating-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.generating-text{margin-top:var(--spacing-md);font-size:14px;color:var(--text-secondary)}@media (min-width: 768px) and (max-width: 1199px){.canvas-main-image{max-width:70vw;max-height:calc(100vh - 140px)}.canvas-size-label{font-size:11px;padding:var(--spacing-xs) var(--spacing-sm)}}@media (min-width: 600px) and (max-width: 767px){.canvas-main-image{max-width:75vw;max-height:calc(100vh - 130px)}.canvas-size-label{bottom:-26px;font-size:10px;padding:2px var(--spacing-sm)}.selection-handle{width:8px;height:8px}.selection-handle.top-left,.selection-handle.top-right,.selection-handle.bottom-left,.selection-handle.bottom-right{top:-4px;left:-4px}.selection-handle.top-right{left:auto;right:-4px}.selection-handle.bottom-left{top:auto;bottom:-4px}.selection-handle.bottom-right{top:auto;bottom:-4px;left:auto;right:-4px}}@media (max-width: 599px){.canvas-wrapper{touch-action:pan-x pan-y pinch-zoom}.canvas-main-image{max-width:92vw;max-height:calc(100dvh - 180px)}.canvas-size-label{bottom:-24px;font-size:10px;padding:2px var(--spacing-sm)}.canvas-zoom-indicator{bottom:var(--spacing-md);right:var(--spacing-md);font-size:11px;padding:2px var(--spacing-sm)}.empty-hint{display:none}.empty-title{font-size:15px}.empty-subtitle{font-size:13px}.empty-icon svg{width:48px;height:48px}.selection-handle{width:14px;height:14px}.selection-handle.top-left{top:-7px;left:-7px}.selection-handle.top-right{top:-7px;right:-7px}.selection-handle.bottom-left{bottom:-7px;left:-7px}.selection-handle.bottom-right{bottom:-7px;right:-7px}.selection-handle.top-center{top:-7px}.selection-handle.bottom-center{bottom:-7px}.selection-handle.left-center{left:-7px}.selection-handle.right-center{right:-7px}.generating-spinner{width:32px;height:32px}.generating-text{font-size:13px}}.canvas-toolbar{position:absolute;top:var(--spacing-lg);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:100}.toolbar-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;border-radius:var(--radius-md);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap;position:relative}.toolbar-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.toolbar-btn:active{transform:scale(.98)}.toolbar-btn.active{background:var(--primary-light);color:var(--primary-color)}.toolbar-btn svg{flex-shrink:0}.toolbar-btn.has-badge{padding-right:calc(var(--spacing-md) + 28px)}.badge-new{position:absolute;right:var(--spacing-sm);top:50%;transform:translateY(-50%);padding:1px 4px;background:var(--primary-color);color:#fff;font-size:9px;font-weight:600;border-radius:var(--radius-sm);text-transform:uppercase}.toolbar-divider{width:1px;height:20px;background:var(--border-color);margin:0 var(--spacing-xs)}.toolbar-more-wrapper{position:relative}.toolbar-more-btn{padding:var(--spacing-sm)}.more-menu{position:absolute;top:calc(100% + var(--spacing-sm));right:0;min-width:160px;padding:var(--spacing-xs);background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:110}.more-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;border-radius:var(--radius-sm);font-size:13px;color:var(--text-primary);cursor:pointer;transition:background .15s ease;text-align:left}.more-menu-item:hover{background:var(--bg-tertiary)}.more-menu-item.danger{color:var(--error-color)}.more-menu-item.danger:hover{background:#ef44441a}.more-menu-item svg{flex-shrink:0;color:var(--text-secondary)}.more-menu-item.danger svg{color:var(--error-color)}.more-menu-divider{height:1px;background:var(--border-light);margin:var(--spacing-xs) 0}@media (min-width: 768px) and (max-width: 1199px){.canvas-toolbar{padding:var(--spacing-xs);gap:2px}.toolbar-btn{padding:var(--spacing-sm)}.toolbar-btn span:not(.badge-new){display:none}.toolbar-btn.has-badge{padding-right:var(--spacing-sm)}.badge-new{position:static;transform:none;margin-left:var(--spacing-xs)}}@media (min-width: 600px) and (max-width: 767px){.canvas-toolbar{padding:2px var(--spacing-xs);gap:1px}.toolbar-btn{padding:var(--spacing-xs) var(--spacing-sm)}.toolbar-btn span:not(.badge-new){display:none}.toolbar-btn svg{width:16px;height:16px}.toolbar-divider{height:16px;margin:0 2px}.badge-new{display:none}}@media (max-width: 599px){.canvas-toolbar{top:var(--spacing-md);max-width:calc(100vw - var(--spacing-lg) * 2);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:var(--spacing-xs);gap:2px}.canvas-toolbar::-webkit-scrollbar{display:none}.toolbar-btn{padding:var(--spacing-sm);min-width:40px;min-height:40px;justify-content:center}.toolbar-btn span:not(.badge-new){display:none}.toolbar-btn svg{width:18px;height:18px}.toolbar-divider,.badge-new{display:none}.more-menu{right:auto;left:50%;transform:translate(-50%);min-width:180px}.more-menu-item{padding:var(--spacing-md);font-size:14px}}.toast-container{position:fixed;top:60px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none}.toast-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 4px 20px #00000026;pointer-events:auto;animation:toastSlideIn .3s ease;min-width:200px;max-width:400px}.toast-item.leaving{animation:toastSlideOut .3s ease forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.toast-item.info{border-left:3px solid var(--primary-color)}.toast-item.info .toast-icon{color:var(--primary-color)}.toast-item.success{border-left:3px solid var(--success-color)}.toast-item.success .toast-icon{color:var(--success-color)}.toast-item.warning{border-left:3px solid var(--warning-color)}.toast-item.warning .toast-icon{color:var(--warning-color)}.toast-item.error{border-left:3px solid var(--error-color)}.toast-item.error .toast-icon{color:var(--error-color)}.toast-item.points{border-left:3px solid var(--points-color);background:linear-gradient(135deg,#fffbeb 0%,var(--bg-primary) 100%)}.toast-item.points .toast-icon{color:var(--points-color)}.toast-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-points-icon{font-size:18px}.toast-message{flex:1;font-size:14px;color:var(--text-primary);line-height:1.4}.toast-close{background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--text-tertiary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.toast-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}@media (max-width: 480px){.toast-container{left:var(--spacing-md);right:var(--spacing-md);transform:none}.toast-item{max-width:none}}.chat-panel{width:var(--chat-panel-width);height:100%;display:flex;flex-direction:column;background:var(--bg-primary);border-left:1px solid var(--border-light);flex-shrink:0;position:relative;transition:border-color .2s ease}.chat-panel.dragging{border-color:var(--primary-color)}.chat-header{height:var(--chat-header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-md);border-bottom:1px solid var(--border-light);flex-shrink:0}.chat-header-left{display:flex;flex-direction:column;gap:2px}.chat-title{font-size:14px;font-weight:600;color:var(--text-primary)}.chat-subtitle{font-size:11px;color:var(--text-tertiary)}.chat-header-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.chat-header-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.chat-header-btn:hover{background:var(--bg-tertiary);color:var(--text-secondary)}.chat-close-btn:hover{background:var(--error-color);color:#fff}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-xl)}.chat-empty-icon{color:var(--text-tertiary);margin-bottom:var(--spacing-lg)}.chat-empty-text{font-size:16px;color:var(--text-secondary);margin:0 0 var(--spacing-sm)}.chat-empty-hint{font-size:14px;color:var(--text-tertiary);margin:0}.message-group{display:flex;flex-direction:column;gap:var(--spacing-md)}.message-date-divider{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm) 0}.message-date-divider span{font-size:12px;color:var(--text-tertiary);background:var(--bg-primary);padding:0 var(--spacing-sm)}.message{display:flex;gap:var(--spacing-sm)}.message.user{flex-direction:row-reverse}.message-avatar{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.message-content{max-width:85%;display:flex;flex-direction:column;gap:var(--spacing-xs)}.message.user .message-content{align-items:flex-end}.message-text{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);font-size:14px;line-height:1.5;word-break:break-word}.message.user .message-text{background:var(--primary-color);color:#fff;border-bottom-right-radius:var(--radius-sm)}.message.assistant .message-text{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:var(--radius-sm)}.message-reference-image{max-width:200px;border-radius:var(--radius-md);overflow:hidden}.message-reference-image img{width:100%;height:auto;display:block}.message-status{display:flex;flex-direction:column;gap:var(--spacing-xs)}.status-indicator{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border:none;border-radius:var(--radius-md);font-size:12px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.status-indicator:hover{background:var(--border-color)}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--primary-color);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-arrow{transition:transform .2s ease}.status-indicator.expanded .status-arrow{transform:rotate(180deg)}.status-detail{padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:12px;color:var(--text-secondary);line-height:1.5}.message-model{display:flex;align-items:center;gap:var(--spacing-xs);font-size:11px;color:var(--text-tertiary)}.model-icon{color:var(--primary-color)}.message-images{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.message-image-thumb{position:relative;width:80px;height:80px;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform .15s ease}.message-image-thumb:hover{transform:scale(1.05)}.message-image-thumb img{width:100%;height:100%;object-fit:cover}.image-thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease;color:#fff}.message-image-thumb:hover .image-thumb-overlay{opacity:1}.message-time{font-size:11px;color:var(--text-tertiary)}.generating-indicator{padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--spacing-sm)}.generating-header{display:flex;align-items:center;gap:var(--spacing-sm)}.generating-dot{width:8px;height:8px;border-radius:50%;background:var(--primary-color);animation:pulse 1s ease-in-out infinite}.generating-text{font-size:13px;color:var(--text-secondary)}.generating-progress{height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.generating-progress-bar{height:100%;background:var(--primary-color);border-radius:2px;transition:width .3s ease}.generating-time{font-size:12px;color:var(--text-tertiary);text-align:right}.reference-preview{padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--border-light);display:flex;align-items:center;gap:var(--spacing-sm);background:var(--bg-secondary)}.reference-image-container{position:relative;width:48px;height:48px;border-radius:var(--radius-md);overflow:hidden}.reference-image-container img{width:100%;height:100%;object-fit:cover}.reference-remove-btn{position:absolute;top:2px;right:2px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;opacity:0;transition:opacity .15s ease}.reference-image-container:hover .reference-remove-btn{opacity:1}.reference-label{font-size:12px;color:var(--text-tertiary)}.chat-input-area{border-top:1px solid var(--border-light);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.chat-input-toolbar{display:flex;align-items:center;gap:var(--spacing-xs)}.toolbar-icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.toolbar-icon-btn:hover{background:var(--bg-tertiary);color:var(--text-secondary)}.toolbar-icon-btn.active{background:var(--primary-light);color:var(--primary-color)}.settings-panel{padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.settings-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.settings-label{font-size:12px;font-weight:500;color:var(--text-secondary)}.aspect-ratio-options,.batch-count-options{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.aspect-ratio-btn,.batch-count-btn{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.aspect-ratio-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-sm);min-width:48px}.aspect-ratio-preview{border:1.5px solid currentColor;border-radius:2px;background:transparent}.aspect-ratio-label{font-size:10px}.aspect-ratio-btn:hover,.batch-count-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.aspect-ratio-btn.active,.batch-count-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.aspect-ratio-btn.active .aspect-ratio-preview{border-color:#fff}.settings-hint{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:12px;color:var(--text-tertiary)}.hint-icon{font-size:14px}.settings-cost{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:linear-gradient(135deg,#fffbeb 0%,var(--bg-secondary) 100%);border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);border:1px solid rgba(251,191,36,.3)}.cost-icon{font-size:14px;color:var(--points-color)}.cost-text strong{color:var(--primary-color);font-weight:600}.cost-warning{color:var(--error-color);font-size:11px;margin-left:var(--spacing-xs)}.chat-input-container{position:relative;display:flex;align-items:flex-end;gap:var(--spacing-sm)}.chat-input{flex:1;min-height:40px;max-height:120px;padding:var(--spacing-sm) var(--spacing-md);padding-right:48px;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:14px;color:var(--text-primary);background:var(--bg-primary);resize:none;outline:none;transition:border-color .15s ease;font-family:inherit}.chat-input:focus{border-color:var(--primary-color)}.chat-input::placeholder{color:var(--text-tertiary)}.chat-send-btn{position:absolute;right:var(--spacing-sm);bottom:var(--spacing-sm);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:var(--bg-tertiary);color:var(--text-tertiary);border-radius:50%;cursor:pointer;transition:all .15s ease}.chat-send-btn:hover:not(:disabled){background:var(--primary-color);color:#fff}.chat-send-btn.active{background:var(--primary-color);color:#fff}.chat-send-btn:disabled{cursor:not-allowed;opacity:.5}.drag-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#7c3aed1a;display:flex;align-items:center;justify-content:center;z-index:10;pointer-events:none}.drag-hint{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);background:var(--bg-primary);border:2px dashed var(--primary-color);border-radius:var(--radius-lg);color:var(--primary-color)}.drag-hint span{font-size:14px;font-weight:500}@media (min-width: 768px) and (max-width: 1199px){.chat-panel{width:var(--chat-panel-width)}.message-content{max-width:90%}.chat-header{padding:0 var(--spacing-sm)}.chat-title{font-size:13px}.chat-subtitle{font-size:10px}.chat-input-area,.settings-panel{padding:var(--spacing-sm)}.aspect-ratio-btn{padding:var(--spacing-xs);min-width:42px}.aspect-ratio-label{font-size:9px}}@media (min-width: 600px) and (max-width: 767px){.chat-panel{width:var(--chat-panel-width)}.message-content{max-width:92%}.chat-header{height:44px;padding:0 var(--spacing-sm)}.chat-title{font-size:12px}.chat-subtitle{display:none}.chat-header-btn{width:24px;height:24px}.chat-input-area{padding:var(--spacing-sm)}.toolbar-icon-btn{width:28px;height:28px}.settings-panel{padding:var(--spacing-sm);gap:var(--spacing-sm)}.aspect-ratio-options{gap:2px}.aspect-ratio-btn{padding:4px;min-width:36px}.aspect-ratio-label{font-size:8px}.message-image-thumb{width:60px;height:60px}}@media (max-width: 599px){.chat-panel{position:fixed;top:0;right:0;bottom:0;left:0;top:var(--header-height);bottom:var(--bottom-nav-height);width:100%;z-index:100;border-left:none;transform:translate(0);transition:transform var(--transition-slow, .3s ease)}.chat-panel.hidden{transform:translate(100%);pointer-events:none}.chat-header{height:52px;padding:0 var(--spacing-md)}.chat-title{font-size:15px}.chat-subtitle{font-size:11px}.message-content{max-width:85%}.chat-input-area{padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom,0px))}.chat-input{font-size:16px}.settings-panel{padding:var(--spacing-md)}.aspect-ratio-options{justify-content:space-between}.aspect-ratio-btn{flex:1;max-width:48px}.message-image-thumb{width:70px;height:70px}.toolbar-icon-btn{width:40px;height:40px;min-width:40px}.chat-send-btn{width:40px;height:40px}.chat-header-btn{width:36px;height:36px}}@media (max-width: 599px){.chat-panel:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:36px;height:4px;background:var(--border-color);border-radius:2px;z-index:10}.chat-header{padding-top:20px}.chat-panel.swiping{box-shadow:-4px 0 20px #0000001a}}.login-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.login-modal{position:relative;width:400px;max-width:90vw;background:var(--bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:0 20px 60px #00000026;padding:32px;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.login-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm, 4px);color:var(--text-tertiary, #999999);cursor:pointer;transition:all .15s ease}.login-modal-close:hover{background:var(--bg-tertiary, #f5f5f5);color:var(--text-primary, #1a1a1a)}.login-modal-header{text-align:center;margin-bottom:24px}.login-modal-header h2{font-size:22px;font-weight:600;color:var(--text-primary, #1a1a1a);margin:0 0 8px}.login-modal-header p{font-size:14px;color:var(--text-secondary, #666666);margin:0}.login-tabs{display:flex;gap:8px;margin-bottom:20px;padding:4px;background:var(--bg-tertiary, #f5f5f5);border-radius:var(--radius-md, 8px)}.login-tab{flex:1;padding:10px 16px;font-size:14px;font-weight:500;color:var(--text-secondary, #666666);background:transparent;border:none;border-radius:var(--radius-sm, 4px);cursor:pointer;transition:all .15s ease}.login-tab:hover{color:var(--text-primary, #1a1a1a)}.login-tab.active{background:var(--bg-primary, #ffffff);color:var(--primary-color, #7c3aed);box-shadow:0 1px 3px #00000014}.login-error{display:flex;align-items:center;gap:8px;padding:12px 14px;margin-bottom:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md, 8px);font-size:13px;color:#dc2626}.login-error svg{flex-shrink:0}.login-form{display:flex;flex-direction:column;gap:16px}.login-input-group{display:flex;flex-direction:column;gap:6px}.login-input-group label{font-size:13px;font-weight:500;color:var(--text-primary, #1a1a1a)}.login-input-wrapper{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:12px;color:var(--text-tertiary, #999999);pointer-events:none}.login-input-wrapper input{width:100%;height:44px;padding:0 12px 0 42px;font-size:14px;color:var(--text-primary, #1a1a1a);background:var(--bg-secondary, #fafafa);border:1px solid var(--border-color, #e5e5e5);border-radius:var(--radius-md, 8px);outline:none;transition:all .15s ease}.login-input-wrapper input::placeholder{color:var(--text-tertiary, #999999)}.login-input-wrapper input:focus{background:var(--bg-primary, #ffffff);border-color:var(--primary-color, #7c3aed);box-shadow:0 0 0 3px var(--primary-light, #ede9fe)}.login-invite-tip{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--primary-light, #ede9fe);border-radius:var(--radius-md, 8px);font-size:12px;color:var(--primary-color, #7c3aed)}.login-invite-tip svg{flex-shrink:0}.login-submit-btn{height:46px;margin-top:8px;font-size:15px;font-weight:600;color:#fff;background:var(--primary-color, #7c3aed);border:none;border-radius:var(--radius-md, 8px);cursor:pointer;transition:all .15s ease}.login-submit-btn:hover:not(:disabled){background:var(--primary-hover, #6d28d9)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}.login-loading{display:flex;align-items:center;justify-content:center;gap:8px}.login-loading .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (min-width: 600px) and (max-width: 1199px){.login-modal{width:380px;padding:28px}}@media (max-width: 599px){.login-modal-overlay{align-items:flex-end}.login-modal{width:100%;max-width:100%;padding:24px;margin:0;border-radius:16px 16px 0 0;animation:modalSlideUpMobile .3s ease-out}@keyframes modalSlideUpMobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.login-modal-header h2{font-size:20px}.login-input-wrapper input{height:48px;font-size:16px}.login-submit-btn{height:50px;font-size:16px}.login-modal-close{width:36px;height:36px}.login-form{padding-bottom:env(safe-area-inset-bottom,0px)}}:root{--primary-color: #7c3aed;--primary-hover: #6d28d9;--primary-light: #ede9fe;--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f5f5f5;--bg-canvas: #e5e5e5;--text-primary: #1a1a1a;--text-secondary: #666666;--text-tertiary: #999999;--border-color: #e5e5e5;--border-light: #f0f0f0;--border-focus: #7c3aed;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--points-color: #fbbf24;--selection-color: #3b82f6;--toolbar-width: 48px;--toolbar-icon-size: 20px;--toolbar-icon-gap: 8px;--toolbar-collapsed-width: 0px;--chat-panel-width: 400px;--chat-input-height: 48px;--chat-header-height: 48px;--header-height: 48px;--canvas-toolbar-height: 40px;--bottom-nav-height: 56px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .12);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}@media (min-width: 1200px){:root{--toolbar-width: 48px;--chat-panel-width: 400px}}@media (min-width: 768px) and (max-width: 1199px){:root{--toolbar-width: 44px;--toolbar-icon-size: 18px;--chat-panel-width: 320px;--header-height: 44px}}@media (min-width: 600px) and (max-width: 767px){:root{--toolbar-width: 40px;--toolbar-icon-size: 16px;--chat-panel-width: 280px;--header-height: 44px}}@media (max-width: 599px){:root{--header-height: 44px;--bottom-nav-height: 56px;--toolbar-width: 0px;--chat-panel-width: 100%;--spacing-md: 10px;--spacing-lg: 14px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-color)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.icon-btn.active{color:var(--primary-color);background:var(--primary-light)}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);background:var(--bg-primary);transition:border-color .2s ease}.input:focus{outline:none;border-color:var(--border-focus)}.input::placeholder{color:var(--text-tertiary)}.textarea{width:100%;padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:14px;color:var(--text-primary);background:var(--bg-primary);resize:none;transition:border-color .2s ease}.textarea:focus{outline:none;border-color:var(--border-focus)}.card{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.divider{height:1px;background:var(--border-light);margin:var(--spacing-md) 0}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:12px;font-weight:500}.badge-new{background:var(--primary-light);color:var(--primary-color)}.badge-success{background:#d1fae5;color:var(--success-color)}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--spacing-xs) var(--spacing-sm);background:var(--text-primary);color:#fff;font-size:12px;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease}.tooltip:hover:after{opacity:1;visibility:visible}.spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}*{-webkit-tap-highlight-color:transparent}@media (max-width: 599px){.btn,.icon-btn,button{min-height:44px;min-width:44px}.input,.textarea,input,textarea,select{font-size:16px}a,[role=button]{min-height:44px;display:inline-flex;align-items:center}}@media (hover: none) and (pointer: coarse){.btn:hover,.icon-btn:hover,button:hover{background:inherit;color:inherit}.btn:active,.icon-btn:active,button:active{opacity:.8;transform:scale(.98)}}@supports (padding: env(safe-area-inset-bottom)){.safe-area-bottom{padding-bottom:env(safe-area-inset-bottom)}.safe-area-top{padding-top:env(safe-area-inset-top)}}@media (max-width: 599px){.scrollable{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}::-webkit-scrollbar{display:none}*{scrollbar-width:none}}@media (max-width: 599px){.modal-overlay{touch-action:none}.modal-content{touch-action:pan-y;overscroll-behavior:contain}}@media (max-width: 599px){input,textarea,select,button{touch-action:manipulation}}*{margin:0;padding:0;box-sizing:border-box}html{overscroll-behavior:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;overscroll-behavior:none;-webkit-user-select:none;user-select:none}input,textarea{-webkit-user-select:text;user-select:text}#root{width:100%;height:100vh;height:100dvh}a{color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit}img{max-width:100%;height:auto;-webkit-user-drag:none;user-drag:none}@media (max-width: 599px){html,body,#root{height:100dvh;overflow:hidden;position:fixed;width:100%}}
