*,*:before,*:after{box-sizing:border-box}:root{--bg: #0c0e12;--surface: #14171f;--surface-2: #1a1e28;--border: #2a313d;--text: #e8edf5;--muted: #8b95a8;--accent: #00c853;--accent-dim: rgba(0, 200, 83, .15);--danger: #ff5252;--radius: 12px;--font: "DM Sans", system-ui, sans-serif}html,body{height:100%;margin:0;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}#root{height:100%}button,textarea{font-family:inherit}button{cursor:pointer}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.app{display:flex;flex-direction:column;height:100%;max-width:880px;margin:0 auto;padding:0 16px 16px;position:relative}.toast-stack{position:fixed;top:16px;right:16px;z-index:50;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast-item{max-width:280px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);padding:10px 12px;font-size:.85rem;box-shadow:0 8px 20px #00000040}.header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0 12px;border-bottom:1px solid var(--border);flex-shrink:0}.brand{display:flex;align-items:center;gap:14px;min-width:0}.header-user{display:flex;align-items:center;gap:14px;flex-shrink:0}.user-email{font-size:.85rem;color:var(--muted);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-signout{padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.875rem;font-weight:500}.btn-signout:hover{color:var(--text);border-color:var(--muted)}.auth-loading{padding:48px 24px;text-align:center;color:var(--muted);font-size:.95rem}.auth-screen{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px 16px}.auth-card{width:100%;max-width:400px;padding:28px 24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.auth-title{margin:0 0 8px;font-size:1.35rem;font-weight:700}.auth-hint{margin:0 0 20px;font-size:.875rem;color:var(--muted);line-height:1.45}.auth-label{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;font-size:.8rem;color:var(--muted);font-weight:500}.auth-input{padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.95rem}.auth-input:focus{outline:none;border-color:var(--accent)}.auth-error{margin-bottom:12px;padding:10px 12px;border-radius:8px;background:#ff52521f;border:1px solid rgba(255,82,82,.35);color:#ffb4b4;font-size:.875rem}.auth-submit{width:100%;margin-top:4px;padding:12px 16px;border:none;border-radius:var(--radius);background:var(--accent);color:#0a0f0c;font-weight:600;font-size:.95rem}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-switch{display:block;width:100%;margin-top:16px;padding:10px;border:none;background:transparent;color:var(--muted);font-size:.875rem;text-align:center;text-decoration:underline;cursor:pointer}.auth-switch:hover:not(:disabled){color:var(--text)}.auth-switch:disabled{opacity:.5}.logo{font-size:2rem;line-height:1}.header h1{margin:0;font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.header p{margin:4px 0 0;font-size:.875rem;color:var(--muted)}.main{flex:1;display:flex;flex-direction:column;min-height:0;padding-top:12px}.main-layout{flex:1;min-height:0;display:grid;grid-template-columns:240px minmax(0,1fr);gap:12px}.threads-panel{min-height:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px;display:flex;flex-direction:column;gap:10px}.threads-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.threads-head h3{margin:0;font-size:.92rem}.btn-new-chat{padding:7px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:.8rem}.threads-list{overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:8px}.threads-empty{margin:0;color:var(--muted);font-size:.82rem}.thread-item{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid var(--border);border-radius:8px;padding:6px 8px;background:transparent;color:var(--text);flex:1}.thread-item-title{flex:1;min-width:0;border:none;background:transparent;color:var(--text);text-align:left;font-size:.84rem;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;padding:4px 2px}.thread-item-actions{display:inline-flex;align-items:center;flex-shrink:0}.thread-row{display:flex;align-items:center;gap:6px;position:relative}.thread-row.active .thread-item{border-color:var(--accent);background:var(--accent-dim)}.thread-menu-trigger{width:28px;height:28px;border:none;border-radius:8px;background:transparent;color:var(--muted);font-size:16px;line-height:1;flex-shrink:0;opacity:0;pointer-events:none;transition:opacity .15s ease,color .15s ease,background .15s ease}.thread-row:hover .thread-menu-trigger,.thread-row:focus-within .thread-menu-trigger,.thread-menu-trigger.open{opacity:1;pointer-events:auto}.thread-menu-trigger:hover:not(:disabled){color:var(--text);background:#ffffff0f}.thread-menu{position:absolute;right:8px;z-index:20;min-width:140px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 20px #00000040;padding:6px}.thread-menu.up{bottom:34px}.thread-menu.down{top:34px}.thread-menu-floating{position:fixed;z-index:60;min-width:140px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 20px #00000040;padding:6px;transform:translateY(0)}.thread-menu-floating.up{transform:translateY(-100%)}.thread-menu-item{width:100%;border:none;background:transparent;color:var(--text);text-align:left;border-radius:6px;padding:8px 10px;font-size:.83rem}.thread-menu-item:hover:not(:disabled){background:#ffffff0d}.thread-menu-item.danger{color:#ffb4b4}.chat-panel{min-height:0;display:flex;flex-direction:column}.chat{flex:1;overflow-y:auto;padding:8px 4px 16px;display:flex;flex-direction:column;gap:12px}.row{display:flex;justify-content:flex-start}.row.user{justify-content:flex-end}.bubble{max-width:min(100%,640px);padding:12px 14px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}.bubble.user{background:var(--surface-2);border-color:var(--accent-dim)}.msg-images{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.msg-img{max-width:min(100%,320px);max-height:240px;border-radius:8px;object-fit:contain;border:1px solid var(--border);background:#0a0c10}.msg-text{margin:0;font-size:.95rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.msg-pre{margin:0;font-size:.9rem;line-height:1.55;white-space:pre-wrap;word-break:break-word;font-family:var(--font)}.typing{display:inline-flex;gap:6px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.typing span{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:pulse 1.2s ease-in-out infinite}.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}@keyframes pulse{0%,80%,to{opacity:.35;transform:scale(.9)}40%{opacity:1;transform:scale(1)}}.error-banner{margin:0 4px 8px;padding:10px 12px;border-radius:8px;background:#ff52521f;border:1px solid rgba(255,82,82,.35);color:#ffb4b4;font-size:.875rem}.composer-wrap{flex-shrink:0;padding-top:8px;border-radius:var(--radius);transition:background .15s ease,border-color .15s ease;border:1px solid transparent}.composer-wrap:focus-within{background:#ffffff05}.composer-wrap.drag-active{border-color:var(--accent);background:#00c85314}.pending-strip{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px}.pending-item{position:relative}.pending-thumb{width:72px;height:72px;object-fit:cover;border-radius:8px;border:1px solid var(--border);display:block}.pending-remove{position:absolute;top:-6px;right:-6px;width:22px;height:22px;padding:0;border:none;border-radius:50%;background:var(--danger);color:#fff;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.pending-remove:hover{filter:brightness(1.1)}.file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.composer{display:flex;flex-shrink:0}.composer-card{flex:1;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);padding:8px;display:flex;flex-direction:column;gap:8px}.input-shell{position:relative;width:100%}.floating-placeholder{position:absolute;top:10px;left:12px;right:12px;color:var(--muted);font-size:.9rem;pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.95;transition:opacity .2s ease}.composer-meta{margin-top:8px;display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.78rem}.composer-hotkeys{margin-left:auto}.composer-clear{border:1px solid var(--border);background:transparent;color:var(--muted);border-radius:8px;padding:4px 8px;font-size:.75rem}.composer-clear:hover:not(:disabled){color:var(--text);border-color:var(--muted)}.composer-actions{display:flex;flex-direction:column;gap:8px;justify-content:flex-end}.composer-toolbar{display:flex;align-items:center;gap:8px}.composer-toolbar-actions{display:inline-flex;align-items:center;gap:8px}.composer-attach-info{color:var(--muted);font-size:.78rem}.btn-attach{padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:.8rem;font-weight:500;white-space:nowrap}.btn-attach.icon-only{width:36px;min-width:36px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1rem}.btn-attach:hover:not(:disabled){border-color:var(--muted);background:var(--surface)}.btn-attach:disabled{opacity:.45;cursor:not-allowed}.input{width:100%;display:block;flex:1;resize:none;min-height:72px;max-height:240px;padding:8px 10px;border-radius:10px;border:none;background:transparent;color:var(--text);font-size:.95rem;line-height:1.45}.input:focus{outline:none;box-shadow:inset 0 0 0 1px var(--accent)}.input:disabled{opacity:.6}.send{padding:10px 16px;border-radius:10px;border:none;background:var(--accent);color:#0a0f0c;font-weight:600;font-size:.9rem;min-height:38px;min-width:110px;margin-left:auto}.send:disabled{opacity:.45;cursor:not-allowed}@media(max-width:760px){.composer-toolbar{flex-direction:column;align-items:stretch;gap:10px}.composer-toolbar-actions{width:100%;justify-content:flex-start}.composer-attach-info{order:2}.send{order:3;width:100%;margin-left:0}.composer-meta{flex-wrap:wrap;gap:6px 10px}.composer-hotkeys{margin-left:0;width:100%}}
