*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #ffffff;--sidebar-bg: #f9f9f9;--surface: #ffffff;--surface-hover: #f3f4f6;--border: #e5e7eb;--border-strong: #d1d5db;--text: #111827;--muted: #6b7280;--muted-light: #9ca3af;--accent: #111827;--accent-hover: #374151;--danger: #dc2626;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 24px rgba(0, 0, 0, .06);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--sidebar-width: 280px}html,body,#root{height:100%;overflow:hidden}body{font-family:DM Sans,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button,input{font:inherit}button{cursor:pointer}input{outline:none}input::placeholder{color:var(--muted-light)}.muted{color:var(--muted);font-size:.875rem}.error{color:var(--danger);font-size:.875rem}.brand{display:flex;align-items:center;gap:.625rem}.brand-icon{width:28px;height:28px;background:var(--accent);border-radius:6px;display:grid;place-items:center;flex-shrink:0}.play-icon{display:block;width:0;height:0;border-style:solid;border-width:5px 0 5px 8px;border-color:transparent transparent transparent #ffffff;margin-left:2px}.brand-name{font-weight:700;font-size:1.125rem;letter-spacing:-.02em}.btn-primary{border:none;border-radius:var(--radius-md);background:var(--accent);color:#fff;font-weight:600;transition:background .15s ease}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-ghost{border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;color:var(--text);padding:.625rem 1rem;font-weight:500}.btn-ghost:hover{background:var(--surface-hover)}.btn-icon{width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:1.25rem;line-height:1;display:grid;place-items:center;flex-shrink:0}.btn-icon:hover{background:var(--surface-hover)}.search-field input{width:100%;padding:.625rem .875rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text)}.search-field input:focus{border-color:var(--border-strong)}.search-field-inline{display:flex;align-items:center;gap:.5rem;flex:1;padding:0 .75rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface)}.search-field-inline svg{color:var(--muted-light);flex-shrink:0}.search-field-inline input{flex:1;border:none;background:transparent;padding:.625rem 0}.section-label{font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-light);margin-bottom:.5rem}.eyebrow{font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-light);text-align:center;margin-bottom:.5rem}.app-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;height:100%;overflow:hidden}.main-panel{background:var(--bg);height:100%;min-height:0;overflow:hidden;display:flex;flex-direction:column}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.sidebar-top{flex:1;padding:1.25rem 1rem;display:flex;flex-direction:column;gap:.875rem;overflow:hidden}.btn-new-chat{width:100%;padding:.75rem 1rem;font-size:.9375rem}.history-section{flex:1;display:flex;flex-direction:column;min-height:0;margin-top:.25rem}.history-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.125rem}.history-empty{padding:.5rem .25rem}.history-item-wrap{display:flex;align-items:stretch;gap:.125rem;border-radius:var(--radius-md)}.history-item-wrap:hover,.history-item-wrap:focus-within{background:var(--surface-hover)}.history-item-wrap.active{background:#ececec}.history-item{flex:1;min-width:0;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.625rem .25rem .625rem .75rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text);text-align:left}.history-delete{flex-shrink:0;align-self:center;width:1.75rem;height:1.75rem;margin-right:.375rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--muted-light);font-size:1.125rem;line-height:1;opacity:0;transition:opacity .12s ease,background .12s ease,color .12s ease}.history-item-wrap:hover .history-delete,.history-item-wrap:focus-within .history-delete,.history-delete:focus-visible{opacity:1}.history-delete:hover{background:#fee2e2;color:var(--danger)}.history-text{display:flex;flex-direction:column;gap:.125rem;min-width:0}.history-title{font-size:.875rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-meta{font-size:.8125rem;color:var(--muted)}.history-time{font-size:.8125rem;color:var(--muted-light);flex-shrink:0;padding-top:.125rem}.sidebar-footer{position:relative;padding:.875rem 1rem;border-top:1px solid var(--border)}.user-chip{width:100%;display:flex;align-items:center;gap:.625rem;padding:.5rem .625rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text);font-weight:500;font-size:.9375rem;text-align:left}.user-chip:hover,.user-chip[aria-expanded=true]{background:var(--surface-hover)}.user-chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu{position:absolute;left:1rem;right:1rem;bottom:calc(100% + .5rem);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden;z-index:20}.user-menu-header{padding:.875rem 1rem;border-bottom:1px solid var(--border)}.user-menu-name{display:block;font-size:.875rem;font-weight:600}.user-menu-email{display:block;margin-top:.125rem;font-size:.75rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-item{width:100%;padding:.75rem 1rem;border:none;background:transparent;color:var(--text);font-size:.875rem;font-weight:500;text-align:left}.user-menu-item:hover{background:var(--surface-hover)}.user-avatar{width:32px;height:32px;border-radius:50%;background:#d1d5db;color:var(--text);font-size:.8125rem;font-weight:600;display:grid;place-items:center;flex-shrink:0}.picker-page{height:100%;min-height:0;display:flex;flex-direction:column;align-items:center;padding:1.5rem 1.5rem 1rem;overflow:hidden}.picker-header{flex-shrink:0;text-align:center;margin-bottom:1.25rem}.picker-title{font-size:clamp(1.5rem,3vw,2rem);font-weight:700;letter-spacing:-.03em;text-align:center}.picker-card{width:100%;max-width:520px;flex:1;min-height:0;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.picker-toolbar{display:flex;align-items:center;gap:.5rem;padding:.875rem;border-bottom:1px solid var(--border);flex-shrink:0}.persona-list{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain}.persona-section-label{padding:.625rem 1.125rem .375rem;font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-light)}.explore-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.875rem 1.125rem;border:none;border-bottom:1px solid var(--border);background:var(--sidebar-bg);color:var(--text);font-weight:600;font-size:.875rem;text-align:left}.explore-toggle:hover{background:var(--surface-hover)}.explore-meta{display:inline-flex;align-items:center;gap:.375rem;color:var(--muted);font-weight:500;font-size:.8125rem}.explore-chevron{transition:transform .15s ease}.explore-chevron.open{transform:rotate(180deg)}.persona-row-pinned{background:#fcfcfc}.picker-hint{flex-shrink:0;margin-top:.875rem;font-size:.875rem;color:var(--muted-light);text-align:center}.persona-empty{padding:2rem 1.25rem;text-align:center}.persona-row{width:100%;display:flex;align-items:center;gap:.875rem;padding:.875rem 1.125rem;border:none;border-bottom:1px solid var(--border);background:transparent;color:var(--text);text-align:left;transition:background .12s ease}.persona-row:last-of-type{border-bottom:none}.persona-row:hover{background:var(--surface-hover)}.persona-row-pending{cursor:default;background:#fafafa}.persona-row-pending:hover{background:#fafafa}.persona-row-failed{background:snow}.persona-avatar-wrap{position:relative;flex-shrink:0}.persona-avatar-pending{background:#9ca3af}.persona-avatar-ring{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border:2px solid var(--text);border-top-color:transparent;border-radius:50%;animation:spin .9s linear infinite}.persona-badge{display:inline-flex;align-items:center;gap:.375rem;flex-shrink:0;font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:999px}.persona-badge-pending{color:var(--muted);background:var(--surface-hover)}.persona-badge-failed{color:var(--danger);background:#fef2f2}.spinner{width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.persona-avatar,.persona-avatar-img{width:40px;height:40px;border-radius:50%;flex-shrink:0}.persona-avatar{background:var(--accent);color:#fff;font-size:.8125rem;font-weight:600;display:grid;place-items:center}.persona-avatar-img{object-fit:cover}.persona-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.persona-name{font-weight:600;font-size:.9375rem}.persona-desc{font-size:.8125rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.persona-stats{font-size:.8125rem;color:var(--muted-light);flex-shrink:0}.create-persona-link{width:100%;padding:.875rem 1.125rem;border:none;border-top:1px solid var(--border);background:transparent;color:var(--text);font-weight:500;font-size:.9375rem;text-align:left;flex-shrink:0}.create-persona-link:hover{background:var(--surface-hover)}.chat-view{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.chat-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem 1.75rem;border-bottom:1px solid var(--border);flex-shrink:0}.chat-topbar-main{display:flex;flex-direction:column;gap:.875rem;min-width:0}.chat-mode-toggle{display:inline-flex;padding:.1875rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--sidebar-bg);width:fit-content}.chat-mode-btn{border:none;background:transparent;color:var(--muted);font-size:.8125rem;font-weight:600;padding:.4375rem .875rem;border-radius:calc(var(--radius-md) - 2px)}.chat-mode-btn:hover{color:var(--text)}.chat-mode-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.chat-mode-btn.active:last-child{color:#b45309}.chat-delete-btn{padding:.5rem .875rem;font-size:.8125rem;white-space:nowrap}.chat-delete-btn:hover{border-color:#fecaca;color:var(--danger);background:#fef2f2}.chat-topbar h2{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1rem}.chat-empty{margin:auto;text-align:center;max-width:420px;line-height:1.5}.message{display:flex;flex-direction:column;gap:.375rem;max-width:720px}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-bubble{padding:.875rem 1rem;border-radius:14px;line-height:1.55;white-space:pre-wrap;font-size:.9375rem}.message.user .message-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message.assistant .message-bubble{background:var(--sidebar-bg);border:1px solid var(--border);border-bottom-left-radius:4px}.message-bubble.typing{color:var(--muted)}.message-sources{padding-left:.25rem}.sources-link{background:none;border:none;color:var(--muted);font-size:.75rem;padding:0}.sources-link:hover{color:var(--text)}.message-sources ul{margin-top:.5rem;padding-left:1rem;font-size:.75rem;color:var(--muted);line-height:1.45}.message-sources li{margin-bottom:.375rem}.chat-error{padding:0 1.75rem .5rem}.chat-composer{display:flex;gap:.75rem;padding:1rem 1.75rem 1.25rem;border-top:1px solid var(--border);flex-shrink:0}.chat-composer input{flex:1;padding:.875rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text)}.chat-composer input:focus{border-color:var(--border-strong)}.chat-composer .btn-primary{padding:0 1.25rem;white-space:nowrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182766;display:grid;place-items:center;padding:1.5rem;z-index:100}.modal{width:100%;max-width:440px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md)}.modal h2{font-size:1.25rem;font-weight:700;margin-bottom:.375rem}.modal p{margin-bottom:1.25rem}.modal form{display:flex;flex-direction:column;gap:1rem}.modal input{padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text)}.modal input:focus{border-color:var(--border-strong)}.modal-actions{display:flex;justify-content:flex-end;gap:.625rem}.modal-actions .btn-primary{padding:.625rem 1rem}.auth-page{height:100%;overflow-y:auto;display:flex;flex-direction:column;background:#f9fafb}.auth-header{padding:1.5rem 2rem}.auth-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem 3rem;width:100%;max-width:420px;margin:0 auto}.auth-eyebrow{font-size:.6875rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-light);text-align:center;margin-bottom:.625rem}.auth-title{font-size:clamp(1.75rem,4vw,2rem);font-weight:700;letter-spacing:-.03em;text-align:center;margin-bottom:.5rem}.auth-subtitle{color:var(--muted);text-align:center;font-size:.9375rem;line-height:1.5;margin-bottom:2rem}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:.625rem;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);font-weight:500;font-size:.9375rem;transition:background .15s ease}.btn-google:hover:not(:disabled){background:var(--surface-hover)}.btn-google:disabled{opacity:.6;cursor:not-allowed}.google-signin-wrap{position:relative;width:100%}.btn-google-visual,.google-signin-wrap.is-loading .google-signin-overlay{pointer-events:none}.google-signin-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;opacity:.01;overflow:hidden;cursor:pointer}.google-signin-overlay iframe{margin:0!important}.auth-divider{display:flex;align-items:center;gap:1rem;width:100%;margin:1.5rem 0;color:var(--muted-light);font-size:.75rem;font-weight:500;letter-spacing:.06em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-form{width:100%;display:flex;flex-direction:column;gap:1.125rem}.field{display:flex;flex-direction:column;gap:.375rem}.field-label{font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.field-label-row{display:flex;align-items:center;justify-content:space-between}.field input{width:100%;padding:.75rem .875rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text)}.field input:focus{border-color:var(--border-strong)}.text-link{background:none;border:none;padding:0;color:var(--muted);font-size:.8125rem;text-decoration:underline;text-underline-offset:2px}.text-link:hover:not(:disabled){color:var(--text)}.text-link:disabled{cursor:default;opacity:.7}.btn-auth-submit{width:100%;padding:.8125rem 1rem;margin-top:.25rem;font-size:.9375rem}.auth-switch{margin-top:1.5rem;text-align:center;font-size:.875rem;color:var(--muted)}.auth-footer{padding:1.5rem 2rem 2rem;display:flex;align-items:center;justify-content:center;gap:1.25rem;flex-wrap:wrap;font-size:.8125rem;color:var(--muted-light)}.auth-footer a{color:var(--muted-light);text-decoration:none}.auth-footer a:hover{color:var(--muted);text-decoration:underline}@media(max-width:768px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:100%}.sidebar{height:auto;max-height:42vh;min-height:0}.sidebar-top{padding-bottom:.5rem}.history-section{max-height:160px}.picker-page{padding-top:1rem}.chat-view{height:100%}}
