@import"https://fonts.googleapis.com/css2?family=SF+Pro+Display:wght@400;500;600&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-tertiary: #262626;--text-primary: #fafafa;--text-secondary: #a3a3a3;--text-muted: #737373;--accent: #3b82f6;--accent-hover: #2563eb;--border: #262626;--user-bubble: #3b82f6;--assistant-bubble: #262626;--success: #22c55e;--error: #ef4444}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}.loading-screen{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-secondary)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,var(--bg-primary) 0%,#1a1a2e 100%)}.auth-card{width:100%;max-width:380px;padding:2.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px}.auth-title{font-size:2rem;font-weight:600;text-align:center;margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent) 0%,#8b5cf6 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.auth-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:2rem;font-size:.9375rem}.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.auth-tab{flex:1;padding:.625rem;font-size:.8125rem;font-weight:500;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.auth-tab:hover{background:var(--bg-tertiary)}.auth-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form input{padding:.875rem 1rem;font-size:.9375rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:8px}.auth-form input:focus{outline:none;border-color:var(--accent)}.auth-form input::placeholder{color:var(--text-muted)}.auth-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;font-size:.9375rem;font-weight:500;font-family:inherit;border:none;border-radius:8px;cursor:pointer;transition:all .15s}.auth-button.primary{background:var(--accent);color:#fff}.auth-button.primary:hover:not(:disabled){background:var(--accent-hover)}.auth-button:disabled{opacity:.5;cursor:not-allowed}.auth-message{padding:.75rem 1rem;font-size:.875rem;border-radius:8px;margin-top:1rem}.auth-message.error{background:#ef44441a;color:var(--error);border:1px solid rgba(239,68,68,.2)}.auth-message.success{background:#22c55e1a;color:var(--success);border:1px solid rgba(34,197,94,.2)}.app-container{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.header-left{display:flex;align-items:center;gap:.75rem}.app-header h1{font-size:1.25rem;font-weight:600;background:linear-gradient(135deg,var(--accent) 0%,#8b5cf6 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.menu-toggle{display:none;width:36px;height:36px;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.menu-toggle:hover{background:var(--bg-tertiary)}.hamburger-icon{position:relative;width:18px;height:2px;background:var(--text-primary);border-radius:1px}.hamburger-icon:before,.hamburger-icon:after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--text-primary);border-radius:1px}.hamburger-icon:before{top:-6px}.hamburger-icon:after{top:6px}.header-right{display:flex;align-items:center;gap:1rem}.user-email{color:var(--text-secondary);font-size:.8125rem}.signout-btn{padding:.5rem 1rem;font-size:.8125rem;font-weight:500;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s}.signout-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.app-main{display:flex;flex:1;overflow:hidden;position:relative}.sidebar-overlay{display:none}.sidebar{width:280px;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg-secondary);overflow:hidden}.persona-list{display:flex;flex-direction:column;padding:1rem;border-bottom:1px solid var(--border)}.persona-list.loading{padding:2rem;text-align:center;color:var(--text-muted)}.persona-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.persona-header h3{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.add-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:400;background:var(--bg-tertiary);color:var(--text-secondary);border:none;border-radius:4px;cursor:pointer;transition:all .15s}.add-btn:hover{background:var(--accent);color:#fff}.persona-form{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;padding:.75rem;background:var(--bg-primary);border-radius:8px}.persona-form input,.persona-form textarea{padding:.625rem;font-size:.8125rem;font-family:inherit;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;resize:none}.persona-form input:focus,.persona-form textarea:focus{outline:none;border-color:var(--accent)}.persona-form button{padding:.625rem;font-size:.8125rem;font-weight:500;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer}.persona-form button:disabled{opacity:.5}.persona-items{display:flex;flex-direction:column;gap:.25rem;max-height:200px;overflow-y:auto}.persona-item{display:flex;align-items:center;justify-content:space-between;padding:.625rem .75rem;background:var(--bg-primary);border-radius:6px;cursor:pointer;transition:all .15s}.persona-item:hover{background:var(--bg-tertiary)}.persona-item.selected{background:var(--accent)}.persona-name{font-size:.875rem;font-weight:500}.persona-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .15s}.persona-item:hover .persona-actions{opacity:1}.edit-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.75rem;background:transparent;color:var(--text-muted);border:none;border-radius:4px;cursor:pointer;transition:all .15s}.edit-btn:hover{background:var(--accent);color:#fff}.delete-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:1rem;background:transparent;color:var(--text-muted);border:none;border-radius:4px;cursor:pointer;transition:all .15s}.chat-item .delete-btn{opacity:0}.chat-item:hover .delete-btn{opacity:1}.delete-btn:hover{background:var(--error);color:#fff}.chat-list{flex:1;display:flex;flex-direction:column;padding:1rem;overflow:hidden}.chat-list.loading{padding:2rem;text-align:center;color:var(--text-muted)}.chat-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.chat-list-header h4{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.chat-items{display:flex;flex-direction:column;gap:.25rem;overflow-y:auto}.chat-item{display:flex;align-items:center;justify-content:space-between;padding:.625rem .75rem;background:var(--bg-primary);border-radius:6px;cursor:pointer;transition:all .15s}.chat-item:hover{background:var(--bg-tertiary)}.chat-item.selected{background:var(--bg-tertiary);border:1px solid var(--accent)}.chat-info{flex:1;min-width:0}.chat-title{font-size:.8125rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-date{font-size:.6875rem;color:var(--text-muted)}.content{flex:1;display:flex;flex-direction:column;overflow:hidden}.no-selection{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.panels{display:grid;grid-template-columns:1fr 1fr;flex:1;overflow:hidden}@media(max-width:1024px){.panels{grid-template-columns:1fr;grid-template-rows:1fr 1fr}}.app{display:grid;grid-template-columns:2fr 3fr;height:100vh;overflow:hidden}@media(max-width:768px){.app{grid-template-columns:1fr;grid-template-rows:1fr 1fr}}.chat-panel{display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg-primary);overflow:hidden}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.chat-header h2{font-size:1.125rem;font-weight:600;letter-spacing:-.01em}.system-toggle{padding:.375rem .75rem;font-size:.75rem;font-weight:500;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s}.system-toggle:hover{background:var(--bg-tertiary)}.system-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent)}.system-prompt{padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.system-prompt textarea{width:100%;padding:.625rem;font-size:.8125rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;resize:none}.system-prompt textarea:focus{outline:none;border-color:var(--accent)}.messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.messages::-webkit-scrollbar{width:6px}.messages::-webkit-scrollbar-track{background:transparent}.messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.empty-state{color:var(--text-muted);font-size:.875rem;text-align:center;padding:2rem}.message{display:flex;max-width:85%}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.bubble{padding:.625rem .875rem;border-radius:16px;position:relative}.message.user .bubble{background:var(--user-bubble);border-bottom-right-radius:4px}.message.assistant .bubble{background:var(--assistant-bubble);border-bottom-left-radius:4px}.bubble .content{font-size:.9375rem;white-space:pre-wrap;word-break:break-word}.bubble .time{font-size:.6875rem;color:#ffffff80;margin-top:.25rem;text-align:right}.message.assistant .bubble .time{color:var(--text-muted)}.chat-input{display:flex;gap:.5rem;padding:1rem;border-top:1px solid var(--border);background:var(--bg-secondary)}.chat-input input{flex:1;padding:.75rem 1rem;font-size:.9375rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:20px}.chat-input input:focus{outline:none;border-color:var(--accent)}.chat-input input::placeholder{color:var(--text-muted)}.chat-input button{padding:.75rem 1.25rem;font-size:.875rem;font-weight:500;font-family:inherit;background:var(--accent);color:#fff;border:none;border-radius:20px;cursor:pointer;transition:background .15s}.chat-input button:hover:not(:disabled){background:var(--accent-hover)}.chat-input button:disabled{opacity:.5;cursor:not-allowed}.image-panel{display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden}.image-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.image-header h2{font-size:1.125rem;font-weight:600;letter-spacing:-.01em}.view-toggle{display:flex;gap:.25rem}.view-toggle button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1rem;background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s}.view-toggle button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.view-toggle button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.prompt-input{display:flex;gap:.5rem;padding:1rem;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.prompt-input input{flex:1;padding:.75rem 1rem;font-size:.9375rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:8px}.prompt-input input:focus{outline:none;border-color:var(--accent)}.prompt-input input::placeholder{color:var(--text-muted)}.prompt-input button{padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;font-family:inherit;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .15s}.prompt-input button:hover:not(:disabled){background:var(--accent-hover)}.prompt-input button:disabled{opacity:.5;cursor:not-allowed}.generating-indicator{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;color:var(--text-secondary);font-size:.875rem;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.image-grid{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.image-grid.list .grid-item{width:100%;flex-shrink:0}.image-grid.list .grid-item img{width:100%;height:auto;object-fit:contain}.image-grid.gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:4px;padding:4px;align-content:start}.image-grid.gallery .grid-item{aspect-ratio:1;width:100%;height:0;padding-bottom:100%;position:relative}.image-grid.gallery .grid-item img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.image-grid.gallery .grid-item .loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:0}.image-grid::-webkit-scrollbar{width:6px}.image-grid::-webkit-scrollbar-track{background:transparent}.image-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.image-grid .empty-state{grid-column:1 / -1;padding:3rem}.grid-item{background:var(--bg-secondary);cursor:pointer;overflow:hidden;position:relative;border-radius:8px}.grid-item:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#000;opacity:0;transition:opacity .15s;pointer-events:none}.grid-item:hover:after{opacity:.15}.grid-item img{display:block}.image-delete-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:#000000b3;color:#fff;border:none;border-radius:50%;cursor:pointer;opacity:0;transition:all .15s;z-index:10}.grid-item:hover .image-delete-btn{opacity:1}.image-delete-btn:hover{background:var(--error)}.grid-item .loading{color:var(--text-muted);font-size:.75rem;padding:2rem;text-align:center}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease;gap:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-content{position:relative;max-width:80vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:4px}.lightbox-nav{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--bg-tertiary);color:var(--text-primary);border:none;border-radius:50%;cursor:pointer;opacity:.7;transition:all .15s;flex-shrink:0}.lightbox-nav:hover{opacity:1;background:var(--accent)}.lightbox-counter{margin-top:1rem;font-size:.875rem;color:var(--text-secondary)}.lightbox-actions{position:absolute;top:-48px;right:0;display:flex;align-items:center;gap:.75rem}.close-btn{width:32px;height:32px;font-size:1.5rem;background:transparent;color:var(--text-primary);border:none;cursor:pointer;opacity:.7;transition:opacity .15s}.close-btn:hover{opacity:1}.lightbox-delete-btn{padding:.5rem 1rem;font-size:.8125rem;font-weight:500;font-family:inherit;background:var(--error);color:#fff;border:none;border-radius:6px;cursor:pointer;opacity:.9;transition:all .15s}.lightbox-delete-btn:hover{opacity:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{width:100%;max-width:480px;max-height:90vh;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.125rem;font-weight:600}.modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:transparent;color:var(--text-secondary);border:none;border-radius:6px;cursor:pointer;transition:all .15s}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:1.25rem;overflow-y:auto}.modal-form{display:flex;flex-direction:column;gap:1rem}.modal-form label{display:flex;flex-direction:column;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.modal-form input,.modal-form textarea{padding:.75rem;font-size:.9375rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;resize:none}.modal-form input:focus,.modal-form textarea:focus{outline:none;border-color:var(--accent)}.modal-form input::placeholder,.modal-form textarea::placeholder{color:var(--text-muted)}.modal-actions{display:flex;gap:.75rem;margin-top:.5rem}.modal-actions button{flex:1;padding:.75rem 1rem;font-size:.875rem;font-weight:500;font-family:inherit;border-radius:8px;cursor:pointer;transition:all .15s}.modal-actions .btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.modal-actions .btn-secondary:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-actions .btn-primary{background:var(--accent);color:#fff;border:none}.modal-actions .btn-primary:hover:not(:disabled){background:var(--accent-hover)}.modal-actions button:disabled{opacity:.5;cursor:not-allowed}.modal-status{display:flex;align-items:center;gap:.5rem;padding:.75rem;font-size:.8125rem;background:var(--bg-primary);border-radius:8px;color:var(--text-secondary)}.modal-status .spinner{width:16px;height:16px}.hidden-warning{padding:.75rem;font-size:.8125rem;background:#ef44441a;color:var(--error);border:1px solid rgba(239,68,68,.2);border-radius:8px;line-height:1.5}.hidden-error{padding:.5rem .75rem;font-size:.8125rem;background:#ef44441a;color:var(--error);border-radius:6px}.hidden-folder-section{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.hidden-folder-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--bg-primary);border-radius:6px;cursor:pointer;transition:all .15s}.hidden-folder-header:hover{background:var(--bg-tertiary)}.hidden-folder-header .folder-label{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.hidden-folder-header .lock-icon{font-size:1rem}.hidden-folder-header .lock-btn{padding:.25rem .5rem;font-size:.6875rem;font-weight:500;background:var(--bg-tertiary);color:var(--text-muted);border:none;border-radius:4px;cursor:pointer;transition:all .15s}.hidden-folder-header .lock-btn:hover{background:var(--error);color:#fff}.hidden-personas{margin-top:.5rem}.hidden-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}.hidden-checkbox input{width:16px;height:16px;accent-color:var(--accent)}.image-actions{position:absolute;top:8px;right:8px;display:flex;gap:6px;z-index:10}.image-actions .image-delete-btn{position:static}.image-edit-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;background:#000000b3;color:#fff;border:none;border-radius:50%;cursor:pointer;opacity:0;transition:all .15s}.grid-item:hover .image-edit-btn{opacity:1}.image-edit-btn:hover{background:var(--accent)}.edit-image-modal{display:flex;flex-direction:column;gap:1rem}.edit-preview{width:100%;max-height:250px;overflow:hidden;border-radius:8px;background:var(--bg-primary)}.edit-preview img{width:100%;height:auto;max-height:250px;object-fit:contain}.edit-prompt-input input{width:100%;padding:.75rem;font-size:.9375rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:8px}.edit-prompt-input input:focus{outline:none;border-color:var(--accent)}.edit-prompt-input input::placeholder{color:var(--text-muted)}.image-upload-section{display:flex;flex-direction:column;gap:.5rem}.image-upload-section label{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.upload-btn{padding:.75rem 1rem;font-size:.875rem;font-weight:500;font-family:inherit;background:var(--bg-primary);color:var(--text-secondary);border:1px dashed var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.upload-btn:hover{background:var(--bg-tertiary);border-color:var(--accent);color:var(--text-primary)}.image-preview{position:relative;border-radius:8px;overflow:hidden;background:var(--bg-primary)}.image-preview img{width:100%;height:auto;max-height:150px;object-fit:contain;display:block}.clear-image-btn{position:absolute;top:8px;right:8px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1rem;background:#000000b3;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .15s}.clear-image-btn:hover{background:var(--error)}.upload-hint{font-size:.75rem;color:var(--text-muted)}@media(max-width:768px){.menu-toggle{display:flex}.user-email{display:none}.sidebar-overlay{display:block;position:fixed;right:0;bottom:0;left:0;top:53px;background:#0009;z-index:40;animation:fadeIn .2s ease}.sidebar{position:fixed;left:0;top:53px;bottom:0;width:280px;z-index:50;transform:translate(-100%);transition:transform .3s ease;border-right:1px solid var(--border)}.sidebar.open{transform:translate(0)}.panels{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.chat-panel{border-right:none;border-bottom:1px solid var(--border)}.signout-btn{padding:.375rem .75rem;font-size:.75rem}.chat-header,.image-header{padding:.75rem 1rem}.chat-header h2,.image-header h2{font-size:1rem}.chat-input,.prompt-input{padding:.75rem}}@media(max-width:480px){.app-header{padding:.625rem 1rem}.app-header h1{font-size:1.125rem}.sidebar{width:100%}.messages{padding:.75rem}.bubble{padding:.5rem .75rem}.bubble .content{font-size:.875rem}.image-grid.gallery{grid-template-columns:repeat(2,1fr)}.lightbox-content{max-width:95vw}.lightbox-nav{width:40px;height:40px;font-size:1.5rem}.modal-content{margin:1rem;max-width:calc(100% - 2rem)}}
