*{box-sizing:border-box}*,body{margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Roboto,sans-serif;overflow-x:hidden}#root,body,html{background:#1a1d29}#root{min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:var(--bg-primary);display:flex;font-family:Inter,Roboto,sans-serif;justify-content:center;min-height:100vh;transition:background-color .3s ease}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:var(--shadow-md);max-width:420px;padding:3rem 2.5rem;transition:all .3s ease;width:100%}.login-header{border-bottom:1px solid var(--border-primary);margin-bottom:2.5rem;padding-bottom:1.5rem;text-align:center}.login-header h1{color:var(--text-primary);font-size:1.8rem;font-weight:700;letter-spacing:4px;margin:0 0 .5rem;transition:color .3s ease}.login-form{margin-bottom:2rem}.login-button{background:linear-gradient(135deg,var(--accent-orange) 0,var(--accent-orange-dark) 100%);border:none;border-radius:6px;box-shadow:var(--shadow-sm);color:var(--bg-primary);cursor:pointer;font-size:.85rem;font-weight:700;letter-spacing:2px;padding:1rem;text-transform:uppercase;transition:all .3s ease;width:100%}.login-button:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.signup-section{border-top:1px solid var(--border-primary);padding-top:1.5rem;text-align:center}.signup-text{margin-right:.5rem;transition:color .3s ease}.signup-link,.signup-text{color:var(--text-tertiary);font-size:.85rem}.signup-link{background:none;border:none;cursor:pointer;font-weight:600;letter-spacing:1px;padding:0;text-transform:uppercase;transition:all .3s ease}.signup-link:hover{color:var(--text-secondary)}.theme-toggle-fab{align-items:center;background:#0000;border:1px solid var(--border-secondary);border-radius:20px;box-shadow:var(--shadow-md);cursor:pointer;display:flex;justify-content:center;padding:0;position:fixed;right:2rem;top:2rem;transition:all .3s ease;z-index:1000}.theme-toggle-fab:hover{border-color:var(--accent-primary);box-shadow:0 0 20px #00ffa34d;transform:scale(1.05)}.signup-container{align-items:center;background:var(--bg-primary);display:flex;font-family:Inter,Roboto,sans-serif;justify-content:center;min-height:100vh;transition:background-color .3s ease}.signup-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:var(--shadow-md);max-width:420px;padding:3rem 2.5rem;transition:all .3s ease;width:100%}.signup-header{border-bottom:1px solid var(--border-primary);margin-bottom:2.5rem;padding-bottom:1.5rem;text-align:center}.signup-header h1{color:var(--text-primary);font-size:1.8rem;font-weight:700;letter-spacing:4px;margin:0 0 .5rem;transition:color .3s ease}.subtitle{color:var(--text-tertiary);font-size:.75rem;font-weight:400;letter-spacing:2px;margin:0;text-transform:uppercase;transition:color .3s ease}.signup-form{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-secondary);display:block;font-size:.7rem;font-weight:600;letter-spacing:1.5px;margin-bottom:.5rem;text-transform:uppercase;transition:color .3s ease}.form-group input{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:6px;box-sizing:border-box;color:var(--text-primary);font-family:Inter,Roboto,monospace;font-size:.95rem;padding:.875rem 1rem;transition:all .3s ease;width:100%}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{background:var(--bg-quaternary);border-color:var(--text-quaternary);box-shadow:0 0 0 1px var(--hover-bg);outline:none}.error-message{background:var(--accent-red-dark);border:1px solid var(--accent-red);border-radius:6px;color:var(--accent-red);margin-bottom:1rem;padding:.75rem;text-align:center}.error-message,.signup-button{font-size:.85rem;transition:all .3s ease}.signup-button{background:linear-gradient(135deg,var(--accent-orange) 0,var(--accent-orange-dark) 100%);border:none;border-radius:6px;box-shadow:var(--shadow-sm);color:var(--bg-primary);cursor:pointer;font-weight:700;letter-spacing:2px;padding:1rem;text-transform:uppercase;width:100%}.signup-button:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.signup-button:active{transform:translateY(0)}.login-section{border-top:1px solid var(--border-primary);padding-top:1.5rem;text-align:center}.login-text{margin-right:.5rem;transition:color .3s ease}.login-link,.login-text{color:var(--text-tertiary);font-size:.85rem}.login-link{background:none;border:none;cursor:pointer;font-weight:600;letter-spacing:1px;padding:0;text-transform:uppercase;transition:all .3s ease}.login-link:hover{color:var(--text-secondary)}:root[data-theme=dark]{--bg-primary:#1a1d29;--bg-secondary:#191c26cc;--bg-tertiary:#14172199;--bg-quaternary:#0f1219cc;--bg-overlay:#191c26f2;--text-primary:#e2e8f0;--text-secondary:#cbd5e1;--text-tertiary:#94a3b8;--text-quaternary:#64748b;--text-muted:#475569;--border-primary:#3c41504d;--border-secondary:#3c415066;--border-tertiary:#3c415080;--border-dashed:#3c415066;--accent-primary:#00ffa3;--accent-secondary:#00c27a;--accent-orange:#ff8c42;--accent-orange-dark:#ff6b35;--accent-red:#ff6b6b;--accent-red-dark:#ff6b6b4d;--hover-bg:#64748b4d;--hover-border:#64748b99;--active-bg:#3c41504d;--shadow-sm:0 4px 12px #0000004d;--shadow-md:0 8px 20px #0006;--shadow-lg:0 20px 60px #0009;--shadow-panel:4px 0 15px #00000080;--shadow-accent-cyan:0 4px 12px #00ffa333;--shadow-accent-cyan-hover:0 6px 16px #00ffa34d;--shadow-accent-orange:0 4px 12px #ff8c424d;--shadow-accent-orange-hover:0 6px 16px #ff8c4266}:root[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#fffffff2;--bg-tertiary:#f1f5f9e6;--bg-quaternary:#ffffffe6;--bg-overlay:#fffffffa;--text-primary:#0f172a;--text-secondary:#1e293b;--text-tertiary:#334155;--text-quaternary:#64748b;--text-muted:#94a3b8;--border-primary:#94a3b840;--border-secondary:#94a3b859;--border-tertiary:#64748b66;--border-dashed:#94a3b84d;--accent-primary:#00c27a;--accent-secondary:#00a365;--accent-orange:#ff8c42;--accent-orange-dark:#ff6b35;--accent-red:#dc2626;--accent-red-dark:#dc262626;--hover-bg:#94a3b826;--hover-border:#64748b66;--active-bg:#94a3b833;--shadow-sm:0 2px 8px #0f172a14;--shadow-md:0 4px 16px #0f172a1f;--shadow-lg:0 10px 40px #0f172a26;--shadow-panel:2px 0 12px #0f172a1a;--shadow-accent-cyan:0 4px 12px #10b98133;--shadow-accent-cyan-hover:0 6px 16px #10b9814d;--shadow-accent-orange:0 4px 12px #f9731640;--shadow-accent-orange-hover:0 6px 16px #f9731659}.theme-toggle{align-items:center;background:#0000;border:1px solid var(--border-secondary);border-radius:20px;cursor:pointer;display:flex;justify-content:center;padding:0;transition:all .3s ease}.theme-toggle:hover{border-color:var(--accent-primary);box-shadow:0 0 12px #00ffa333}.theme-toggle-track{align-items:center;background:var(--bg-tertiary);border-radius:20px;display:flex;height:24px;padding:0 2px;position:relative;transition:all .3s ease;width:48px}:root[data-theme=dark] .theme-toggle-track{background:linear-gradient(135deg,#1e293b,#334155)}:root[data-theme=light] .theme-toggle-track{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.theme-toggle-thumb{align-items:center;background:var(--accent-primary);border-radius:50%;box-shadow:0 2px 8px #0003;color:var(--bg-primary);display:flex;height:20px;justify-content:center;position:absolute;transition:all .4s cubic-bezier(.34,1.56,.64,1);width:20px}:root[data-theme=dark] .theme-toggle-thumb{background:linear-gradient(135deg,#00ffa3,#00c27a);left:2px}:root[data-theme=light] .theme-toggle-thumb{background:linear-gradient(135deg,#fbbf24,#f59e0b);left:26px}.theme-toggle-thumb svg{stroke:none;height:14px;width:14px}.dashboard-container{background:var(--bg-primary);display:flex;flex-direction:column;font-family:Inter,Roboto,sans-serif;height:100vh;min-height:100vh;overflow:hidden;transition:background-color .3s ease}.dashboard-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);flex-shrink:0;justify-content:space-between;padding:1rem 2rem;transition:all .3s ease}.dashboard-header,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.back-button{align-items:center;background:#0000;border:1px solid var(--border-tertiary);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .3s ease;width:36px}.back-button:hover{background:var(--hover-bg);border-color:var(--accent-primary);color:var(--accent-primary)}.brand-container{display:flex;flex-direction:column}.brand-container h1{color:var(--text-primary);font-size:1.2rem;font-weight:700;letter-spacing:3px;margin:0;transition:color .3s ease}.panel-toggle{align-items:center;background:#0000;border:1px solid var(--border-tertiary);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .3s ease;width:36px}.panel-toggle.active,.panel-toggle:hover{background:var(--active-bg);border-color:var(--text-primary);color:var(--text-primary)}.header-subtitle{color:var(--text-tertiary);font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;transition:color .3s ease}.logout-button{background:var(--accent-red-dark);border:1px solid var(--border-secondary);border-radius:6px;color:var(--accent-red);cursor:pointer;font-size:.75rem;font-weight:600;letter-spacing:1px;padding:.5rem 1rem;transition:all .3s ease;white-space:nowrap}.logout-button:hover{background:var(--hover-bg);border-color:var(--accent-red)}.header-right{gap:.75rem;margin-left:auto}.files-button,.header-right{align-items:center;display:flex}.files-button{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:.75rem;font-weight:600;gap:.5rem;letter-spacing:1px;padding:.5rem 1rem;transition:all .3s ease;white-space:nowrap}.files-button:hover{background:var(--hover-bg);border-color:var(--hover-border);color:var(--text-primary)}.new-chat-button{background:linear-gradient(135deg,var(--accent-primary) 0,var(--accent-secondary) 100%);border:none;border-radius:6px;color:var(--bg-primary);cursor:pointer;font-size:.75rem;font-weight:700;letter-spacing:.5px;padding:.5rem 1rem;transition:all .3s ease;white-space:nowrap}.new-chat-button:hover{box-shadow:0 4px 12px #00ffa34d;transform:translateY(-1px)}.history-toggle-button{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:.75rem;font-weight:600;letter-spacing:1px;padding:.5rem 1rem;transition:all .3s ease;white-space:nowrap}.history-toggle-button.active{background:var(--active-bg);border-color:var(--text-secondary);color:var(--text-primary)}.dashboard-content{flex:1 1;min-height:0}.dashboard-content,.left-panel{display:flex;overflow:hidden;position:relative}.left-panel{background:var(--bg-overlay);border-right:1px solid var(--border-primary);flex-direction:column;flex-shrink:0;gap:0;padding:0;transition:all .3s ease;width:380px;z-index:20}.left-panel.hidden{border-right:none;overflow:hidden;padding:0;width:0!important}.horizontal-resize-handle{align-items:center;background:#0000;bottom:0;cursor:col-resize;display:flex;justify-content:center;position:absolute;right:0;top:0;transition:background .2s ease;-webkit-user-select:none;user-select:none;width:8px;z-index:10}.horizontal-resize-handle:hover{background:var(--hover-bg)}.horizontal-resize-handle:active{background:var(--active-bg);cursor:col-resize}.resize-handle-dots{display:flex;flex-direction:column;gap:3px;pointer-events:none}.resize-handle-dots .dot{background:var(--text-quaternary);border-radius:50%;height:3px;transition:background .2s ease;width:3px}.horizontal-resize-handle:hover .dot{background:var(--text-secondary)}.vertical-resize-handle{align-items:center;background:var(--border-primary);border-bottom:1px solid var(--border-tertiary);border-top:1px solid var(--border-tertiary);cursor:row-resize;display:flex;flex-shrink:0;height:12px;justify-content:center;position:relative;transition:background .2s ease;-webkit-user-select:none;user-select:none;z-index:5}.vertical-resize-handle:hover{background:var(--hover-bg)}.vertical-resize-handle:active{background:#00ffa333;cursor:row-resize}.resize-handle-line{background:var(--text-quaternary);border-radius:2px;height:3px;pointer-events:none;transition:all .2s ease;width:50px}.vertical-resize-handle:hover .resize-handle-line{background:var(--accent-primary);height:4px;width:70px}.left-panel::-webkit-scrollbar{width:6px}.left-panel::-webkit-scrollbar-track{background:var(--bg-tertiary)}.left-panel::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:3px;-webkit-transition:background .2s ease;transition:background .2s ease}.left-panel::-webkit-scrollbar-thumb:hover{background:var(--text-quaternary)}.image-section{background:var(--bg-tertiary);border:none;display:flex;flex:1 1;flex-direction:column;min-height:0;min-height:150px;overflow:hidden;padding:1rem;transition:background .3s ease}.image-section.input-section{border-bottom:none}.section-header{flex-shrink:0;margin-bottom:1rem}.section-title{color:var(--text-secondary);font-size:.7rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;transition:color .3s ease}.image-container{align-items:center;background:var(--bg-quaternary);border:1px dashed var(--border-dashed);border-radius:6px;display:flex;flex:1 1;justify-content:center;min-height:100px;overflow:hidden;transition:all .3s ease}.preview-image{max-height:100%;max-width:100%;object-fit:contain;transition:transform .3s ease,opacity .3s ease}.preview-image.clickable{cursor:pointer}.preview-image.clickable:hover{opacity:.95;transform:scale(1.02)}@media (max-width:768px){.preview-image.clickable:hover{transform:none}.preview-image.clickable:active{opacity:.9}}.image-placeholder{align-items:center;color:var(--text-quaternary);display:flex;flex-direction:column;gap:.5rem;text-align:center}.image-placeholder span{color:var(--text-tertiary);font-size:.85rem}.upload-button{background:linear-gradient(135deg,var(--accent-orange) 0,var(--accent-orange-dark) 100%);border:none;border-radius:6px;color:var(--bg-primary);cursor:pointer;display:block;font-size:.75rem;font-weight:700;letter-spacing:1.5px;padding:.75rem;text-align:center;text-transform:uppercase;transition:all .3s ease;width:100%}.upload-button:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.center-panel{background:var(--bg-tertiary);min-width:0;overflow:hidden;transition:background .3s ease}.center-panel,.chat-messages{display:flex;flex:1 1;flex-direction:column}.chat-messages{gap:1rem;min-height:0;overflow-x:hidden;overflow-y:auto;padding:2rem}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:var(--bg-tertiary)}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--text-quaternary)}.empty-state{align-items:center;color:var(--text-quaternary);display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state h3{color:var(--text-secondary);font-size:1.2rem;font-weight:600;letter-spacing:2px;margin:0 0 .5rem;transition:color .3s ease}.empty-state p{color:var(--text-tertiary);font-size:.9rem;transition:color .3s ease}.message{display:flex;margin-bottom:1rem}.message.user{justify-content:flex-end}.message.bot{justify-content:flex-start}.message-content{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;display:flex;flex-direction:column;gap:.5rem;max-width:70%;padding:1rem;transition:all .3s ease}.message.user .message-content{background:#ff8c4226;border-color:#ff8c424d}.message-text{color:var(--text-primary);font-size:.95rem;line-height:1.5;transition:color .3s ease}.message-time{align-self:flex-end;color:var(--text-quaternary);font-size:.75rem;transition:color .3s ease}.chat-input-container{background:var(--bg-secondary);border-top:1px solid var(--border-primary);gap:1rem;padding:1.5rem 2rem}.attach-button,.chat-input-container{align-items:center;display:flex;flex-shrink:0;transition:all .3s ease}.attach-button{background:#0000;border:1px solid var(--border-secondary);border-radius:50%;color:var(--text-secondary);cursor:pointer;height:40px;justify-content:center;width:40px}.attach-button:hover{background:var(--hover-bg);border-color:var(--accent-primary);color:var(--accent-primary)}.chat-input{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-primary);flex:1 1;font-family:Inter,Roboto,monospace;font-size:.95rem;padding:.875rem 1rem;transition:all .3s ease}.chat-input::placeholder{color:var(--text-muted)}.chat-input:focus{background:var(--bg-quaternary);border-color:var(--text-quaternary);outline:none}.send-button{align-items:center;background:linear-gradient(135deg,var(--accent-orange) 0,var(--accent-orange-dark) 100%);border:none;border-radius:6px;color:var(--bg-primary);cursor:pointer;display:flex;justify-content:center;padding:.875rem 1.5rem;transition:all .3s ease}.send-button:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.right-panel{background:var(--bg-overlay);border-left:1px solid var(--border-primary);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;transition:all .3s ease;width:280px;z-index:20}.right-panel.hidden{border-left:none;width:0}.history-header{align-items:center;border-bottom:1px solid var(--border-primary);display:flex;flex-shrink:0;justify-content:space-between;padding:1rem}.history-list{display:flex;flex:1 1;flex-direction:column;gap:.75rem;min-height:0;overflow-y:auto;padding:1rem}.history-list::-webkit-scrollbar{width:6px}.history-list::-webkit-scrollbar-track{background:var(--bg-tertiary)}.history-list::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:3px}.history-list::-webkit-scrollbar-thumb:hover{background:var(--text-quaternary)}.history-item{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;display:flex;flex-direction:column;gap:.25rem;padding:.875rem;transition:all .3s ease}.history-item:hover{background:var(--bg-quaternary);border-color:var(--border-tertiary)}.history-title{color:var(--text-primary);font-size:.85rem;font-weight:500;transition:color .3s ease}.history-date{color:var(--text-quaternary);font-size:.75rem;transition:color .3s ease}.files-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);bottom:0;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.files-modal,.files-modal-overlay{background:var(--bg-overlay);display:flex}.files-modal{animation:modalSlideIn .3s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-primary);border-radius:16px;box-shadow:var(--shadow-lg);flex-direction:column;max-height:80vh;max-width:800px;transition:all .3s ease;width:100%}.files-modal-header{align-items:center;border-bottom:1px solid var(--border-primary);display:flex;flex-shrink:0;justify-content:space-between;padding:1.5rem 2rem}.files-modal-header h3{color:var(--text-primary);font-size:1.4rem;font-weight:600;letter-spacing:1px;margin:0;transition:color .3s ease}.files-modal-content{flex:1 1;overflow-y:auto;padding:1.5rem 2rem}.files-modal-content::-webkit-scrollbar{width:8px}.files-modal-content::-webkit-scrollbar-track{background:var(--bg-tertiary)}.files-modal-content::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px}.files-modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-quaternary)}.no-files{align-items:center;color:var(--text-quaternary);display:flex;flex-direction:column;justify-content:center;padding:3rem;text-align:center}.no-files svg{margin-bottom:1rem}.no-files p{color:var(--text-tertiary);font-size:1rem;transition:color .3s ease}.files-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));padding:.5rem 0}.file-item{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.file-item:hover{border-color:var(--border-tertiary);box-shadow:var(--shadow-md);transform:translateY(-4px)}.file-image,.file-item-image{background:var(--bg-quaternary);overflow:hidden;padding-bottom:75%;position:relative;width:100%}.file-image img,.file-item-image img{height:100%;left:0;object-fit:cover;position:absolute;top:0;transition:transform .3s ease;width:100%}.file-item:hover .file-image img,.file-item:hover .file-item-image img{transform:scale(1.05)}.file-badge,.file-item-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:6px;font-size:.65rem;font-weight:700;letter-spacing:.5px;padding:.25rem .6rem;position:absolute;right:.5rem;text-transform:uppercase;top:.5rem;z-index:1}.file-badge.input,.file-item-badge[data-type=input]{background:#ff8c4240;border:1px solid #ff8c4280;color:var(--accent-orange)}.file-badge.output,.file-item-badge[data-type=output]{background:#00ffa340;border:1px solid #00ffa380;color:var(--accent-primary)}.file-info,.file-item-info{align-items:center;background:var(--bg-tertiary);border-top:1px solid var(--border-primary);display:flex;justify-content:center;padding:.75rem}.file-item-time,.file-time{color:var(--text-tertiary);font-size:.7rem;font-weight:500;letter-spacing:.3px;transition:color .3s ease}.empty-files{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;justify-content:center;padding:3rem 2rem;text-align:center}.empty-files svg{stroke:var(--text-quaternary);margin-bottom:1rem;opacity:.5}.empty-files p{font-size:1rem;letter-spacing:.3px;margin:0}@media (max-width:1024px){.left-panel{bottom:0;box-shadow:4px 0 15px #00000080;left:0;position:absolute;top:0;transform:translateX(0);width:320px;z-index:30}.left-panel.hidden{transform:translateX(-100%);width:320px}.right-panel{bottom:0;box-shadow:-4px 0 15px #00000080;position:absolute;right:0;top:0;transform:translateX(0);width:280px;z-index:30}.right-panel.hidden{transform:translateX(100%);width:280px}.center-panel{width:100%}.horizontal-resize-handle{display:none}}@media (max-width:768px){.dashboard-container{padding-bottom:50px}.dashboard-header{flex-wrap:nowrap;gap:.5rem;padding:.5rem .75rem}.header-left{flex-shrink:0;gap:.5rem}.header-subtitle{display:none}.brand-container h1{font-size:.9rem;letter-spacing:2px}.history-toggle-button,.panel-toggle{display:none}.header-right{flex-shrink:0;gap:.5rem;margin-left:auto}.files-button,.logout-button,.new-chat-button{align-items:center;color:#0000;display:flex;font-size:0;height:36px;justify-content:center;min-width:36px;overflow:visible;padding:0;position:relative;width:36px}.files-button:before{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23cbd5e1' stroke-width='2'%3E%3Cpath d='M13 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V9z'/%3E%3Cpath d='M13 2v7h7'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:contain;content:"";display:block;height:18px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:18px}.logout-button:before{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff6b6b' stroke-width='2'%3E%3Cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4M16 17l5-5-5-5M21 12H9'/%3E%3C/svg%3E")}.logout-button:before,.new-chat-button:before{background-position:50%;background-repeat:no-repeat;background-size:contain;content:"";display:block;height:20px;width:20px}.new-chat-button:before{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a0e1a' stroke-width='2.5'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E")}.center-panel,.left-panel,.right-panel{bottom:0;box-shadow:none;left:0;max-width:100%!important;opacity:0;pointer-events:none;position:absolute!important;right:0;top:0;transform:translateX(0)!important;transition:opacity .3s ease;width:100%!important}.center-panel.mobile-active,.left-panel.mobile-active,.right-panel.mobile-active{opacity:1;pointer-events:auto;z-index:10}.horizontal-resize-handle,.vertical-resize-handle{display:none}.left-panel .image-section{flex:1 1!important}.image-container{padding:1rem}.chat-input-container{gap:.75rem;padding:1rem}.chat-input{font-size:16px;padding:.875rem 1rem}.attach-button,.send-button{height:44px;min-width:44px;padding:0;width:44px}.send-button svg{stroke-width:2.5}.attach-button svg,.send-button svg{height:22px;width:22px}.chat-messages{padding:1rem}.message{max-width:85%}.history-list{padding:0}.history-item{font-size:.95rem;padding:1rem}.files-modal{border-radius:0;height:100vh;max-height:100vh;max-width:100vw;width:100vw}.files-modal-content,.files-modal-header{padding:1rem}.files-grid{gap:.875rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.file-image,.file-item-image{padding-bottom:75%}}@media (max-width:480px){.dashboard-header{padding:.5rem}.brand-container h1{font-size:.875rem;letter-spacing:2px}.files-button,.logout-button,.new-chat-button{height:28px;width:28px}.files-button:before{height:16px;width:16px}.logout-button:before,.new-chat-button:before{height:18px;width:18px}.chat-input{font-size:14px;padding:.75rem}.message{max-width:90%}.files-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.file-image,.file-item-image{padding-bottom:80%}.file-badge,.file-item-badge{font-size:.6rem;padding:.2rem .5rem;right:.4rem;top:.4rem}.file-info,.file-item-info{padding:.6rem}.file-item-time,.file-time{font-size:.65rem}.files-modal{border-radius:12px;max-height:85vh;max-width:95%}.files-modal-header{padding:1rem 1.25rem}.files-modal-header h3{font-size:1.1rem}.files-modal-content{padding:1rem}.files-grid{gap:.75rem}}@media (max-width:768px) and (orientation:landscape){.dashboard-container{padding-bottom:50px}.mobile-nav{padding:.25rem 0}.mobile-nav-btn{font-size:.65rem;padding:.5rem}.mobile-nav-btn svg{height:18px;width:18px}.image-section{flex-direction:row!important}.image-section .image-container{flex:1 1}}@media (hover:none) and (pointer:coarse){.back-button,.modal-close-btn,.panel-toggle{height:44px;width:44px}.file-item,.history-item{min-height:44px}.attach-button:hover,.back-button:hover,.files-button:hover,.logout-button:hover,.new-chat-button:hover,.panel-toggle:hover,.send-button:hover{transform:none}.attach-button:active,.back-button:active,.panel-toggle:active,.send-button:active{opacity:.7;transform:scale(.95)}}.chat-history-view{background:var(--bg-primary);display:flex;flex-direction:column;font-family:Inter,Roboto,sans-serif;min-height:100vh;transition:background-color .3s ease}.history-view-header{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);display:flex;flex-shrink:0;gap:1rem;justify-content:space-between;padding:1rem 2rem;transition:all .3s ease}.history-view-header .brand-container h1{color:var(--text-primary);font-size:1.2rem;font-weight:700;letter-spacing:3px;margin:0;transition:color .3s ease}.history-view-header .header-subtitle{color:var(--text-tertiary);font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;transition:color .3s ease}.history-view-content{flex:1 1;margin:0 auto;max-width:1400px;overflow-y:auto;padding:2rem 3rem;width:100%}.history-view-top{align-items:center;border-bottom:1px solid var(--border-secondary);display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.history-view-title{color:var(--text-primary);font-size:1.8rem;font-weight:600;letter-spacing:1px;margin:0;transition:color .3s ease}.new-chat-btn{align-items:center;background:linear-gradient(135deg,var(--accent-primary) 0,var(--accent-secondary) 100%);border:none;border-radius:8px;box-shadow:var(--shadow-accent-cyan);color:var(--bg-primary);cursor:pointer;display:flex;font-size:.9rem;font-weight:700;gap:.5rem;letter-spacing:.5px;padding:.75rem 1.5rem;transition:all .3s ease}.new-chat-btn:hover{box-shadow:var(--shadow-accent-cyan-hover);transform:translateY(-2px)}.chat-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));padding-bottom:2rem}.chat-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:12px;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.chat-card:hover{border-color:var(--border-tertiary);box-shadow:var(--shadow-md);transform:translateY(-4px)}.chat-card-image{background:var(--bg-tertiary);height:200px;overflow:hidden;position:relative;width:100%}.chat-card-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.chat-card:hover .chat-card-image img{transform:scale(1.05)}.chat-card-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:50%;color:var(--accent-primary);display:flex;height:40px;justify-content:center;opacity:0;position:absolute;right:.75rem;top:.75rem;transition:opacity .3s ease;width:40px}.chat-card:hover .chat-card-overlay{opacity:1}.chat-card-content{display:flex;flex-direction:column;gap:.5rem;padding:1.25rem}.chat-card-title{color:var(--text-primary);font-size:1.1rem;font-weight:600;letter-spacing:.5px;margin:0;transition:color .3s ease}.chat-card-preview{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-tertiary);display:-webkit-box;font-size:.85rem;line-height:1.4;margin:0;overflow:hidden;text-overflow:ellipsis;transition:color .3s ease}.chat-card-date{color:var(--text-quaternary);font-size:.75rem;letter-spacing:.5px;margin-top:.25rem;transition:color .3s ease}.upload-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:var(--bg-overlay);bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.upload-modal{animation:modalSlideIn .3s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-overlay);border:1px solid var(--border-primary);border-radius:16px;box-shadow:var(--shadow-lg);max-width:600px;transition:all .3s ease;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.upload-modal-header{align-items:center;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;padding:1.5rem 2rem}.upload-modal-header h3{color:var(--text-primary);font-size:1.4rem;font-weight:600;letter-spacing:1px;margin:0;transition:color .3s ease}.modal-close-btn{align-items:center;background:#0000;border:1px solid var(--border-tertiary);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .3s ease;width:36px}.modal-close-btn:hover{background:var(--accent-red-dark);border-color:var(--accent-red);color:var(--accent-red)}.upload-modal-content{display:flex;flex-direction:column;gap:1.5rem;padding:2rem}.upload-area{min-height:320px}.upload-area,.upload-label{align-items:center;display:flex;justify-content:center}.upload-label{background:var(--bg-tertiary);border:2px dashed var(--border-dashed);border-radius:12px;color:var(--text-tertiary);cursor:pointer;flex-direction:column;gap:1rem;height:320px;transition:all .3s ease;width:100%}.upload-label:hover{background:var(--bg-quaternary);border-color:var(--border-tertiary);color:var(--text-secondary)}.upload-text{font-size:1.1rem;font-weight:600;letter-spacing:.5px}.upload-hint{color:var(--text-quaternary);font-size:.85rem;transition:color .3s ease}.uploaded-preview{display:flex;flex-direction:column;gap:1rem;width:100%}.uploaded-preview img{background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:12px;height:320px;object-fit:contain;width:100%}.change-image-btn{align-self:center;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:.75rem 1.5rem;transition:all .3s ease}.change-image-btn:hover{background:var(--hover-bg);border-color:var(--border-tertiary)}.start-chat-btn{align-items:center;background:linear-gradient(135deg,var(--accent-orange) 0,var(--accent-orange-dark) 100%);border:none;border-radius:8px;box-shadow:var(--shadow-accent-orange);color:var(--bg-primary);cursor:pointer;display:flex;font-size:1rem;font-weight:700;gap:.5rem;justify-content:center;letter-spacing:1px;padding:1rem 1.5rem;transition:all .3s ease;width:100%}.start-chat-btn:hover{box-shadow:var(--shadow-accent-orange-hover);transform:translateY(-2px)}@media (max-width:768px){.history-view-content{padding:1.5rem 1rem}.history-view-top{align-items:flex-start;flex-direction:column;gap:1rem}.new-chat-btn{justify-content:center;width:100%}.chat-grid{grid-template-columns:1fr}.upload-modal{max-width:95%}.upload-modal-content{padding:1.5rem}.upload-area,.upload-label,.uploaded-preview img{height:240px;min-height:240px}}@media (max-width:480px){.history-view-header{padding:1rem}.history-view-title{font-size:1.4rem}.new-chat-btn{font-size:.85rem;padding:.65rem 1.25rem}}.image-viewer-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000f2;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:200}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-viewer-modal{height:90vh;max-height:800px;max-width:1200px;position:relative;width:90vw}.image-viewer-modal,.viewer-close-btn{align-items:center;display:flex;justify-content:center}.viewer-close-btn{background:#191c26e6;border:1px solid #3c415080;border-radius:50%;color:#cbd5e1;cursor:pointer;height:44px;position:absolute;right:1rem;top:1rem;transition:all .3s ease;width:44px;z-index:10}.viewer-close-btn:hover{background:#ff6b6b33;border-color:#ff6b6b66;color:#ff6b6b;transform:rotate(90deg)}.viewer-image-container{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;position:relative;width:100%}.viewer-image{border-radius:8px;box-shadow:0 10px 40px #0009;max-height:calc(100% - 60px);max-width:100%;object-fit:contain}.viewer-label{border:1px solid #3c415080;border-radius:20px;font-size:.875rem;font-weight:600;letter-spacing:1px;margin-top:1rem;padding:.5rem 1.5rem;text-transform:uppercase}.viewer-label,.viewer-nav-btn{background:#191c26e6;color:#cbd5e1}.viewer-nav-btn{align-items:center;border:1px solid #3c415080;border-radius:50%;cursor:pointer;display:flex;height:48px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:48px;z-index:10}.viewer-nav-btn:hover{background:#64748b66;border-color:#00ffa3;color:#00ffa3;transform:translateY(-50%) scale(1.1)}.viewer-nav-btn:active{transform:translateY(-50%) scale(.95)}.viewer-nav-btn.prev{left:1rem}.viewer-nav-btn.next{right:1rem}.viewer-indicator{background:#191c26e6;border:1px solid #3c415080;border-radius:20px;bottom:1rem;color:#cbd5e1;font-size:.875rem;font-weight:600;left:50%;letter-spacing:1px;padding:.5rem 1.5rem;position:absolute;transform:translateX(-50%)}@media (max-width:768px){.image-viewer-modal{height:100vh;max-height:100vh;max-width:100vw;width:100vw}.viewer-close-btn{right:.5rem;top:.5rem}.viewer-close-btn,.viewer-nav-btn{height:40px;width:40px}.viewer-nav-btn.prev{left:.5rem}.viewer-nav-btn.next{right:.5rem}.viewer-indicator,.viewer-label{font-size:.75rem;padding:.375rem 1rem}.viewer-indicator{bottom:4.5rem}.viewer-image{max-height:calc(100% - 120px)}}@media (hover:none) and (pointer:coarse){.viewer-nav-btn:hover{transform:translateY(-50%) scale(1)}.viewer-nav-btn:active{opacity:.7}}.mobile-nav{safe-area-inset-bottom:env(safe-area-inset-bottom);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-secondary);border-top:1px solid var(--border-secondary);bottom:0;box-shadow:0 -4px 20px var(--shadow-sm);display:none;left:0;padding:.25rem 0;position:fixed;right:0;transition:all .3s ease;z-index:100}.mobile-nav-btn{align-items:center;background:#0000;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:.65rem;font-weight:600;gap:.25rem;justify-content:center;letter-spacing:.3px;min-height:50px;padding:.35rem .25rem;text-transform:uppercase;transition:all .3s ease;white-space:nowrap}.mobile-nav-btn svg{stroke:currentColor;flex-shrink:0;height:20px;transition:all .3s ease;width:20px}.mobile-nav-btn span{display:block;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis}.mobile-nav-btn:disabled{cursor:not-allowed;opacity:.4}.mobile-nav-btn:not(:disabled):hover{color:var(--text-secondary)}.mobile-nav-btn.active{color:var(--accent-primary)}.mobile-nav-btn.active svg{filter:drop-shadow(0 0 6px rgba(0,255,163,.4));transform:scale(1.1)}@media (max-width:768px){.mobile-nav{display:flex}}
/*# sourceMappingURL=main.161cf6aa.css.map*/