*{box-sizing:border-box}:root{--bg: #f3f6fb;--panel: #ffffff;--panel-soft: #f8fafd;--border: #d9e2ef;--text: #1f2a37;--muted: #607084;--primary: #2563eb;--primary-hover: #1d4ed8;--danger: #dc2626}body{margin:0;font-family:Calibri,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}button,input,select{font-family:inherit;font-size:inherit}.app-loading{min-height:100vh;display:grid;place-items:center;text-align:center;gap:12px}.spinner{width:36px;height:36px;border:3px solid #d5deec;border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:32px 28px;box-shadow:0 12px 28px #11182714}.auth-card h1{margin:0 0 4px;font-size:1.6rem}.auth-brand{display:inline-flex;align-items:center;gap:10px;margin-bottom:10px}.auth-brand-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;border:1px solid var(--border);box-shadow:0 4px 14px #1118271f}.auth-brand-name{font-size:1rem;font-weight:700;letter-spacing:.02em;color:#1d4ed8}.auth-subtitle{margin:0 0 18px;color:var(--muted);font-size:.9rem}.auth-tabs{display:flex;gap:8px;margin-bottom:20px}.auth-tabs button{flex:1;padding:9px 0;background:#eef3fb;border:1px solid var(--border);color:#334155;border-radius:8px;cursor:pointer}.auth-tabs button.active{background:var(--primary);border-color:var(--primary);color:#fff}.auth-card form{display:grid;gap:14px}.auth-card label{display:grid;gap:6px;font-size:.88rem;color:#334155}.auth-card input{padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text)}.auth-card input:focus,.composer input:focus,.profile input:focus,.message-dropdowns select:focus{outline:none;border-color:var(--primary)}.auth-card button[type=submit]{margin-top:4px;padding:11px 12px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-weight:600;cursor:pointer}.auth-card button[type=submit]:hover:not(:disabled),.composer button:hover:not(:disabled),.profile button:hover{background:var(--primary-hover)}.auth-card button[type=submit]:disabled,.composer button:disabled{opacity:.6;cursor:not-allowed}.error{color:var(--danger);font-size:.85rem}.chat-shell{display:grid;grid-template-columns:300px 1fr;min-height:100vh;position:relative;transition:grid-template-columns .22s ease}.chat-shell.sidebar-collapsed{grid-template-columns:0 1fr}.chat-main{grid-column:2;display:flex;flex-direction:column;height:100vh;padding:64px 24px 20px;gap:12px}.chat-sidebar{grid-column:1;background:var(--panel);border-right:1px solid var(--border);padding:20px;display:flex;flex-direction:column;gap:20px;overflow-y:auto;max-height:100vh;transition:transform .22s ease,opacity .22s ease}.chat-shell.sidebar-collapsed .chat-sidebar{transform:translate(-100%);opacity:0;pointer-events:none}.sidebar-toggle{display:inline-flex;align-items:center;justify-content:center;position:fixed;top:20px;left:22px;z-index:20;width:42px;height:42px;padding:0;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text);cursor:pointer;box-shadow:0 8px 22px #1118271a}.sidebar-toggle:hover{background:#eef3fb}.sidebar-toggle-icon{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}.profile{padding-left:54px}.bot-brand{display:flex;align-items:center;gap:10px;margin-bottom:8px}.bot-brand-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;border:1px solid var(--border);box-shadow:0 3px 10px #1118271f}.bot-brand-name{font-size:.9rem;font-weight:700;letter-spacing:.02em;color:#1d4ed8}.profile h2{margin:0 0 4px;font-size:1rem}.chat-shell.sidebar-collapsed .sidebar-toggle{top:12px;left:12px}.profile-email{display:block;font-size:.8rem;color:var(--muted);margin-bottom:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile input{width:100%;padding:8px 10px;border-radius:7px;border:1px solid var(--border);background:#fff;color:var(--text)}.profile button{margin-top:8px;width:100%;padding:8px 0;border:none;border-radius:7px;background:var(--primary);color:#fff;cursor:pointer}.sessions{flex:1;min-height:0;display:flex;flex-direction:column}.admin-panel{border:1px solid var(--border);border-radius:10px;padding:10px;background:#f8fbff}.admin-panel h3{margin:0 0 8px;font-size:.9rem}.admin-panel form{display:grid;gap:8px}.admin-panel input{width:100%;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text)}.admin-panel button{width:100%;padding:8px 10px;border-radius:8px;border:none;background:var(--primary);color:#fff;font-weight:600;cursor:pointer}.admin-panel button:disabled{opacity:.65;cursor:not-allowed}.admin-role-toggle{display:flex;align-items:center;gap:8px;font-size:.84rem;color:#334155;-webkit-user-select:none;user-select:none}.admin-role-toggle input{width:16px;height:16px;margin:0}.admin-open-create{width:100%;padding:9px 10px;border-radius:8px;border:1px solid #bfdbfe;background:#eaf2ff;color:#1e40af;font-weight:600;cursor:pointer}.admin-open-create:hover{background:#dce9ff}.sessions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sessions-header h3{margin:0;font-size:.95rem}.sessions-header button{padding:5px 12px;border:1px solid var(--border);border-radius:6px;background:#eef3fb;color:#334155;cursor:pointer}.sessions-header button:hover{background:#dde9ff}.sessions ul{list-style:none;padding:0;margin:0;display:grid;gap:6px;overflow-y:auto;flex:1}.sessions ul::-webkit-scrollbar,.messages::-webkit-scrollbar{width:8px}.sessions ul::-webkit-scrollbar-thumb,.messages::-webkit-scrollbar-thumb{background:#c7d3e6;border-radius:6px}.session-row{display:grid;gap:6px}.session-open{width:100%;padding:9px 10px;background:var(--panel-soft);border:1px solid var(--border);color:#334155;border-radius:8px;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:.88rem}.session-open:hover,.session-open.active{border-color:#9fb7ea;background:#eaf1ff;color:#1e3a8a}.session-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-actions{display:block}.session-menu{width:100%;padding:6px 8px;border-radius:8px;border:1px solid var(--border);background:#f8fbff;color:#334155;font-size:.82rem}.session-menu:focus{outline:none;border-color:var(--primary)}.session-date{font-size:.72rem;color:var(--muted)}.empty-hint{font-size:.82rem;color:var(--muted);text-align:center;padding:16px 0}.logout{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;padding:10px 0;border-radius:8px;cursor:pointer}.logout:hover{background:#fee2e2}.messages{flex:1;display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding-right:8px}.admin-page{flex:1;background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;display:grid;gap:14px;align-content:start}.admin-page-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.admin-page-head h2{margin:0;font-size:1.05rem}.admin-back{padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:#f8fbff;color:#334155;cursor:pointer}.admin-back:hover{background:#edf4ff}.admin-page-form{max-width:520px;display:grid;gap:10px}.admin-page-form input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text)}.admin-page-form button{width:fit-content;min-width:140px;padding:9px 14px;border-radius:8px;border:none;background:var(--primary);color:#fff;font-weight:600;cursor:pointer}.admin-page-form button:disabled{opacity:.65;cursor:not-allowed}.empty-chat{flex:1;display:grid;place-items:center;color:var(--muted);font-size:.95rem}.message{max-width:72%;padding:12px 16px;border-radius:14px;word-wrap:break-word;white-space:pre-wrap}.message.user{align-self:flex-end;background:var(--primary);color:#fff;border-bottom-right-radius:4px}.message.bot{align-self:flex-start;background:#fff;color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}.message-video{display:block;width:min(100%,520px);max-height:320px;margin-top:10px;border-radius:10px;border:1px solid var(--border);background:#000}.message-video-toggle{margin-top:10px;padding:7px 12px;border-radius:8px;border:1px solid #b8c8e4;background:#f5f9ff;color:#1e3a8a;font-weight:600;cursor:pointer}.message-video-toggle:hover{background:#e8f0ff}.message-actions{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}.message-actions button{padding:6px 14px;border-radius:999px;border:1px solid #93b1f3;background:#eef4ff;color:#1e40af;cursor:pointer;font-size:.85rem}.message-actions button:hover{background:#dce9ff}.message-dropdowns{margin-top:10px;display:grid;gap:10px}.message-dropdowns label{display:grid;gap:6px;font-size:.88rem;color:#334155;font-weight:600}.dropdown-select{width:100%;min-height:40px;padding:8px 12px;border-radius:10px;border:1px solid #b8c8e4;background:linear-gradient(180deg,#fff,#f5f9ff);color:var(--text);font-weight:500;cursor:pointer;box-shadow:0 2px 8px #2563eb14;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.dropdown-select:hover{border-color:#8eaae0;background:linear-gradient(180deg,#fff,#edf4ff)}.dropdown-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb24;outline:none}.composer{display:flex;gap:10px}.composer input{flex:1;padding:12px 14px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text)}.composer button{padding:12px 22px;border-radius:10px;border:none;background:var(--primary);color:#fff;font-weight:600;cursor:pointer}.status{font-size:.82rem;color:var(--muted);text-align:center}@media (max-width: 900px){.chat-shell,.chat-shell.sidebar-collapsed{grid-template-columns:1fr}.chat-sidebar{position:fixed;left:0;top:12px;bottom:12px;width:280px;z-index:10;margin:0;border-right:1px solid var(--border);border-left:none;transform:translate(-100%);transition:transform .25s ease;border-radius:0 12px 12px 0;max-height:none}.chat-sidebar.open,.chat-shell.sidebar-collapsed .chat-sidebar.open{transform:translate(0);opacity:1;pointer-events:auto}.chat-main{padding-top:66px}.profile h2,.profile{padding-left:0}.message{max-width:88%}.message-video{max-height:240px}}
