:root{--primary-color: #007AFF;--primary-hover: #0051D5;--secondary-color: #5856D6;--accent-color: #00C7BE;--success-color: #30D158;--warning-color: #FF9F0A;--error-color: #FF3B30;--info-color: #64D2FF;--gray-50: #FAFAFA;--gray-75: #F7F7F7;--gray-100: #F2F2F7;--gray-150: #EBEBF0;--gray-200: #D1D1D6;--gray-300: #C7C7CC;--gray-400: #AEAEB2;--gray-500: #8E8E93;--gray-600: #636366;--gray-700: #48484A;--gray-800: #2C2C2E;--gray-900: #1C1C1E;--gray-950: #000000;--text-primary: #FFFFFF;--text-secondary: #EBEBF5;--text-tertiary: #EBEBF5;--text-quaternary: #8E8E93;--text-white: #FFFFFF;--text-inverse: #000000;--text-muted: #636366;--bg-primary: #000000;--bg-secondary: #1C1C1E;--bg-tertiary: #2C2C2E;--bg-quaternary: #3A3A3C;--bg-elevated: #1C1C1E;--bg-overlay: rgba(0, 0, 0, .6);--bg-blur: rgba(28, 28, 30, .8);--border-primary: #38383A;--border-secondary: #48484A;--border-tertiary: #636366;--border-light: #2C2C2E;--border-focus: #007AFF;--border-error: #FF3B30;--shadow-xs: 0 1px 3px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5), 0 2px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 25px rgba(0, 0, 0, .6), 0 4px 12px rgba(0, 0, 0, .4);--shadow-xl: 0 12px 40px rgba(0, 0, 0, .7), 0 8px 16px rgba(0, 0, 0, .5);--shadow-card: 0 2px 8px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .2);--shadow-button: 0 1px 3px rgba(0, 0, 0, .5), 0 1px 2px rgba(0, 0, 0, .4);--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-3xl: 24px;--radius-full: 50px;--space-0: 0;--space-1: 2px;--space-2: 4px;--space-3: 8px;--space-4: 12px;--space-5: 16px;--space-6: 20px;--space-7: 24px;--space-8: 32px;--space-9: 40px;--space-10: 48px;--space-12: 64px;--space-16: 80px;--space-20: 96px;--space-24: 128px;--font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", system-ui, sans-serif;--font-mono: "SF Mono", ui-monospace, "Monaco", "Cascadia Code", "Roboto Mono", Consolas, monospace;--text-xs: 11px;--text-sm: 12px;--text-base: 14px;--text-md: 15px;--text-lg: 16px;--text-xl: 17px;--text-2xl: 20px;--text-3xl: 22px;--text-4xl: 28px;--text-5xl: 34px;--text-6xl: 48px;--font-thin: 100;--font-ultralight: 200;--font-light: 300;--font-regular: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-heavy: 800;--font-black: 900;--leading-none: 1;--leading-tight: 1.2;--leading-snug: 1.3;--leading-normal: 1.4;--leading-relaxed: 1.5;--leading-loose: 1.6;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--navbar-height: 64px;--sidebar-width: 300px;--sidebar-collapsed-width: 72px;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{line-height:var(--leading-normal);-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--text-xl);font-weight:var(--font-regular);color:var(--text-primary);background-color:var(--bg-primary);line-height:var(--leading-normal);letter-spacing:-.01em}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-600);border-radius:var(--radius-full);border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--gray-500);background-clip:padding-box}:focus{outline:3px solid var(--border-focus);outline-offset:1px}:focus:not(:focus-visible){outline:none}:focus-visible{outline:3px solid var(--border-focus);outline-offset:1px}button{font-family:inherit;font-size:inherit;background:none;border:none;cursor:pointer;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}ul,ol{list-style:none}.app{height:100vh;display:flex;flex-direction:column;background-color:var(--bg-primary);overflow:hidden}.app-body{display:flex;flex:1;min-height:0;overflow:hidden}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:var(--bg-primary);gap:var(--space-4)}.loading-screen .spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top:3px solid var(--primary-color);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.w-full{width:100%}.h-full{height:100%}.hidden{display:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);font-family:var(--font-family);font-size:var(--text-lg);font-weight:var(--font-medium);letter-spacing:-.01em;border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer;border:none;text-decoration:none;position:relative;overflow:hidden}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:active{transform:scale(.98)}.btn-primary{background-color:var(--primary-color);color:var(--text-white);box-shadow:var(--shadow-button)}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-primary);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-secondary);box-shadow:var(--shadow-sm)}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-secondary);color:var(--text-primary)}.btn-sm{padding:var(--space-3) var(--space-5);font-size:var(--text-base);border-radius:var(--radius-md)}.btn-lg{padding:var(--space-5) var(--space-8);font-size:var(--text-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.input{width:100%;padding:var(--space-4) var(--space-5);font-family:var(--font-family);font-size:var(--text-lg);font-weight:var(--font-regular);letter-spacing:-.01em;border:1px solid var(--border-primary);border-radius:var(--radius-lg);background-color:var(--bg-elevated);transition:all var(--transition-fast);line-height:var(--leading-normal)}.input:focus{border-color:var(--border-focus);background-color:var(--bg-primary);box-shadow:0 0 0 4px #007aff1a}.input::placeholder{color:var(--text-quaternary);font-weight:var(--font-regular)}.input:disabled{background-color:var(--bg-secondary);border-color:var(--border-secondary);opacity:.5;cursor:not-allowed}.textarea{resize:vertical;min-height:120px}.card{background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-7);box-shadow:var(--shadow-card);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.card-header{margin-bottom:var(--space-6)}.card-title{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--text-primary);letter-spacing:-.02em;line-height:var(--leading-tight)}.card-subtitle{font-size:var(--text-lg);color:var(--text-secondary);font-weight:var(--font-regular);margin-top:var(--space-2);line-height:var(--leading-normal)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.animate-fadeIn{animation:fadeIn .4s cubic-bezier(.4,0,.2,1)}.animate-slideInUp{animation:slideInUp .5s cubic-bezier(.4,0,.2,1)}.animate-slideInRight{animation:slideInRight .5s cubic-bezier(.4,0,.2,1)}.animate-scaleIn{animation:scaleIn .3s cubic-bezier(.4,0,.2,1)}.animate-bounceIn{animation:bounceIn .6s cubic-bezier(.68,-.55,.265,1.55)}.animate-pulse{animation:pulse 2s infinite}.animate-shimmer{background:linear-gradient(90deg,var(--bg-secondary) 0%,var(--bg-elevated) 50%,var(--bg-secondary) 100%);background-size:200px 100%;animation:shimmer 1.5s infinite}.hover-lift{transition:transform var(--transition-fast)}.hover-lift:hover{transform:translateY(-2px)}.hover-scale{transition:transform var(--transition-fast)}.hover-scale:hover{transform:scale(1.02)}.hover-glow{transition:box-shadow var(--transition-fast)}.hover-glow:hover{box-shadow:0 0 20px #007aff4d}@media (max-width: 768px){:root{--sidebar-width: 260px;--space-4: .875rem;--space-6: 1.25rem}.btn{padding:var(--space-3) var(--space-4)}.card{padding:var(--space-4)}}.navbar{height:var(--navbar-height);background-color:#000000f2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-primary);position:sticky;top:0;z-index:var(--z-sticky);transition:all var(--transition-normal)}.navbar-container{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:100%;padding:0 var(--space-6);gap:var(--space-4)}.navbar-left{display:flex;align-items:center;gap:var(--space-4);flex-shrink:0}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);color:var(--text-secondary);transition:all var(--transition-fast);font-size:var(--text-lg);flex-shrink:0}.sidebar-toggle:hover{background-color:var(--bg-secondary);color:var(--text-primary);transform:scale(1.05)}.sidebar-toggle:active{transform:scale(.95)}.brand-container{display:flex;align-items:center;gap:var(--space-4)}.brand-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:var(--text-white);border-radius:var(--radius-lg);font-size:var(--text-2xl);font-weight:var(--font-semibold);box-shadow:var(--shadow-sm)}.brand-title{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--text-primary);letter-spacing:-.02em}.navbar-center{flex:1;display:flex;justify-content:center;max-width:400px;margin:0 var(--space-6)}.nav-items{display:flex;background-color:var(--bg-secondary);border-radius:var(--radius-xl);padding:var(--space-1);gap:var(--space-1);box-shadow:var(--shadow-xs)}.nav-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);transition:all var(--transition-fast);min-width:80px;justify-content:center;letter-spacing:-.01em}.nav-item:hover{color:var(--text-primary);background-color:var(--bg-elevated);transform:translateY(-1px)}.nav-item.active{color:var(--primary-color);background-color:var(--bg-elevated);box-shadow:var(--shadow-sm);font-weight:var(--font-semibold)}.nav-label{font-size:var(--text-sm)}.navbar-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0;margin-left:-170px}.user-section{display:flex;align-items:center;gap:var(--space-3)}.user-info{display:flex;align-items:center;gap:var(--space-2)}.user-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,var(--accent-color) 0%,var(--primary-color) 100%);border-radius:var(--radius-full);color:var(--text-white);font-weight:var(--font-semibold);font-size:var(--text-sm);box-shadow:var(--shadow-sm);flex-shrink:0}.user-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);letter-spacing:-.01em}.navbar .action-buttons{display:flex;align-items:center;gap:var(--space-2);flex-direction:row!important}.action-btn-nav{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);letter-spacing:-.01em;transition:all var(--transition-fast);border:1px solid var(--border-primary);background-color:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-xs);white-space:nowrap}.action-btn:hover:not(:disabled){background-color:var(--bg-secondary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.action-btn:active{transform:translateY(0) scale(.98)}.action-btn:disabled{opacity:.4;cursor:not-allowed}.new-chat-btn{position:relative;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer;overflow:hidden}.new-chat-btn-nav{position:relative;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--bg-elevated);color:var(--text-primary);font-size:14px;box-shadow:var(--shadow-md);border-radius:var(--radius-lg);border:1px solid var(--border-primary);transition:all var(--transition-fast);cursor:pointer;overflow:hidden}.new-chat-btn-nav:hover{position:relative;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--primary-color);color:var(--text-white);font-size:14px;box-shadow:var(--shadow-md);border-radius:var(--radius-lg);border:1px solid var(--primary-color);transition:all var(--transition-fast);cursor:pointer;overflow:hidden}.new-chat-btn:hover:not(:disabled){background-color:var(--primary-color);color:var(--text-white);border-color:var(--primary-color);box-shadow:var(--shadow-md)}.dropdown-container{position:relative}.menu-btn{width:32px;padding:var(--space-2)}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:var(--space-3);background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);min-width:200px;z-index:var(--z-dropdown);display:none;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%)}.dropdown-container:hover .dropdown-menu{display:block}.dropdown-item{display:flex;align-items:center;gap:var(--space-4);width:100%;padding:var(--space-5) var(--space-6);font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--text-primary);transition:all var(--transition-fast);letter-spacing:-.01em}.dropdown-item:first-child{border-radius:var(--radius-xl) var(--radius-xl) 0 0}.dropdown-item:last-child{border-radius:0 0 var(--radius-xl) var(--radius-xl)}.dropdown-item:hover{background-color:var(--bg-secondary)}.dropdown-item.logout-item{color:var(--error-color)}.sidebar{width:var(--sidebar-width);height:100%;background-color:var(--bg-elevated);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;transition:all var(--transition-normal);position:relative;overflow:hidden;box-shadow:var(--shadow-xs)}.sidebar.open{width:var(--sidebar-width)}@media (min-width: 769px){.sidebar:not(.open){width:0;border-right:none;box-shadow:none}}.sidebar-header{padding:var(--space-8);border-bottom:1px solid var(--border-primary);background-color:var(--bg-elevated)}.header-content{margin-bottom:var(--space-6)}.header-title{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-5)}.header-title h3{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--text-primary);letter-spacing:-.02em}.chat-stats{display:flex;gap:var(--space-4)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.stat-number{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.stat-label{font-size:var(--text-xs);color:var(--text-secondary)}.search-container{margin-top:var(--space-4)}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:var(--space-3);color:var(--text-muted);font-size:var(--text-sm)}.search-input{width:100%;padding:var(--space-4) var(--space-12) var(--space-4) var(--space-12);font-family:var(--font-family);font-size:var(--text-lg);font-weight:var(--font-regular);border:1px solid var(--border-secondary);border-radius:var(--radius-xl);background-color:var(--bg-secondary);transition:all var(--transition-fast);letter-spacing:-.01em;color:#fff}.search-input:focus{border-color:var(--border-focus);background-color:var(--bg-primary);box-shadow:0 0 0 4px #007aff1a}.clear-search{position:absolute;right:var(--space-3);color:var(--text-muted);font-size:var(--text-sm);transition:color var(--transition-fast)}.clear-search:hover{color:var(--text-secondary)}.sidebar-content{flex:1;overflow-y:auto;padding:var(--space-4) 0;min-height:0}.history-container{padding:0 var(--space-6);height:100%;overflow-y:auto}.empty-history{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12) var(--space-6);color:var(--text-secondary);gap:var(--space-3)}.empty-history i{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.empty-history small{font-size:var(--text-xs);color:var(--text-muted)}.sidebar-footer{padding:var(--space-8);border-top:1px solid var(--border-primary);background-color:var(--bg-elevated)}.new-chat-btn{width:100%;justify-content:center;padding:var(--space-5) var(--space-6);background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-xl);font-size:var(--text-lg);font-weight:var(--font-semibold);letter-spacing:-.01em;transition:all var(--transition-fast);box-shadow:var(--shadow-button)}.new-chat-btn:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.new-chat-btn:active{transform:translateY(0) scale(.98)}.new-chat-btn:disabled{opacity:.4;cursor:not-allowed}.main-content{flex:1;display:flex;flex-direction:column;background-color:var(--bg-primary);position:relative;min-height:0}.main-content.sidebar-open{margin-left:0}.content-wrapper{flex:1;display:flex;flex-direction:column;position:relative;min-height:0}.flash-messages-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:var(--z-popover);display:flex;flex-direction:column;gap:var(--space-2)}.react-root{display:contents}@media (max-width: 1024px){.navbar-container{padding:0 var(--space-4)}.navbar-center{margin:0 var(--space-4);max-width:300px}.brand-title{display:none}}@media (max-width: 768px){.sidebar{position:fixed;left:-100%;z-index:var(--z-fixed);transition:left var(--transition-normal);width:var(--sidebar-width)!important;border-right:1px solid var(--border-primary);box-shadow:var(--shadow-xs)}.sidebar.open{left:0}.main-content{width:100%}.sidebar.open:before{content:"";position:fixed;top:0;left:var(--sidebar-width);right:0;bottom:0;background-color:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:-1}.navbar-center,.user-name{display:none}.navbar .action-buttons{gap:var(--space-2);flex-direction:row!important}.action-btn span{display:none}.action-btn{padding:var(--space-2) var(--space-3);min-width:40px}}@media (max-width: 480px){.navbar-container{padding:0 var(--space-3)}.brand-icon{width:28px;height:28px;font-size:var(--text-base)}.user-info{display:none}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);padding:var(--space-6)}.auth-container{width:100%;max-width:480px;background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-3xl);box-shadow:var(--shadow-xl);padding:var(--space-12);animation:bounceIn .6s cubic-bezier(.68,-.55,.265,1.55);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%)}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-logo{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-xl);font-size:var(--text-2xl);margin:0 auto var(--space-4)}.auth-title{font-size:var(--text-5xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-3);letter-spacing:-.03em}.auth-subtitle{font-size:var(--text-xl);color:var(--text-secondary);line-height:var(--leading-relaxed);font-weight:var(--font-regular);letter-spacing:-.01em}.error-message{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--error-color);font-size:var(--text-sm);margin-bottom:var(--space-6)}.error-message i{flex-shrink:0;font-size:var(--text-base)}.auth-form{margin-bottom:var(--space-6)}.form-group{margin-bottom:var(--space-5)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:var(--space-4);color:var(--text-muted);font-size:var(--text-sm);z-index:1}.form-input{width:100%;padding:var(--space-4) var(--space-4) var(--space-4) var(--space-12);font-size:var(--text-base);border:1px solid var(--border-light);border-radius:var(--radius-md);background-color:var(--bg-primary);transition:all var(--transition-fast)}.form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.form-input::placeholder{color:var(--text-muted)}.auth-button{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4);font-size:var(--text-base);font-weight:var(--font-medium);border-radius:var(--radius-md);transition:all var(--transition-fast);border:1px solid transparent;cursor:pointer}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-button.primary{background-color:var(--primary-color);color:var(--text-white)}.auth-button.primary:hover:not(:disabled){background-color:#5856eb}.auth-button.secondary{background-color:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-light)}.auth-button.secondary:hover:not(:disabled){background-color:var(--bg-tertiary)}.button-spinner{width:20px;height:20px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:var(--radius-full);animation:spin 1s linear infinite}.auth-divider{text-align:center;margin:var(--space-6) 0;position:relative}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:var(--border-light)}.auth-divider span{background-color:var(--bg-primary);color:var(--text-secondary);font-size:var(--text-sm);padding:0 var(--space-4);position:relative;z-index:1}.demo-card{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-5);margin-top:var(--space-6)}.demo-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);color:var(--text-primary);font-weight:var(--font-medium);font-size:var(--text-sm)}.demo-content{display:flex;flex-direction:column;gap:var(--space-3)}.demo-credential{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.demo-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.demo-value{font-family:var(--font-mono);font-size:var(--text-sm);background-color:var(--bg-primary);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);border:1px solid var(--border-light);color:var(--text-primary)}@media (max-width: 480px){.auth-page{padding:var(--space-2)}.auth-container{padding:var(--space-6)}.auth-logo{width:56px;height:56px;font-size:var(--text-xl)}.auth-title{font-size:var(--text-2xl)}.form-input{padding:var(--space-3) var(--space-3) var(--space-3) var(--space-10);font-size:var(--text-sm)}.input-icon{left:var(--space-3)}.auth-button{padding:var(--space-3);font-size:var(--text-sm)}}.chat-container{display:flex;flex-direction:column;height:100%;width:100%;background-color:var(--bg-primary);position:relative}.chat-view{display:flex;flex-direction:column;height:100%;width:100%;max-width:900px;margin:0 auto;position:relative;min-height:0}.chat-messages-area{flex:1;display:flex;flex-direction:column;position:relative;min-height:0}.chat-input-section{flex-shrink:0;padding:var(--space-4) var(--space-6);background-color:var(--bg-primary)}.welcome-screen{display:flex;align-items:center;justify-content:center;height:100%;padding:var(--space-8);overflow-y:auto}.welcome-content{max-width:900px;width:100%;text-align:center}.welcome-header{margin-bottom:var(--space-12)}.welcome-logo{position:relative;display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--space-6)}.logo-cube{display:flex;align-items:center;justify-content:center;width:80px;height:80px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-xl);font-size:var(--text-3xl)}.logo-sparkle{position:absolute;top:-8px;right:-8px;width:24px;height:24px;background-color:var(--accent-color);color:var(--text-white);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm)}.welcome-title{font-size:var(--text-5xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-5);line-height:var(--leading-tight);letter-spacing:-.03em}.welcome-subtitle{font-size:var(--text-2xl);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-10);font-weight:var(--font-regular);letter-spacing:-.01em}.welcome-cta{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6) var(--space-8);background-color:var(--bg-secondary);border-radius:var(--radius-xl);color:var(--text-secondary);font-size:var(--text-lg);font-weight:var(--font-medium);letter-spacing:-.01em;margin-bottom:var(--space-12);transition:all var(--transition-fast);cursor:pointer;box-shadow:var(--shadow-xs)}.welcome-cta:hover{background-color:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.welcome-prompt-container{margin:var(--space-12) 0;max-width:700px;margin-left:auto;margin-right:auto}.welcome-prompt-container .prompt-form-container{border-radius:var(--radius-3xl);box-shadow:var(--shadow-lg);padding:var(--space-2);-webkit-backdrop-filter:none;backdrop-filter:none}.welcome-prompt-container .quick-actions{padding:var(--space-3) var(--space-2) var(--space-2)}.welcome-features{margin-top:var(--space-16)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6);margin-top:var(--space-8)}@media (max-width: 768px){.welcome-screen{padding:var(--space-5);align-items:flex-start;padding-top:var(--space-8)}.welcome-header{margin-bottom:var(--space-8)}.welcome-prompt-container{margin:var(--space-8) 0}.welcome-features{margin-top:var(--space-12)}.features-grid{grid-template-columns:1fr;gap:var(--space-4)}.feature-card{padding:var(--space-5)}}.cta-prompt i{animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}60%{transform:translateY(-2px)}}.welcome-features{margin-bottom:var(--space-12)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6);margin-top:var(--space-8)}.feature-card{background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-7);text-align:center;transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.feature-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md);transform:translateY(-4px)}.feature-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);border-radius:var(--radius-xl);margin:0 auto var(--space-5);color:var(--text-white);font-size:var(--text-2xl);box-shadow:var(--shadow-sm)}.feature-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-3);letter-spacing:-.01em}.feature-description{font-size:var(--text-lg);color:var(--text-secondary);line-height:var(--leading-relaxed);letter-spacing:-.01em}.welcome-examples{text-align:left}.examples-header h3{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-4)}.examples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-3)}.example-prompt{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);font-style:italic;transition:all var(--transition-fast);cursor:pointer}.example-prompt:hover{border-color:var(--primary-color);color:var(--text-primary)}.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-6) 0;position:relative;min-height:0;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.chat-messages::-webkit-scrollbar{display:none}.messages-container{width:100%;padding:0 var(--space-4) var(--space-6);display:flex;flex-direction:column;min-height:min-content}.message{display:flex;gap:var(--space-3);animation:slideInUp .3s ease-out;max-width:100%;width:100%;margin-bottom:var(--space-4);padding:var(--space-2) 0}.user-message{flex-direction:row-reverse}.message-avatar{flex-shrink:0;margin-top:var(--space-1)}.avatar-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);box-shadow:var(--shadow-sm)}.user-avatar{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:var(--text-white)}.assistant-avatar{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-elevated) 100%);color:var(--text-secondary);border:1px solid var(--border-primary)}.message-content{flex:1;min-width:0;max-width:75%;display:flex;flex-direction:column;gap:var(--space-2)}.user-message .message-content{align-items:flex-end}.assistant-message .message-content{align-items:flex-start}.message-text{font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--text-primary);word-wrap:break-word;font-weight:var(--font-regular);letter-spacing:-.01em;white-space:pre-wrap;padding:var(--space-3) var(--space-4);border-radius:var(--radius-2xl);max-width:100%;box-shadow:var(--shadow-xs)}.user-message .message-text{background-color:var(--primary-color);color:var(--text-white);border-bottom-right-radius:var(--radius-sm)}.assistant-message .message-text{background-color:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:var(--radius-sm)}.message-timestamp{font-size:var(--text-xs);color:var(--text-quaternary);margin-top:var(--space-1);font-weight:var(--font-medium);padding:0 var(--space-2)}.user-message .message-timestamp{text-align:right}.assistant-message .message-timestamp{text-align:left}.message-image-container{max-width:350px;margin:var(--space-2) 0;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm)}.user-message .message-image-container{border-bottom-right-radius:var(--radius-sm)}.assistant-message .message-image-container{border-bottom-left-radius:var(--radius-sm)}.image-wrapper{position:relative;background-color:var(--bg-secondary);border-radius:inherit;overflow:hidden}.message-image{width:100%;height:auto;max-height:250px;object-fit:cover;display:block}.image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.image-wrapper:hover .image-overlay{opacity:1}.message-model{max-width:500px;margin:var(--space-3) 0}.media-items{display:flex;flex-direction:column;gap:var(--space-3)}.media-item{max-width:400px}.processing-indicator{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--bg-tertiary);border-radius:var(--radius-2xl);border-bottom-left-radius:var(--radius-sm);color:var(--text-secondary);box-shadow:var(--shadow-xs);max-width:fit-content}.processing-spinner{width:16px;height:16px;border:2px solid var(--gray-300);border-top:2px solid var(--primary-color);border-radius:var(--radius-full);animation:spin 1s linear infinite}.processing-text{font-size:var(--text-sm)}.chat-history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12) var(--space-6);color:var(--text-secondary)}.empty-icon{font-size:var(--text-3xl);margin-bottom:var(--space-4);color:var(--text-muted)}.empty-text{font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-subtext{font-size:var(--text-sm);color:var(--text-secondary)}.chat-history{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2) 0}.chat-history-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);margin:var(--space-1) 0}.chat-history-item:hover{background-color:var(--bg-secondary);border-color:var(--border-primary);transform:translate(2px)}.chat-item-content{flex:1;min-width:0}.chat-item-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-1)}.chat-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-actions{display:flex;align-items:center;gap:var(--space-1);opacity:0;transition:opacity var(--transition-fast)}.chat-history-item:hover .chat-actions{opacity:1}.chat-action-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition-fast)}.chat-action-btn:hover{background-color:var(--bg-tertiary);color:var(--text-secondary)}.delete-btn:hover{background-color:#fef2f2;color:var(--error-color)}.chat-item-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--text-muted)}.chat-date,.chat-message-count{display:flex;align-items:center;gap:var(--space-1)}.chat-item-indicator{color:var(--text-muted);font-size:var(--text-xs);opacity:0;transition:opacity var(--transition-fast)}.chat-history-item:hover .chat-item-indicator{opacity:1}@media (max-width: 768px){.chat-view{max-width:100%}.chat-input-section{padding:var(--space-3) var(--space-4)}.messages-container{padding:0 var(--space-4);gap:var(--space-4)}.welcome-content{padding:var(--space-4)}.welcome-title{font-size:var(--text-3xl)}.features-grid{grid-template-columns:1fr;gap:var(--space-4)}.examples-grid{grid-template-columns:1fr}.message{gap:var(--space-3)}.avatar-icon{width:32px;height:32px}.message-content{max-width:85%}.message-text{font-size:var(--text-base);padding:var(--space-2) var(--space-3)}}@media (max-width: 480px){.messages-container{padding:0 var(--space-3)}.message{gap:var(--space-2)}.avatar-icon{width:28px;height:28px;font-size:var(--text-xs)}.chat-history-item{padding:var(--space-3)}.chat-title{font-size:var(--text-xs)}.chat-item-meta{font-size:11px}}.prompt-form-container{background-color:transparent;padding:0;max-width:100%;width:100%}.selected-style-indicator{margin-bottom:var(--space-4)}.style-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--text-primary)}.style-remove{display:flex;align-items:center;justify-content:center;width:16px;height:16px;color:var(--text-muted);transition:color var(--transition-fast)}.style-remove:hover{color:var(--text-secondary)}.collapsible-section{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);margin-bottom:var(--space-4);overflow:hidden}.section-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);border-bottom:1px solid var(--border-light)}.negative-prompt-input{width:100%;padding:var(--space-3);border:none;background-color:transparent;font-size:var(--text-sm);color:var(--text-primary);resize:vertical;min-height:60px}.negative-prompt-input:focus{outline:none}.negative-prompt-input::placeholder{color:var(--text-muted)}.input-container{display:flex;flex-direction:column;gap:var(--space-3)}.input-wrapper{background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-2xl);overflow:hidden;transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.input-wrapper:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 4px #007aff1a}@media (max-width: 768px){.prompt-form-container{padding:var(--space-4) var(--space-5)}.input-main{padding:var(--space-3) var(--space-4)}.send-button{width:36px;height:36px;font-size:var(--text-base)}.file-upload-btn{width:32px;height:32px;font-size:var(--text-base)}}.input-main{display:flex;align-items:flex-end;gap:var(--space-4);padding:var(--space-4) var(--space-5);width:100%}.prompt-textarea{flex:1;border:none;background:transparent;font-family:var(--font-family);font-size:var(--text-lg);font-weight:var(--font-regular);color:var(--text-primary);resize:none;min-height:32px;max-height:180px;line-height:var(--leading-normal);letter-spacing:-.01em;width:100%;min-width:0;height:29px;padding-left:15px;border-radius:80px}.prompt-textarea:focus{outline:none}.prompt-textarea::placeholder{color:var(--text-quaternary);font-weight:var(--font-regular)}.input-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0;margin-left:auto}.send-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:transparent;color:var(--primary-color);border-radius:var(--radius-full);transition:all var(--transition-fast);font-size:var(--text-lg);box-shadow:none;flex-shrink:0;border:none}.send-button:hover:not(:disabled){background-color:var(--bg-secondary);color:var(--primary-hover);transform:scale(1.05)}.send-button:active{transform:scale(.95)}.send-button:disabled{opacity:.4;cursor:not-allowed;transform:none}.file-upload-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);color:var(--text-quaternary);transition:all var(--transition-fast);position:relative;font-size:var(--text-lg);flex-shrink:0}.file-upload-btn:hover:not(:disabled){background-color:var(--bg-secondary);color:var(--text-primary);transform:scale(1.05)}.file-upload-btn.uploading{color:var(--primary-color)}.file-upload-btn.drag-over{background-color:var(--bg-secondary);color:var(--primary-color)}.upload-spinner{width:16px;height:16px;border:2px solid var(--gray-300);border-top:2px solid var(--primary-color);border-radius:var(--radius-full);animation:spin 1s linear infinite}.quick-actions{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) 0 0}.action-group{display:flex;align-items:center;gap:var(--space-1)}.action-button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-lg);transition:all var(--transition-fast);border:1px solid transparent;font-weight:var(--font-medium)}.action-button:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.action-button.active{background-color:var(--primary-color);color:var(--text-white)}.toggle-group{display:flex;align-items:center;gap:var(--space-4)}.toggle-option{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.toggle-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-color)}.toggle-label{font-size:var(--text-xs);color:var(--text-secondary);-webkit-user-select:none;user-select:none}.image-editor{background-color:var(--bg-primary);border-top:1px solid var(--border-light);padding:var(--space-6)}.editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.editor-title{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.editor-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--text-muted);border-radius:var(--radius-md);transition:all var(--transition-fast)}.editor-close-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.editor-content,.editor-controls{display:flex;flex-direction:column;gap:var(--space-4)}.control-group{display:flex;align-items:center;gap:var(--space-3)}.control-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-fast)}.control-btn:hover:not(:disabled){background-color:var(--bg-tertiary)}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn.disabled{opacity:.5;cursor:not-allowed}.selected-style{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.style-label{font-size:var(--text-sm);color:var(--text-secondary)}.editor-info{margin:var(--space-4) 0}.info-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-md);color:#1d4ed8;font-size:var(--text-sm)}.mask-status{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-md);color:#166534;font-size:var(--text-sm)}.editor-input{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden}.edit-textarea{width:100%;padding:var(--space-4);border:none;background:transparent;font-size:var(--text-base);color:var(--text-primary);resize:vertical;min-height:80px;line-height:1.5}.edit-textarea:focus{outline:none}.edit-textarea::placeholder{color:var(--text-muted)}.edit-submit-btn{position:absolute;bottom:var(--space-3);right:var(--space-3);display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-md);transition:all var(--transition-fast)}.edit-submit-btn:hover:not(:disabled){background-color:#5856eb}.edit-submit-btn:disabled{opacity:.5;cursor:not-allowed}.editor-actions{display:flex;justify-content:center;gap:var(--space-3);margin-top:var(--space-4)}.editor-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);transition:all var(--transition-fast);border:1px solid var(--border-light)}.cancel-btn{background-color:var(--bg-secondary);color:var(--text-primary)}.cancel-btn:hover{background-color:var(--bg-tertiary)}.file-upload-btn{position:relative;overflow:hidden}.file-upload-btn input[type=file]{position:absolute;left:-9999px}.prompt-builder{padding:var(--space-4)}.builder-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.header-info{display:flex;align-items:center;gap:var(--space-3)}.header-info h4{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.header-info p{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.clear-all-button button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);color:var(--text-muted);background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-fast)}.clear-all-button button:hover{background-color:var(--bg-tertiary);color:var(--text-secondary)}.loading-suggestions{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);color:var(--text-secondary)}.loading-spinner{width:16px;height:16px;border:2px solid var(--gray-300);border-top:2px solid var(--primary-color);border-radius:var(--radius-full);animation:spin 1s linear infinite}.suggestions-container{display:flex;flex-direction:column;gap:var(--space-3)}.suggestion-category{border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden}.category-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background-color:var(--bg-secondary);border:none;cursor:pointer;transition:background-color var(--transition-fast)}.category-header:hover{background-color:var(--bg-tertiary)}.category-info{display:flex;align-items:center;gap:var(--space-3)}.category-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.selection-count{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.category-chevron{color:var(--text-muted);font-size:var(--text-sm);transition:transform var(--transition-fast)}.suggestion-options{padding:var(--space-4);display:flex;flex-wrap:wrap;gap:var(--space-2);background-color:var(--bg-primary)}.suggestion-chip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-light);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.suggestion-chip:hover{background-color:var(--bg-tertiary);border-color:var(--border-medium)}.suggestion-chip.selected{background-color:var(--primary-color);color:var(--text-white);border-color:var(--primary-color)}.chip-check{font-size:var(--text-xs)}@media (max-width: 768px){.prompt-form-container{padding:var(--space-4)}.input-main{padding:var(--space-3)}.prompt-textarea{font-size:var(--text-sm)}.quick-actions{flex-direction:column;align-items:stretch;gap:var(--space-3);padding:var(--space-3) 0 0}.action-group{justify-content:center;flex-wrap:wrap}.toggle-group{justify-content:center}.editor-content{gap:var(--space-3)}.control-group,.selected-style{flex-direction:column;align-items:stretch;gap:var(--space-2)}}@media (max-width: 480px){.prompt-form-container{padding:var(--space-3)}.input-wrapper{border-radius:80px}.input-main{padding:var(--space-2);gap:var(--space-2)}.input-actions{gap:var(--space-1)}.file-upload-btn,.send-button{width:32px;height:32px}.action-button{padding:var(--space-1) var(--space-2);font-size:11px}.suggestion-options{padding:var(--space-3);gap:var(--space-1)}.suggestion-chip{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--bg-overlay);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-6);opacity:0;visibility:hidden;transition:all var(--transition-normal)}.modal-overlay.modal-open{opacity:1;visibility:visible}.modal-container{background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-3xl);box-shadow:var(--shadow-xl);width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;position:relative;z-index:var(--z-modal);transform:scale(.9) translateY(40px);transition:all var(--transition-bounce)}.modal-open .modal-container{transform:scale(1) translateY(0)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-8);border-bottom:1px solid var(--border-primary);flex-shrink:0;background-color:var(--bg-primary)}.modal-title-section{display:flex;align-items:center;gap:var(--space-3)}.modal-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.modal-title{font-size:var(--text-3xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;letter-spacing:-.02em}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--text-quaternary);border-radius:var(--radius-full);transition:all var(--transition-fast);font-size:var(--text-xl)}.modal-close-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary);transform:scale(1.05)}.modal-body{flex:1;overflow-y:auto;padding:var(--space-8)}.modal-backdrop-blur{position:absolute;top:0;left:0;right:0;bottom:0;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);z-index:-1;pointer-events:none}.modal-success .modal-icon{color:var(--success-color)}.modal-warning .modal-icon{color:var(--warning-color)}.modal-error .modal-icon{color:var(--error-color)}.credits-modal .modal-body{padding:0}.credits-modal-content{display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-6)}.current-balance{text-align:center}.balance-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-6);background-color:var(--bg-secondary);border-radius:var(--radius-lg)}.balance-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-full);font-size:var(--text-2xl)}.balance-info h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.balance-amount{font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-2)}.balance-amount.high{color:var(--success-color)}.balance-amount.medium{color:var(--warning-color)}.balance-amount.low,.balance-amount.empty{color:var(--error-color)}.balance-warning{display:flex;align-items:center;gap:var(--space-2);color:var(--warning-color);font-size:var(--text-sm)}.pricing-section h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.pricing-categories{display:flex;flex-direction:column;gap:var(--space-5)}.pricing-category{border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden}.category-title{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);background-color:var(--bg-secondary);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary);margin:0}.pricing-items{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.pricing-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background-color:var(--bg-primary);border-radius:var(--radius-md)}.item-name{font-size:var(--text-sm);color:var(--text-primary)}.item-cost{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--primary-color)}.credits-note{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-md);color:#1d4ed8;font-size:var(--text-sm)}.modal-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-6);border-top:1px solid var(--border-light);background-color:var(--bg-secondary)}.action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);transition:all var(--transition-fast);border:1px solid var(--border-light);cursor:pointer}.action-btn.primary{background-color:var(--primary-color);color:var(--text-white);border-color:var(--primary-color)}.action-btn.primary:hover{background-color:#5856eb}.action-btn.secondary{background-color:var(--bg-primary);color:var(--text-primary)}.action-btn.secondary:hover{background-color:var(--bg-tertiary)}.action-btn.danger{background-color:var(--error-color);color:var(--text-white);border-color:var(--error-color)}.action-btn.danger:hover{background-color:#dc2626}.delete-modal-content{display:flex;flex-direction:column;gap:var(--space-5)}.warning-section{display:flex;align-items:flex-start;gap:var(--space-4)}.warning-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:#fef2f2;color:var(--error-color);border-radius:var(--radius-full);font-size:var(--text-xl);flex-shrink:0}.warning-text h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.warning-text p{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.chat-info{padding:var(--space-4);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.info-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.insufficient-credits-modal-content{display:flex;flex-direction:column;gap:var(--space-6)}.credits-breakdown{display:flex;flex-direction:column;gap:var(--space-5)}.operation-info{display:flex;align-items:flex-start;gap:var(--space-4)}.operation-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:var(--bg-secondary);color:var(--primary-color);border-radius:var(--radius-full);font-size:var(--text-xl);flex-shrink:0}.operation-details h4{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.operation-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.credits-comparison{display:flex;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-4);background-color:var(--bg-secondary);border-radius:var(--radius-lg)}.credit-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.credit-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.credit-value{font-size:var(--text-2xl);font-weight:var(--font-bold)}.credit-item.available .credit-value{color:var(--text-primary)}.credit-item.required .credit-value{color:var(--primary-color)}.credit-separator{color:var(--text-muted);font-size:var(--text-lg)}.shortage-info{text-align:center}.shortage-card{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4);background-color:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--error-color)}.shortage-text{font-size:var(--text-sm)}.purchase-prompt{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.prompt-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-full);font-size:var(--text-sm);flex-shrink:0}.prompt-text p{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.settings-modal .modal-body{padding:0}.settings-modal-content{display:flex;min-height:500px}.settings-sidebar{width:200px;background-color:var(--bg-secondary);border-right:1px solid var(--border-light);flex-shrink:0}.settings-nav{padding:var(--space-4)}.settings-nav .nav-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:var(--space-1)}.settings-nav .nav-item:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.settings-nav .nav-item.active{background-color:var(--primary-color);color:var(--text-white)}.settings-content{flex:1;padding:var(--space-6);overflow-y:auto}.settings-section{display:flex;flex-direction:column;gap:var(--space-6)}.section-subtitle{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-4)}.generation-mode,.service-selection{padding:var(--space-5);background-color:var(--bg-secondary);border-radius:var(--radius-lg)}.mode-selector{margin-top:var(--space-4)}.checkbox-label{display:flex;align-items:flex-start;gap:var(--space-3);cursor:pointer;padding:var(--space-4);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.checkbox-label:hover{background-color:var(--bg-primary)}.checkbox-label.highlight{border:1px solid var(--border-light);background-color:var(--bg-primary)}.checkbox-input{width:18px;height:18px;accent-color:var(--primary-color);margin:0}.checkbox-custom{width:18px;height:18px;border:2px solid var(--border-medium);border-radius:var(--radius-sm);position:relative;flex-shrink:0}.checkbox-text{display:flex;flex-direction:column;gap:var(--space-1)}.checkbox-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.checkbox-description{font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.multi-image-info{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-3);padding:var(--space-3);background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-md);color:#1d4ed8;font-size:var(--text-xs)}.service-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.service-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border:1px solid var(--border-light);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-fast);cursor:pointer}.service-tab:hover{border-color:var(--border-medium)}.service-tab.active{background-color:var(--primary-color);color:var(--text-white);border-color:var(--primary-color)}.service-note{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-4)}.service-options{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background-color:var(--bg-primary);border-radius:var(--radius-md)}.options-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-4)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.settings-select,.settings-input{padding:var(--space-3);border:1px solid var(--border-light);border-radius:var(--radius-md);background-color:var(--bg-primary);font-size:var(--text-sm);color:var(--text-primary);transition:border-color var(--transition-fast)}.settings-select:focus,.settings-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.input-help{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.model-settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.form-group.span-2{grid-column:span 2}.apply-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);transition:background-color var(--transition-fast);margin-top:var(--space-4)}.style-modal-content{display:flex;flex-direction:column;gap:var(--space-6)}.style-intro{text-align:center}.style-intro h3{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.style-intro p{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.styles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-4)}.style-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-6);border:2px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);position:relative;text-align:center}.style-card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md)}.style-card.selected{border-color:var(--primary-color);background-color:#faf5ff}.style-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:var(--bg-secondary);border-radius:var(--radius-lg);font-size:var(--text-xl);color:var(--primary-color)}.style-info{flex:1}.style-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.style-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.selected-indicator{position:absolute;top:var(--space-3);right:var(--space-3);color:var(--primary-color);font-size:var(--text-lg)}.selection-preview{text-align:center;padding:var(--space-4);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.preview-content{display:flex;align-items:center;justify-content:center;gap:var(--space-2);color:var(--text-primary);font-size:var(--text-sm)}.credits-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-sm)}.credits-badge:hover{background-color:var(--bg-secondary);border-color:var(--border-secondary)}.credits-badge.loading{opacity:.6}.credits-badge.empty{border-color:var(--error-color);background-color:#ff3b301a}.credits-badge.low{border-color:var(--warning-color);background-color:#ff9f0a1a}.credits-badge.medium{border-color:var(--accent-color);background-color:#00c7be1a}.credits-badge.high{border-color:var(--success-color);background-color:#30d1581a}.badge-icon{color:var(--text-muted)}.credits-badge.empty .badge-icon{color:var(--error-color)}.credits-badge.low .badge-icon{color:var(--warning-color)}.credits-badge.medium .badge-icon{color:var(--accent-color)}.credits-badge.high .badge-icon{color:var(--success-color)}.badge-content{display:flex;flex-direction:column;align-items:flex-start}.badge-label{font-size:var(--text-xs);color:var(--text-muted)}.badge-value{font-weight:var(--font-semibold);color:var(--text-primary)}.badge-spinner{width:16px;height:16px;border:2px solid var(--gray-600);border-top:2px solid var(--primary-color);border-radius:var(--radius-full);animation:spin 1s linear infinite}.mask-editor-modal{max-width:95vw}.mask-editor-content{display:flex;flex-direction:column;gap:var(--space-4)}.mask-canvas-container{display:flex;justify-content:center;padding:var(--space-4);background-color:var(--bg-secondary);border-radius:var(--radius-lg)}.canvas-wrapper{border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-md)}.mask-canvas{display:block;max-width:100%;height:auto}.mask-controls{display:flex;flex-direction:column;gap:var(--space-4)}.brush-controls{padding:var(--space-4);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.brush-thickness{display:flex;flex-direction:column;gap:var(--space-2)}.brush-thickness label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.slider-container{display:flex;align-items:center;gap:var(--space-3)}.brush-slider{flex:1;height:6px;background-color:var(--bg-primary);border-radius:var(--radius-full);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.brush-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background-color:var(--primary-color);border-radius:var(--radius-full);cursor:pointer}.brush-slider::-moz-range-thumb{width:18px;height:18px;background-color:var(--primary-color);border-radius:var(--radius-full);border:none;cursor:pointer}.brush-value{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);min-width:40px;text-align:right}.mask-actions{display:flex;gap:var(--space-3)}.mask-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-fast)}.mask-btn:hover:not(:disabled){background-color:var(--bg-secondary)}.mask-btn:disabled{opacity:.5;cursor:not-allowed}.undo-btn:hover:not(:disabled){background-color:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.clear-btn:hover:not(:disabled){background-color:#fef2f2;color:var(--error-color);border-color:#fecaca}.mask-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.mask-info{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--text-sm)}.apply-mask-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);transition:background-color var(--transition-fast)}.apply-mask-btn:hover:not(:disabled){background-color:#5856eb}.apply-mask-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.modal-overlay{padding:var(--space-2)}.modal-header,.modal-body{padding:var(--space-4)}.modal-actions{padding:var(--space-4);flex-direction:column;gap:var(--space-2)}.action-btn{width:100%;justify-content:center}.settings-modal-content{flex-direction:column}.settings-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border-light)}.settings-nav{display:flex;overflow-x:auto;gap:var(--space-2)}.settings-nav .nav-item{white-space:nowrap;margin-bottom:0}.pricing-categories{gap:var(--space-4)}.pricing-items{padding:var(--space-3);gap:var(--space-2)}.styles-grid{grid-template-columns:1fr}.credits-comparison{flex-direction:column;gap:var(--space-3)}.credit-separator{transform:rotate(90deg)}.model-settings-grid{grid-template-columns:1fr}.form-group.span-2{grid-column:span 1}}@media (max-width: 480px){.modal-header,.modal-body,.modal-actions{padding:var(--space-3)}.modal-title{font-size:var(--text-lg)}.balance-card{padding:var(--space-4)}.balance-icon{width:48px;height:48px;font-size:var(--text-xl)}.balance-amount{font-size:var(--text-2xl)}.style-card{padding:var(--space-4)}.style-icon{width:40px;height:40px;font-size:var(--text-lg)}.mask-footer{flex-direction:column;align-items:stretch;gap:var(--space-3)}.apply-mask-btn{width:100%;justify-content:center}}.gallery-page{display:flex;flex-direction:column;height:100%;background-color:var(--bg-primary)}.gallery-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-10) var(--space-8);border-bottom:1px solid var(--border-primary);background-color:#000000f2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%)}.gallery-title{display:flex;align-items:center;gap:var(--space-4);font-size:var(--text-5xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-3);letter-spacing:-.03em}.gallery-subtitle{font-size:var(--text-xl);color:var(--text-secondary);line-height:var(--leading-relaxed);font-weight:var(--font-regular);letter-spacing:-.01em}.gallery-stats{display:flex;gap:var(--space-6)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);text-align:center}.stat-number{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.gallery-tabs{background-color:var(--bg-primary);border-bottom:1px solid var(--border-light);padding:0 var(--space-6)}.tabs-container{display:flex;gap:var(--space-2);padding:var(--space-4) 0;justify-content:center}.gallery-tab{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-8);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-2xl);cursor:pointer;transition:all var(--transition-fast);min-width:150px;font-size:var(--text-lg);font-weight:var(--font-medium);letter-spacing:-.01em;box-shadow:var(--shadow-xs)}.gallery-tab:hover{background-color:var(--bg-elevated);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.gallery-tab.active{background-color:var(--primary-color);color:var(--text-white);border-color:var(--primary-color);box-shadow:var(--shadow-md);font-weight:var(--font-semibold)}.tab-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:var(--text-base)}.tab-content{display:flex;flex-direction:column;gap:var(--space-1)}.tab-label{font-size:var(--text-sm);font-weight:var(--font-medium)}.tab-count{font-size:var(--text-xs);opacity:.8}.gallery-content{flex:1;overflow-y:auto;padding:var(--space-6)}.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:400px;gap:var(--space-4)}.empty-icon{font-size:var(--text-4xl);color:var(--text-muted);margin-bottom:var(--space-2)}.empty-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.empty-message{font-size:var(--text-base);color:var(--text-secondary);margin:0;line-height:var(--leading-relaxed)}.empty-cta{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3) var(--space-5);background-color:var(--bg-secondary);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm)}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-6);padding:var(--space-4) 0}.media-item{background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-fast);cursor:pointer;position:relative}.media-item:hover{border-color:var(--border-medium);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.media-thumbnail{position:relative;width:100%;height:200px;overflow:hidden;background-color:var(--bg-secondary)}.thumbnail-image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-normal)}.media-item:hover .thumbnail-image{transform:scale(1.05)}.media-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.media-item:hover .media-overlay{opacity:1}.overlay-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.preview-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background-color:var(--bg-primary);color:var(--text-primary);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast)}.preview-btn:hover{background-color:var(--primary-color);color:var(--text-white)}.stage-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background-color:var(--accent-color);color:var(--text-white);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:var(--font-medium);transition:all var(--transition-fast)}.stage-btn:hover{background-color:#0891b2}.media-type-badge{position:absolute;top:var(--space-3);left:var(--space-3);display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:#000000b3;color:var(--text-white);border-radius:var(--radius-md);font-size:var(--text-sm)}.media-type-badge.model-badge{background-color:#6366f1e6}.media-type-badge.video-badge{background-color:#ef4444e6}.media-info{padding:var(--space-4)}.media-title{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-meta{display:flex;align-items:center;gap:var(--space-4);font-size:var(--text-xs);color:var(--text-muted)}.media-date,.media-model{display:flex;align-items:center;gap:var(--space-1)}.model-thumbnail{background-color:var(--gray-100)}.model-viewer-container{width:100%;height:91%}.thumbnail-model-viewer{width:100%;height:100%;background-color:transparent}.model-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);color:var(--text-secondary)}.video-thumbnail-wrapper{position:relative;width:100%;height:100%}.video-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:#0000004d}.play-button{display:flex;align-items:center;justify-content:center;width:60px;height:60px;background-color:#000000b3;color:var(--text-white);border-radius:var(--radius-full);font-size:var(--text-xl);transition:all var(--transition-fast)}.media-item:hover .play-button{background-color:var(--primary-color);transform:scale(1.1)}.media-preview-modal{max-width:90vw;max-height:90vh}.preview-content{display:flex;flex-direction:column;gap:var(--space-6);max-height:80vh}.preview-media{display:flex;justify-content:center;background-color:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden}.preview-image,.preview-video{max-width:100%;max-height:60vh;object-fit:contain}.preview-model-viewer{width:100%;height:60vh;min-height:400px}.unsupported-preview{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-12);color:var(--text-secondary)}.preview-details{flex-shrink:0}.media-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.media-filename{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;overflow-wrap:break-word}.media-badges{display:flex;gap:var(--space-2);flex-shrink:0}.type-badge{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-md);text-transform:uppercase;letter-spacing:.05em}.type-badge.image-badge{background-color:#f0f9ff;color:#0369a1}.type-badge.model-badge{background-color:#faf5ff;color:#7c3aed}.type-badge.video-badge{background-color:#fef2f2;color:#dc2626}.media-metadata{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6)}.metadata-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.metadata-item i{width:16px;color:var(--text-muted)}.preview-actions{display:flex;gap:var(--space-3)}.download-btn{background-color:var(--bg-secondary);color:var(--text-primary)}.download-btn:hover{background-color:var(--bg-tertiary)}.stage-btn{background-color:var(--primary-color);color:var(--text-white)}.stage-btn:hover{background-color:#5856eb}.multi-image-selector{margin:var(--space-4) 0;background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden}.selector-header{padding:var(--space-5);border-bottom:1px solid var(--border-light);background-color:var(--bg-primary)}.selector-header.completed{background-color:#f0fdf4;border-bottom-color:#bbf7d0}.header-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:var(--bg-secondary);border-radius:var(--radius-lg);font-size:var(--text-xl);color:var(--primary-color);margin-bottom:var(--space-3)}.selector-header.completed .header-icon{background-color:var(--success-color);color:var(--text-white)}.header-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.header-subtitle{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);padding:var(--space-5)}.image-grid.disabled{opacity:.7;pointer-events:none}.image-option{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition-fast);border:2px solid transparent}.image-option:hover:not(.disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.image-option.selected{border-color:var(--primary-color)}.image-option.disabled{cursor:not-allowed}.image-wrapper{position:relative;background-color:var(--bg-tertiary)}.message-img{width:100%;height:160px;object-fit:cover;display:block}.selection-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#6366f1e6;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.image-option.selected .selection-overlay{opacity:1}.selection-indicator{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:var(--text-white);color:var(--primary-color);border-radius:var(--radius-full);font-size:var(--text-lg)}.image-info{padding:var(--space-3);background-color:var(--bg-primary)}.model-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);text-align:center}.selector-actions{padding:var(--space-5);border-top:1px solid var(--border-light);background-color:var(--bg-primary);text-align:center}.confirm-selection-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast)}.confirm-selection-btn:hover:not(:disabled){background-color:#5856eb}.confirm-selection-btn:disabled{opacity:.5;cursor:not-allowed}.action-buttons{display:flex;flex-direction:column;gap:var(--space-3);min-width:180px}.action-btn{position:relative;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer;overflow:hidden}.action-btn:hover:not(:disabled){border-color:var(--border-medium);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.primary{background-color:var(--primary-color);border-color:var(--primary-color);color:var(--text-white)}.action-btn.primary:hover:not(:disabled){background-color:#5856eb;border-color:#5856eb}.btn-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0}.btn-content{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-1)}.btn-label{font-size:var(--text-sm);font-weight:var(--font-medium)}.btn-subtitle{font-size:var(--text-xs);opacity:.8}.btn-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .6s ease}.action-btn:hover .btn-glow{transform:translate(100%)}.btn-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.btn-particles span{position:absolute;width:4px;height:4px;background-color:currentColor;border-radius:var(--radius-full);opacity:0;animation:float 3s infinite ease-in-out}.btn-particles span:nth-child(1){top:20%;left:20%;animation-delay:0s}.btn-particles span:nth-child(2){top:50%;left:50%;animation-delay:1s}.btn-particles span:nth-child(3){top:80%;left:80%;animation-delay:2s}@keyframes float{0%,to{transform:translateY(0) scale(0);opacity:0}50%{transform:translateY(-20px) scale(1);opacity:.6}}.action-btn.primary:hover .btn-particles span{animation-play-state:running}.message-media{margin:var(--space-4) 0}.message-image-container{position:relative;display:inline-block;border-radius:var(--radius-lg);overflow:hidden;background-color:var(--bg-secondary);max-width:100%}.message-image{display:block;max-width:100%;height:auto;border-radius:var(--radius-lg)}.image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.message-image-container:hover .image-overlay{opacity:1}.media-items{display:flex;flex-direction:column;gap:var(--space-4)}.media-item{border-radius:var(--radius-lg);overflow:hidden;background-color:var(--bg-secondary)}@media (max-width: 1024px){.media-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-4)}.gallery-stats{gap:var(--space-4)}.image-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3)}}@media (max-width: 768px){.gallery-header{flex-direction:column;align-items:flex-start;gap:var(--space-4);padding:var(--space-6) var(--space-4)}.gallery-title{font-size:var(--text-2xl)}.gallery-stats{align-self:stretch;justify-content:space-around}.tabs-container{padding:var(--space-3) 0;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.tabs-container::-webkit-scrollbar{display:none}.gallery-tab{flex-shrink:0;min-width:100px;padding:var(--space-3) var(--space-4)}.gallery-content{padding:var(--space-4)}.media-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-3)}.media-thumbnail{height:160px}.image-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-2)}.message-img{height:120px}.action-buttons{min-width:150px;gap:var(--space-2)}.action-btn{padding:var(--space-3)}.btn-label{font-size:var(--text-xs)}.btn-subtitle{font-size:11px}.preview-content{gap:var(--space-4)}.preview-model-viewer{height:50vh;min-height:300px}.media-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.preview-actions{flex-direction:column;gap:var(--space-2)}.action-btn{width:100%;justify-content:center}}@media (max-width: 480px){.gallery-header{padding:var(--space-4) var(--space-3)}.gallery-title{font-size:var(--text-xl)}.gallery-content{padding:var(--space-3)}.media-grid{grid-template-columns:1fr;gap:var(--space-3)}.media-thumbnail{height:180px}.gallery-tab{padding:var(--space-2) var(--space-3)}.tab-content{gap:0}.tab-label{font-size:var(--text-xs)}.tab-count{font-size:11px}.image-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.message-img{height:100px}.selector-header,.selector-actions{padding:var(--space-4)}.action-buttons{gap:var(--space-2)}.action-btn{padding:var(--space-2) var(--space-3)}.media-filename{font-size:var(--text-lg)}.preview-model-viewer{height:40vh;min-height:250px}}.stage-page{display:flex;flex-direction:column;height:100%;background-color:var(--bg-primary);position:relative}.stage-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6) var(--space-6);border-bottom:1px solid var(--border-light);background-color:var(--bg-primary);z-index:10}.header-content{flex:1}.stage-title{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.stage-subtitle{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed)}.stage-stats{display:flex;gap:var(--space-6)}.stage-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-6);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-light);z-index:10}.toolbar-section{display:flex;align-items:center;gap:var(--space-2)}.tool-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.tool-btn:hover{background-color:var(--bg-tertiary);border-color:var(--border-medium)}.tool-btn.active{background-color:var(--primary-color);color:var(--text-white);border-color:var(--primary-color)}.stage-content{flex:1;position:relative;overflow:hidden;background-color:var(--gray-100)}.stage-canvas-container{position:relative;width:100%;height:100%}.stage-canvas{width:100%;height:100%;display:block;cursor:grab}.stage-canvas:active{cursor:grabbing}.stage-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#ffffffe6;z-index:20;gap:var(--space-4)}.loading-text{font-size:var(--text-base);color:var(--text-secondary)}.canvas-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5}.drop-zone-hint{position:absolute;bottom:var(--space-6);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background-color:#000000b3;color:var(--text-white);border-radius:var(--radius-lg);font-size:var(--text-sm);opacity:.8;transition:opacity var(--transition-fast)}.stage-canvas-container.drag-highlight{background-color:#6366f11a}.stage-canvas-container.drag-highlight .drop-zone-hint{opacity:1;background-color:var(--primary-color)}.stage-error{display:flex;align-items:center;justify-content:center;height:100%;padding:var(--space-8)}.error-content{text-align:center;max-width:400px}.error-icon{font-size:var(--text-4xl);color:var(--error-color);margin-bottom:var(--space-4)}.error-text h3{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.error-text p{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-6)}.retry-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);transition:background-color var(--transition-fast)}.retry-btn:hover{background-color:#5856eb}.stage-panel{position:absolute;top:var(--space-4);right:var(--space-4);width:320px;max-height:calc(100vh - 200px);background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:30;display:flex;flex-direction:column}.stage-panel.assets-panel{left:var(--space-4);right:auto}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--border-light);background-color:var(--bg-secondary);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.panel-header h3{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.close-panel-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.close-panel-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.panel-content{flex:1;overflow-y:auto;padding:var(--space-4)}.control-group{margin-bottom:var(--space-4)}.control-group:last-child{margin-bottom:0}.control-group label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-2)}.control-select,.control-color{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--border-light);border-radius:var(--radius-md);background-color:var(--bg-primary);font-size:var(--text-sm);color:var(--text-primary);transition:border-color var(--transition-fast)}.control-select:focus,.control-color:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.control-color{height:40px;cursor:pointer}.slider-group{display:flex;align-items:center;gap:var(--space-3)}.control-slider{flex:1;height:6px;background-color:var(--bg-secondary);border-radius:var(--radius-full);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background-color:var(--primary-color);border-radius:var(--radius-full);cursor:pointer}.control-slider::-moz-range-thumb{width:18px;height:18px;background-color:var(--primary-color);border-radius:var(--radius-full);border:none;cursor:pointer}.slider-value{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);min-width:40px;text-align:right}.apply-btn,.reset-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);transition:all var(--transition-fast);margin-top:var(--space-4)}.apply-btn{background-color:var(--primary-color);color:var(--text-white);border:1px solid var(--primary-color)}.apply-btn:hover{background-color:#5856eb}.reset-btn{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-light)}.reset-btn:hover{background-color:var(--bg-tertiary)}.model-details{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--border-light)}.detail-item:last-child{border-bottom:none}.detail-label{font-size:var(--text-sm);color:var(--text-secondary)}.detail-value{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.scale-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-top:var(--space-2)}.scale-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition-fast)}.scale-btn:hover{background-color:var(--bg-tertiary);border-color:var(--border-medium)}.scale-value{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);min-width:60px;text-align:center}.assets-panel{width:400px}.drop-zone-hint{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.hint-content{display:flex;align-items:center;gap:var(--space-2)}.close-hint-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:#0000004d;color:var(--text-white);border-radius:var(--radius-sm);font-size:var(--text-xs);transition:all var(--transition-fast)}.close-hint-btn:hover{background-color:#00000080;transform:scale(1.05)}.assets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-3)}.asset-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-6);background-color:var(--bg-secondary);border:2px dashed var(--border-light);border-radius:var(--radius-md);color:var(--text-muted);text-align:center}.asset-placeholder i{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.ai-assistant{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:40;transition:all var(--transition-normal)}.assistant-toggle{display:flex;align-items:center;justify-content:center;width:60px;height:60px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);font-size:var(--text-xl);transition:all var(--transition-fast);position:relative}.assistant-toggle:hover{background-color:#5856eb;transform:scale(1.05)}.connection-status{position:absolute;top:-2px;right:-2px;width:16px;height:16px;border-radius:var(--radius-full);border:2px solid var(--bg-primary)}.connection-status.connected{background-color:var(--success-color)}.connection-status.disconnected{background-color:var(--error-color)}.status-dot{width:100%;height:100%;border-radius:var(--radius-full);animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}to{transform:scale(1);opacity:1}}.assistant-window{position:absolute;bottom:80px;right:0;width:500px;max-height:600px;background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;overflow:hidden;animation:slideInUp .3s ease-out}.assistant-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--border-light);background-color:var(--bg-secondary)}.header-info h4{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-1) 0}.connection-indicator{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-secondary)}.connection-indicator.connected{color:var(--success-color)}.connection-indicator.disconnected{color:var(--error-color)}.close-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.close-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.assistant-messages{flex:1;overflow-y:scroll;overflow-x:hidden;padding:var(--space-6);max-height:280px;min-height:250px;scrollbar-width:none;-ms-overflow-style:none}.assistant-messages::-webkit-scrollbar{width:0px;background:transparent}.welcome-message{text-align:center;padding:var(--space-6) var(--space-4)}.welcome-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-full);font-size:var(--text-xl);margin:0 auto var(--space-4)}.welcome-message h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-3)}.welcome-message p{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.capability-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.capability-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);text-align:left}.capability-item i{width:16px;color:var(--primary-color)}.example-prompt{padding:var(--space-3);background-color:var(--bg-secondary);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary);text-align:left}.chat-message{display:flex;gap:var(--space-4);margin-bottom:var(--space-6);align-items:flex-start;padding:var(--space-2)}.chat-message.user{flex-direction:row-reverse}.chat-message.processing{justify-content:flex-start}.chat-message.system{justify-content:center;align-items:center;flex-direction:column;text-align:center}.chat-message.error{background-color:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);padding:var(--space-3)}.message-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);flex-shrink:0;margin-top:var(--space-1)}.chat-message.user .message-avatar{background-color:var(--primary-color);color:var(--text-white)}.chat-message.assistant .message-avatar,.chat-message.system .message-avatar{background-color:var(--bg-secondary);color:var(--text-secondary)}.message-bubble{max-width:80%;padding:var(--space-3);border-radius:var(--radius-lg);position:relative}.chat-message.user .message-bubble{background-color:var(--primary-color);color:var(--text-white);border-bottom-right-radius:var(--radius-sm)}.chat-message.assistant .message-bubble,.chat-message.system .message-bubble{background-color:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:var(--radius-sm)}.message-content{font-size:var(--text-sm);line-height:var(--leading-relaxed);margin-bottom:var(--space-2)}.message-time{font-size:var(--text-xs);opacity:.7}.typing-indicator{display:flex;gap:var(--space-1);margin-right:var(--space-2)}.typing-indicator span{width:6px;height:6px;background-color:currentColor;border-radius:var(--radius-full);animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.retry-connection-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);margin-top:var(--space-2);background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-sm);font-size:var(--text-xs);transition:background-color var(--transition-fast)}.retry-connection-btn:hover{background-color:#5856eb}.assistant-input{border-top:1px solid var(--border-light);padding:var(--space-4);background-color:var(--bg-primary)}.input-form{display:flex;gap:var(--space-2)}.input-wrapper{flex:1;display:flex;align-items:center;background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:80px;overflow:hidden;transition:border-color var(--transition-fast)}.input-wrapper:focus-within{border-color:var(--primary-color)}.chat-input{flex:1;padding:var(--space-3);border:none;background:transparent;font-size:var(--text-sm);color:var(--text-primary)}.chat-input:focus{outline:none}.chat-input::placeholder{color:var(--text-muted)}.chat-input:disabled{opacity:.6;cursor:not-allowed}.send-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-md);transition:all var(--transition-fast);flex-shrink:0}.send-btn:hover:not(:disabled){background-color:#5856eb}.send-btn:disabled{opacity:.5;cursor:not-allowed}.model-viewer-container{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;margin:var(--space-4) 0}.model-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background-color:var(--bg-primary);border-bottom:1px solid var(--border-light)}.model-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.model-status{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm)}.status-loading{color:var(--warning-color)}.status-error{color:var(--error-color)}.status-ready{color:var(--success-color)}.model-error{padding:var(--space-4);background-color:#fef2f2;border:1px solid #fecaca;color:var(--error-color)}.error-content{display:flex;align-items:flex-start;gap:var(--space-3)}.error-content i{flex-shrink:0;margin-top:var(--space-1)}.error-content div{flex:1}.error-content strong{display:block;margin-bottom:var(--space-1)}.error-content small{display:block;font-size:var(--text-xs);opacity:.8}.model-viewer-wrapper{position:relative;height:170px;background-color:var(--gray-100)}.model-viewer{width:100%;height:100%}.model-actions{display:flex;gap:var(--space-3);padding:var(--space-4);background-color:var(--bg-primary)}.model-action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);transition:all var(--transition-fast);border:1px solid var(--border-light)}.model-action-btn.primary{background-color:var(--primary-color);color:var(--text-white);border-color:var(--primary-color)}.model-action-btn.primary:hover{background-color:#5856eb}.model-action-btn.secondary{background-color:var(--bg-secondary);color:var(--text-primary)}.model-action-btn.secondary:hover{background-color:var(--bg-tertiary)}.model-section{margin-top:var(--space-4);border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden}.section-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--bg-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.section-description{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);background-color:var(--bg-primary);border-bottom:1px solid var(--border-light)}.download-list{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.download-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.download-info{display:flex;flex-direction:column;gap:var(--space-1)}.download-type{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.download-filename{font-size:var(--text-xs);color:var(--text-secondary);font-family:var(--font-mono)}.download-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.download-btn:hover{background-color:#5856eb}.retexture-form{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.retexture-input-group{display:flex;gap:var(--space-2)}.retexture-input{flex:1;padding:var(--space-3);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary)}.retexture-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.retexture-apply-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);transition:background-color var(--transition-fast);white-space:nowrap}.retexture-apply-btn:hover:not(:disabled){background-color:#5856eb}.retexture-apply-btn:disabled{opacity:.5;cursor:not-allowed}.retexture-status{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-md);color:#1d4ed8;font-size:var(--text-sm)}.engine-info{padding:var(--space-4);background-color:var(--bg-secondary)}.info-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.info-list{display:flex;flex-direction:column;gap:var(--space-2)}.info-item{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}@media (max-width: 1024px){.stage-panel{width:300px}.assistant-window{width:350px;max-height:500px}.toolbar-section{gap:var(--space-1)}.tool-btn{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}}@media (max-width: 768px){.stage-header{flex-direction:column;align-items:flex-start;gap:var(--space-3);padding:var(--space-4)}.stage-title{font-size:var(--text-2xl)}.stage-stats{align-self:stretch;justify-content:space-around}.stage-toolbar{flex-direction:column;gap:var(--space-3);padding:var(--space-3)}.toolbar-section{justify-content:center;flex-wrap:wrap}.stage-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100vw - 2rem);max-width:400px;max-height:calc(100vh - 4rem)}.ai-assistant{bottom:var(--space-4);right:var(--space-4)}.assistant-window{position:fixed;bottom:0;right:0;left:0;width:100%;max-height:70vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.model-actions{flex-direction:column;gap:var(--space-2)}.model-action-btn{justify-content:center}.retexture-input-group{flex-direction:column}}@media (max-width: 480px){.stage-header{padding:var(--space-3)}.stage-title{font-size:var(--text-xl)}.stage-toolbar{padding:var(--space-2)}.tool-btn{padding:var(--space-1) var(--space-2)}.tool-btn span{display:none}.assistant-toggle{width:50px;height:50px;font-size:var(--text-lg)}.assistant-messages,.assistant-input{padding:var(--space-3)}.message-bubble{max-width:90%}.panel-content{padding:var(--space-3)}.control-group{margin-bottom:var(--space-3)}}.assets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-3);padding:var(--space-2);max-height:500px;overflow-y:auto}.asset-card{display:flex;flex-direction:column;background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-3);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.asset-card:hover{background-color:var(--bg-hover);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.asset-card:active{transform:translateY(0)}.asset-preview{display:flex;align-items:center;justify-content:center;height:80px;background-color:var(--bg-primary);border-radius:var(--radius-md);margin-bottom:var(--space-2);font-size:2rem;color:var(--primary-color);overflow:hidden;position:relative}.asset-preview model-viewer{width:100%;height:100%;border-radius:var(--radius-md)}.model-fallback{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--primary-color);font-size:2rem;z-index:1}.asset-info{display:flex;flex-direction:column;gap:var(--space-1)}.asset-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-date{font-size:var(--text-xs);color:var(--text-secondary)}.asset-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-8);color:var(--text-secondary);text-align:center}.asset-placeholder i{font-size:3rem;opacity:.5}.asset-placeholder small{display:block;margin-top:var(--space-2);font-size:var(--text-xs);opacity:.7}.modern-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-6)}.spinner-container{position:relative;display:flex;align-items:center;justify-content:center}.spinner-small .spinner-ring{width:24px;height:24px}.spinner-medium .spinner-ring{width:32px;height:32px}.spinner-large .spinner-ring{width:48px;height:48px}.spinner-ring{position:relative;border-radius:var(--radius-full)}.spinner-ring-inner,.spinner-ring-outer{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-full);border:2px solid transparent}.spinner-ring-outer{border-top:2px solid currentColor;animation:spin 1.2s linear infinite}.spinner-ring-inner{border-bottom:2px solid currentColor;animation:spin .8s linear infinite reverse;opacity:.6}.spinner-primary{color:var(--primary-color)}.spinner-accent{color:var(--accent-color)}.spinner-light{color:var(--gray-300)}.spinner-dark{color:var(--gray-700)}.spinner-particles{position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;pointer-events:none}.particle{position:absolute;width:3px;height:3px;background-color:currentColor;border-radius:var(--radius-full);opacity:0;animation:float-particle 2s infinite ease-in-out}.particle-1{top:0;left:50%;animation-delay:0s}.particle-2{top:50%;right:0;animation-delay:.5s}.particle-3{bottom:0;left:50%;animation-delay:1s}.particle-4{top:50%;left:0;animation-delay:1.5s}@keyframes float-particle{0%,to{transform:scale(0) rotate(0);opacity:0}50%{transform:scale(1) rotate(180deg);opacity:.8}}.spinner-glow{position:absolute;top:25%;right:25%;bottom:25%;left:25%;background-color:currentColor;border-radius:var(--radius-full);opacity:.2;animation:pulse-glow 2s infinite ease-in-out}@keyframes pulse-glow{0%,to{transform:scale(.8);opacity:.2}50%{transform:scale(1.2);opacity:.4}}.spinner-progress{width:100%;max-width:200px;margin-top:var(--space-4)}.progress-bar{width:100%;height:4px;background-color:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background-color:currentColor;border-radius:var(--radius-full);transition:width .3s ease-out;animation:progress-shimmer 2s infinite}@keyframes progress-shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.progress-text{text-align:center;margin-top:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);font-weight:var(--font-medium)}.spinner-text{text-align:center}.text-content{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);margin-bottom:var(--space-2)}.text-dots{display:inline-flex;gap:var(--space-1)}.text-dots span{width:4px;height:4px;background-color:currentColor;border-radius:var(--radius-full);animation:dot-bounce 1.4s infinite ease-in-out}.text-dots span:nth-child(1){animation-delay:-.32s}.text-dots span:nth-child(2){animation-delay:-.16s}.text-dots span:nth-child(3){animation-delay:0s}@keyframes dot-bounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.button-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:var(--radius-full);animation:spin 1s linear infinite}.badge-spinner,.upload-spinner,.processing-spinner{width:16px;height:16px;border:2px solid var(--gray-300);border-top:2px solid var(--primary-color);border-radius:var(--radius-full);animation:spin 1s linear infinite}.loading-spinner{width:20px;height:20px;border:2px solid var(--gray-300);border-top:2px solid var(--primary-color);border-radius:var(--radius-full);animation:spin 1s linear infinite}.canvas-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-8);color:var(--text-secondary)}.canvas-loading .loading-spinner{width:32px;height:32px;border-width:3px}.gallery-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;gap:var(--space-4);color:var(--text-secondary)}.gallery-loading .loading-spinner{width:24px;height:24px}.status-indicator{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.status-indicator.loading{background-color:#fef3c7;color:#92400e}.status-indicator.success{background-color:#dcfce7;color:#166534}.status-indicator.error{background-color:#fecaca;color:#dc2626}.status-indicator.warning{background-color:#fef3c7;color:#d97706}.status-indicator.info{background-color:#dbeafe;color:#2563eb}.notification{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:400px;animation:slideInRight .3s ease-out}.notification.success{border-left:4px solid var(--success-color);background-color:#f0fdf4}.notification.error{border-left:4px solid var(--error-color);background-color:#fef2f2}.notification.warning{border-left:4px solid var(--warning-color);background-color:#fffbeb}.notification.info{border-left:4px solid var(--accent-color);background-color:#f0f9ff}.notification-icon{flex-shrink:0;width:20px;height:20px;margin-top:var(--space-1)}.notification.success .notification-icon{color:var(--success-color)}.notification.error .notification-icon{color:var(--error-color)}.notification.warning .notification-icon{color:var(--warning-color)}.notification.info .notification-icon{color:var(--accent-color)}.notification-content{flex:1;min-width:0}.notification-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-1)}.notification-message{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.notification-close{flex-shrink:0;width:20px;height:20px;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast)}.notification-close:hover{color:var(--text-secondary)}.tooltip{position:relative;display:inline-block}.tooltip-content{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--gray-800);color:var(--text-white);font-size:var(--text-xs);border-radius:var(--radius-md);white-space:nowrap;z-index:var(--z-tooltip);opacity:0;visibility:hidden;transition:all var(--transition-fast);pointer-events:none}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--gray-800)}.tooltip:hover .tooltip-content{opacity:1;visibility:visible}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.badge.primary{background-color:var(--primary-color);color:var(--text-white)}.badge.secondary{background-color:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-light)}.badge.success{background-color:var(--success-color);color:var(--text-white)}.badge.warning{background-color:var(--warning-color);color:var(--text-white)}.badge.error{background-color:var(--error-color);color:var(--text-white)}.badge.info{background-color:var(--accent-color);color:var(--text-white)}.skeleton{background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1em;margin-bottom:var(--space-2)}.skeleton-text.large{height:1.5em}.skeleton-text.small{height:.75em}.skeleton-avatar{width:40px;height:40px;border-radius:var(--radius-full)}.skeleton-image{width:100%;height:200px}.skeleton-card{padding:var(--space-4);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12) var(--space-6);min-height:300px}.empty-state-icon{width:64px;height:64px;margin-bottom:var(--space-4);color:var(--text-muted);font-size:var(--text-3xl)}.empty-state-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-6);max-width:400px}.empty-state-action{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background-color:var(--primary-color);color:var(--text-white);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);transition:background-color var(--transition-fast)}.empty-state-action:hover{background-color:#5856eb}.progress-circle{position:relative;width:40px;height:40px}.progress-circle svg{width:100%;height:100%;transform:rotate(-90deg)}.progress-circle-bg{fill:none;stroke:var(--gray-200);stroke-width:3}.progress-circle-fill{fill:none;stroke:var(--primary-color);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .3s ease}.progress-circle-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-primary)}.divider{border:none;height:1px;background-color:var(--border-light);margin:var(--space-6) 0}.divider.vertical{width:1px;height:auto;margin:0 var(--space-4)}.divider-text{position:relative;text-align:center;margin:var(--space-6) 0}.divider-text:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:var(--border-light)}.divider-text span{background-color:var(--bg-primary);color:var(--text-secondary);font-size:var(--text-sm);padding:0 var(--space-4);position:relative;z-index:1}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:var(--z-modal-backdrop);opacity:0;visibility:hidden;transition:all var(--transition-normal)}.overlay.active{opacity:1;visibility:visible}.backdrop-blur{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.focus-ring{outline:2px solid var(--primary-color);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media print{.no-print{display:none!important}.print-only{display:block!important}body{font-size:12pt;line-height:1.4;color:#000;background:#fff}.card{border:1px solid black;box-shadow:none}.btn{border:1px solid black;background:#fff!important;color:#000!important}}@media (prefers-contrast: high){:root{--border-light: #000000;--border-medium: #000000;--border-dark: #000000;--text-muted: #000000;--text-secondary: #000000}.btn,.card{border-width:2px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.animate-fadeIn,.animate-slideInUp,.animate-slideInRight{animation:none}}body{min-height:100vh;overflow-x:hidden}body,input,textarea,button,select{text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@supports (-webkit-touch-callout: none){.app{height:-webkit-fill-available}}*:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.demos-section-3d{background:#000;padding:120px 0 80px;overflow:visible;position:relative;min-height:100vh;perspective:1000px}.demos-background-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;pointer-events:none}.demos-content{position:relative;z-index:2}.demos-title-3d{text-align:center;margin-bottom:80px;font-size:56px;font-weight:600;letter-spacing:-.02em;color:#fff}.carousel-container{position:relative;width:100%;height:450px;display:flex;align-items:center;justify-content:center;transform-style:preserve-3d;perspective:1200px;cursor:grab;-webkit-user-select:none;user-select:none;overflow:visible}.carousel-container:active{cursor:grabbing}.carousel-3d{position:relative;width:400px;height:380px;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.175,.885,.32,1.275);pointer-events:none}.demo-card-3d{position:absolute;width:400px;height:380px;background:linear-gradient(145deg,#ffffff1a,#ffffff05);border:2px solid rgba(0,113,227,.3);border-radius:25px;overflow:hidden;display:flex;flex-direction:column;transition:all .6s cubic-bezier(.175,.885,.32,1.275);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transform-style:preserve-3d;box-shadow:0 20px 60px #00000080,inset 0 1px #ffffff1a;pointer-events:auto}.demo-card-3d.active{border-color:#0071e3cc;box-shadow:0 30px 80px #0009,0 0 50px #0071e366,inset 0 1px #fff3}.demo-interface-3d{padding:20px;background:linear-gradient(180deg,#000c,#0006);border-bottom:1px solid rgba(255,255,255,.1)}.prompt-bar-3d{display:flex;align-items:center;background:#ffffff14;border:2px solid rgba(0,113,227,.3);border-radius:20px;padding:12px 18px;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.prompt-text-3d{flex:1;color:#fff;font-size:16px;font-family:SF Mono,Monaco,monospace;position:relative;min-height:20px}.prompt-cursor-3d{position:absolute;top:0;width:2px;height:20px;background:#0071e3;border-radius:1px;transition:left .1s ease}.prompt-cursor-3d.typing{animation:cursorBlink 1s infinite}@keyframes cursorBlink{0%,50%{opacity:1}51%,to{opacity:0}}.generate-btn-3d{background:linear-gradient(135deg,#0071e3,#0056b3);color:#fff;border:none;padding:10px 20px;border-radius:15px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #0071e34d}.generate-btn-3d:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0071e366}.processing-3d{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;margin-top:12px;background:#0071e31a;border-radius:12px;border:1px solid rgba(0,113,227,.3)}.processing-orb{width:10px;height:10px;border-radius:50%;background:radial-gradient(circle,#0071e3,#003d7a);animation:orbPulse 1.5s ease-in-out infinite;box-shadow:0 0 15px #0071e399}@keyframes orbPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.7}}.blob-text-3d{color:#0071e3;font-size:16px;font-weight:500}.loading-dots-3d span{color:#0071e3;opacity:0;animation:dotFade 1.5s infinite}.loading-dots-3d span:nth-child(1){animation-delay:0s}.loading-dots-3d span:nth-child(2){animation-delay:.5s}.loading-dots-3d span:nth-child(3){animation-delay:1s}@keyframes dotFade{0%,to{opacity:0;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.canvas-container-3d{flex:1;position:relative;background:radial-gradient(circle at center,#0071e30d,#000c)}.demo-canvas-3d{width:100%;height:100%;border-radius:0 0 23px 23px}.carousel-controls{display:flex;justify-content:center;align-items:center;gap:30px;margin-top:50px}.control-btn{background:#ffffff1a;border:2px solid rgba(0,113,227,.3);color:#fff;font-size:28px;width:50px;height:50px;border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.control-btn:hover{background:#0071e333;border-color:#0071e399;transform:scale(1.1);box-shadow:0 0 20px #0071e366}.demo-indicators{display:flex;gap:15px}.indicator{width:10px;height:10px;border-radius:50%;background:#ffffff4d;cursor:pointer;transition:all .3s ease;border:1px solid rgba(0,113,227,.3)}.indicator.active{background:#0071e3;width:30px;border-radius:5px;box-shadow:0 0 10px #0071e399}.indicator:hover:not(.active){background:#0071e380;transform:scale(1.2)}@media (max-width: 768px){.demos-section-3d{padding:80px 0 60px;min-height:80vh}.demos-title-3d{font-size:36px;margin-bottom:40px}.carousel-container{height:400px}.carousel-3d,.demo-card-3d{width:320px;height:350px}.demo-interface-3d{padding:15px}.prompt-bar-3d{padding:10px 15px}.prompt-text-3d{font-size:14px}.generate-btn-3d{padding:8px 15px;font-size:12px}.carousel-controls{gap:20px;margin-top:30px}.control-btn{width:40px;height:40px;font-size:20px}}.model-preloader{position:fixed;top:0;left:0;width:100%;height:100%;background:#000;display:flex;align-items:center;justify-content:center;z-index:9999}.preloader-content{text-align:center;color:#fff;max-width:400px;width:90%}.preloader-content h2{font-size:56px;font-weight:600;margin-bottom:2rem;letter-spacing:-.02em;color:#fff;animation:titleGlow 3s ease-in-out infinite alternate}@keyframes titleGlow{0%{filter:drop-shadow(0 0 5px rgba(0,113,227,.3))}to{filter:drop-shadow(0 0 20px rgba(0,113,227,.6))}}.progress-bar{width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;margin-bottom:1rem}.progress-fill{height:100%;background:#0071e3;transition:width .3s ease;border-radius:3px;box-shadow:0 0 10px #0071e399}.preloader-content p{color:#fffc;font-size:.9rem}.landing-wrapper{opacity:0;transition:opacity .5s ease}.landing-wrapper.loaded{opacity:1}@media (prefers-reduced-motion: no-preference){.landing-page{animation:fadeIn .5s ease forwards}}.stats-section-3d{padding:140px 40px;background:#000;position:relative;width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center}.stats-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.stats-container{max-width:1200px;margin:0 auto;position:relative;z-index:2;text-align:center}.stats-title{font-size:56px;font-weight:600;margin-bottom:100px;letter-spacing:-.03em;color:#fff;opacity:0;transform:translateY(30px);animation:fadeInUp 1.2s ease-out .2s forwards;line-height:1.1}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:80px;max-width:1000px;margin:0 auto}.stat-item{position:relative;opacity:0;transform:translateY(50px)}.stat-item.animate{animation:statSlideIn .8s ease-out forwards}.stat-item:nth-child(1){animation-delay:.1s}.stat-item:nth-child(2){animation-delay:.2s}.stat-item:nth-child(3){animation-delay:.3s}.stat-item:nth-child(4){animation-delay:.4s}.stats-number{font-size:88px;font-weight:700;color:#0071e3;margin-bottom:16px;line-height:1;position:relative;filter:drop-shadow(0 0 20px rgba(0,113,227,.4));transition:all .3s ease}.stat-item:hover .stat-number{transform:scale(1.1);filter:drop-shadow(0 0 30px rgba(0,113,227,.6))}.stat-label{font-size:16px;color:#ffffffb3;font-weight:500;letter-spacing:1px;text-transform:uppercase;transition:color .3s ease}.stat-item:hover .stat-label{color:#fff}.stat-line{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);width:60px;height:2px;background:linear-gradient(90deg,transparent,#0071e3,transparent);opacity:0;transition:all .4s ease}.stat-item:hover .stat-line{opacity:1;width:100px}.floating-dot{position:absolute;width:4px;height:4px;background:#0071e3;border-radius:50%;opacity:.6;animation:float 4s ease-in-out infinite}.floating-dot:nth-child(1){top:20%;left:10%;animation-delay:0s}.floating-dot:nth-child(2){top:40%;left:20%;animation-delay:1s}.floating-dot:nth-child(3){top:60%;left:15%;animation-delay:2s}.floating-dot:nth-child(4){top:80%;left:25%;animation-delay:3s}.floating-dot:nth-child(5){top:30%;right:10%;animation-delay:.5s}.floating-dot:nth-child(6){top:50%;right:20%;animation-delay:1.5s}.floating-dot:nth-child(7){top:70%;right:15%;animation-delay:2.5s}.floating-dot:nth-child(8){top:90%;right:25%;animation-delay:3.5s}@keyframes float{0%,to{transform:translateY(0);opacity:.6}50%{transform:translateY(-20px);opacity:1}}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}@keyframes statSlideIn{to{opacity:1;transform:translateY(0)}}.ambient-line{position:absolute;height:1px;background:linear-gradient(90deg,transparent,rgba(0,113,227,.3),transparent);opacity:.5;animation:ambientPulse 3s ease-in-out infinite alternate}.ambient-line-1{top:25%;left:0;right:0;animation-delay:0s}.ambient-line-2{top:75%;left:0;right:0;animation-delay:1.5s}@keyframes ambientPulse{0%{opacity:.2}to{opacity:.6}}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:60px;max-width:600px}.stats-title{font-size:56px;margin-bottom:80px}.stat-number{font-size:72px}}@media (max-width: 768px){.stats-section-3d{padding:100px 20px}.stats-title{font-size:42px;margin-bottom:60px}.stats-grid{grid-template-columns:1fr;gap:50px;max-width:300px}.stat-number{font-size:64px}.stat-label{font-size:14px}}.coming-soon-container{min-height:100vh;background:#000;color:#fff;position:relative;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}.coming-soon-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.coming-soon-nav{position:fixed;top:0;left:0;right:0;height:48px;background:#000c;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:1000;display:flex;align-items:center;padding:0 40px}.nav-logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:600;color:#fff;cursor:pointer;transition:opacity .3s}.nav-logo:hover{opacity:.8}.coming-soon-content{position:relative;z-index:2;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:80px 40px 40px}.coming-soon-main{max-width:600px;text-align:center;animation:fadeInUp 1s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.coming-soon-title{font-size:72px;font-weight:600;line-height:1.1;margin-bottom:24px;letter-spacing:-.02em}.coming-soon-title span{display:block}.gradient-text{background:linear-gradient(135deg,#0071e3,#00d4aa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.coming-soon-subtitle{font-size:24px;color:#86868b;margin-bottom:48px;font-weight:400;line-height:1.4}.launch-countdown{display:flex;justify-content:center;margin-bottom:48px}.countdown-item{text-align:center;padding:24px 48px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.countdown-number{font-size:48px;font-weight:600;color:#0071e3;margin-bottom:8px}.countdown-label{font-size:18px;color:#86868b;text-transform:uppercase;letter-spacing:.1em}.notify-form{margin-bottom:48px}.form-group{display:flex;gap:12px;max-width:400px;margin:0 auto}.email-input{flex:1;padding:14px 20px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:980px;color:#fff;font-size:16px;outline:none;transition:all .3s}.email-input::placeholder{color:#86868b}.email-input:focus{background:#ffffff14;border-color:#0071e3}.email-input:disabled{opacity:.6;cursor:not-allowed}.notify-button{padding:14px 30px;background:#0071e3;color:#fff;border:none;border-radius:980px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s;white-space:nowrap;min-width:120px}.notify-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #0071e34d}.notify-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.message{margin-top:16px;font-size:14px;animation:fadeIn .5s ease-out;padding:12px 20px;border-radius:12px;font-weight:500}.success-message{color:#00d4aa;background:#00d4aa1a;border:1px solid rgba(0,212,170,.2)}.promo-message{color:gold;background:linear-gradient(135deg,#ffd7001a,#0071e31a);border:1px solid rgba(255,215,0,.3);animation:promoGlow 2s ease-in-out infinite alternate}.error-message{color:#ff6b6b;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.2)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes promoGlow{0%{box-shadow:0 0 5px #ffd70033}to{box-shadow:0 0 20px #ffd70066}}.features-preview{margin-bottom:48px;padding:32px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.features-preview h3{font-size:20px;margin-bottom:24px;color:#fff}.feature-list{display:flex;flex-direction:column;gap:16px;text-align:left}.feature-item{display:flex;align-items:center;gap:12px;color:#86868b;font-size:16px;transition:color .3s}.feature-item:hover{color:#fff}.feature-icon{font-size:24px;min-width:32px}.back-button{padding:12px 24px;background:transparent;color:#86868b;border:1px solid rgba(255,255,255,.1);border-radius:980px;font-size:14px;cursor:pointer;transition:all .3s}.back-button:hover{color:#fff;border-color:#ffffff4d}@media (max-width: 768px){.coming-soon-nav{padding:0 20px}.coming-soon-content{padding:80px 20px 40px}.coming-soon-title{font-size:48px}.coming-soon-subtitle{font-size:18px}.form-group{flex-direction:column;max-width:320px}.email-input,.notify-button{width:100%}.countdown-item{padding:20px 32px}.countdown-number{font-size:36px}.features-preview{padding:24px}.feature-item{font-size:14px}.feature-icon{font-size:20px;min-width:28px}}
