*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--border:#2a2d3d;--accent:#6c8ef5;--text:#e2e4ed;--muted:#8b8fa8;--error:#e05c5c;--success:#4caf82;--radius:.533em;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.6}body{background:var(--bg);color:var(--text);height:100dvh}#root,.app{flex-direction:column;height:100%;display:flex}.navbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:4.667em;padding:0 1.6em;display:flex}.navbar-brand{letter-spacing:-.02em;color:var(--accent);font-size:2.2em;font-weight:700}.navbar-nav{align-items:center;gap:1.333em;display:flex}.navbar-nav a{color:var(--muted);font-size:.933em;text-decoration:none;transition:color .15s}.navbar-nav a:hover{color:var(--text)}.navbar-link-active{display:none}.navbar-user{color:var(--muted);font-size:.933em;text-decoration:none;transition:color .15s}.navbar-user:hover{color:var(--text)}.btn-logout{border:1px solid var(--border);color:var(--muted);border-radius:var(--radius);cursor:pointer;background:0 0;padding:.333em .8em;font-size:.867em;transition:all .15s}.btn-logout:hover{border-color:var(--accent);color:var(--text)}.navbar-mobile{display:none;position:relative}.hamburger{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:0 0;flex-direction:column;justify-content:center;gap:5px;width:2.6em;height:2.6em;padding:.5em .6em;display:flex}.hamburger span{background:var(--text);transform-origin:50%;border-radius:2px;height:2px;transition:transform .2s,opacity .2s;display:block}.hamburger-open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger-open span:nth-child(2){opacity:0}.hamburger-open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);z-index:100;flex-direction:column;gap:.2em;min-width:11em;padding:.6em;display:flex;position:absolute;top:calc(100% + .6em);right:0;box-shadow:0 .4em 1.6em #0006}.mobile-menu a,.mobile-menu .navbar-user{color:var(--muted);border-radius:calc(var(--radius) - 2px);padding:.6em .8em;font-size:.933em;text-decoration:none;transition:background .15s,color .15s;display:block}.mobile-menu a:hover,.mobile-menu .navbar-user:hover{background:var(--bg);color:var(--text)}.mobile-menu .btn-logout{text-align:left;border-radius:calc(var(--radius) - 2px);border:none;width:100%;margin-top:.2em;padding:.6em .8em;font-size:.933em}.mobile-menu .btn-logout:hover{background:var(--bg);border-color:#0000}@media (width<=640px){.navbar-desktop{display:none}.navbar-mobile{display:block}}.main-content{flex-direction:column;flex:1;display:flex;overflow-y:auto}.auth-page{flex:1;justify-content:center;align-items:center;display:flex}.auth-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:1.067em;width:100%;max-width:26.667em;padding:2.667em;display:flex}.auth-form h1{margin-bottom:.267em;font-size:1.467em}.auth-form input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;padding:.667em .933em;font-size:.933em;transition:border-color .15s}.auth-form input:focus{border-color:var(--accent)}.auth-form button{background:var(--accent);border-radius:var(--radius);color:#fff;cursor:pointer;border:none;padding:.733em;font-size:.933em;font-weight:600;transition:opacity .15s}.auth-form button:disabled{opacity:.5;cursor:not-allowed}.auth-link{color:var(--muted);text-align:center;font-size:.867em}.auth-link a{color:var(--accent);text-decoration:none}.auth-hint{color:var(--muted);font-size:.8em}.error{border:1px solid var(--error);color:var(--error);border-radius:var(--radius);background:#e05c5c1a;padding:.667em .933em;font-size:.867em}.success{border:1px solid var(--success);color:var(--success);border-radius:var(--radius);background:#4caf821a;padding:.667em .933em;font-size:.867em}.chat-page{flex-direction:column;flex:1;width:100%;max-width:57.333em;margin:0 auto;padding:0 1.067em;display:flex;overflow:hidden}.chat-messages{flex-direction:column;flex:1;gap:1.067em;padding:1.6em 0;display:flex;overflow-y:auto}.chat-empty{color:var(--muted);text-align:center;margin-top:4em}.chat-stats{color:var(--muted);text-align:right;margin:0;padding:.4em 0 0;font-size:.78em}.message{flex-direction:column;gap:.4em;max-width:80%;display:flex}.message-user{align-self:flex-end;align-items:flex-end}.message-assistant,.message-error{align-self:flex-start}.message-label{text-transform:uppercase;letter-spacing:.033em;color:var(--muted);font-size:.733em;font-weight:600}.message-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);white-space:pre-wrap;padding:.8em 1.067em;font-size:.933em;line-height:1.7}.message-user .message-content{background:var(--accent);border-color:var(--accent);color:#fff}.message-error .message-content{border-color:var(--error);color:var(--error)}.message-sources{color:var(--muted);cursor:pointer;font-size:.8em}.message-sources summary{-webkit-user-select:none;user-select:none}.message-sources ul{flex-direction:column;gap:.133em;margin-top:.4em;padding-left:1.067em;display:flex}.typing{color:var(--muted)}.chat-form{border-top:1px solid var(--border);flex-shrink:0;align-items:flex-end;gap:.667em;padding:1.067em 0 1.6em;display:flex}.chat-form textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);resize:none;outline:none;flex:1;max-height:10.667em;padding:.733em 1.067em;font-family:inherit;font-size:.933em;line-height:1.5;transition:border-color .15s;overflow-y:auto}.chat-form textarea:focus{border-color:var(--accent)}.chat-form button{background:var(--accent);border-radius:var(--radius);color:#fff;cursor:pointer;white-space:nowrap;border:none;flex-shrink:0;padding:.733em 1.333em;font-size:.933em;font-weight:600;transition:opacity .15s}.chat-form button:disabled{opacity:.4;cursor:not-allowed}.api-key-banner{border:1px solid var(--error);border-radius:var(--radius);max-width:33.333em;color:var(--text);background:#e05c5c14;margin:2.667em auto;padding:1.333em 1.6em;font-size:.933em;line-height:1.6}.api-key-banner a{color:var(--accent);text-decoration:none}.api-key-banner a:hover{text-decoration:underline}.profile-page{flex-direction:column;flex:1;gap:2.133em;width:100%;max-width:42.667em;margin:0 auto;padding:2.667em 1.067em;display:flex;overflow-y:auto}.profile-page h1{font-size:1.467em}.profile-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.533em;padding:1.6em;display:flex}.profile-section h2{margin-bottom:.533em;font-size:1.067em}.profile-form{flex-direction:column;gap:1.6em;display:flex}.profile-field{flex-direction:column;gap:.4em;display:flex}.profile-field label{color:var(--text);font-size:.867em;font-weight:600}.profile-field input[type=password],.profile-field input[type=text]{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;padding:.667em .933em;font-size:.933em;transition:border-color .15s}.profile-field input[type=password]:focus,.profile-field input[type=text]:focus{border-color:var(--accent)}.profile-field input[type=range]{accent-color:var(--accent);width:100%}.profile-hint{color:var(--muted);font-size:.8em}.profile-key-row{align-items:center;display:flex}.profile-key-active{color:#4caf82;margin:0;font-size:.867em;font-weight:500}.profile-section .profile-key-delete{border:1px solid var(--muted);color:var(--muted);cursor:pointer;opacity:.7;background:0 0;border-radius:.267em;margin-left:auto;padding:.2em .533em;font-size:.733em;font-weight:400;transition:border-color .15s,color .15s,opacity .15s}.profile-section .profile-key-delete:hover{color:#c0392b;opacity:1;border-color:#c0392b}.profile-key-missing{color:var(--muted);font-size:.867em}.profile-link{color:var(--accent);font-size:.867em;text-decoration:none}.profile-link:hover{text-decoration:underline}.profile-section button{background:var(--accent);border-radius:var(--radius);color:#fff;cursor:pointer;border:none;align-self:flex-start;padding:.733em 1.6em;font-size:.933em;font-weight:600;transition:opacity .15s}.profile-section button:disabled{opacity:.5;cursor:not-allowed}.profile-back{color:var(--muted);font-size:.867em;text-decoration:none}.profile-back:hover{color:var(--text)}.home-page{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3.2em;min-height:min-content;padding:2.667em 1.067em;display:flex}.home-hero{text-align:center;flex-direction:column;gap:.667em;display:flex}.home-title{color:var(--accent);letter-spacing:-.02em;font-size:3.2em;font-weight:700}.home-subtitle{color:var(--muted);font-size:1.2em}.home-cards{flex-wrap:wrap;justify-content:center;align-items:stretch;gap:1.6em;display:flex}.home-card{background:var(--surface);border:1px solid var(--border);width:18.667em;color:var(--text);text-align:center;border-radius:.8em;flex-direction:column;align-items:center;gap:.8em;padding:2.4em 2.133em;text-decoration:none;transition:border-color .2s,transform .2s,box-shadow .2s;display:flex}.home-card:hover{transform:translateY(-3px)}.home-card:not(.home-card-dark):hover{border-color:var(--accent);box-shadow:0 .533em 2.133em #6c8ef51f}.home-card-dark:hover{border-color:#a78bfa;box-shadow:0 .533em 2.133em #a78bfa1f}.home-card-icon{font-size:2.4em;line-height:1}.home-card h2{font-size:1.35em;font-weight:700}.home-card p{color:var(--muted);font-size:1em;line-height:1.6}.home-card-cta{color:var(--accent);margin-top:auto;padding-top:.533em;font-size:.95em;font-weight:600}.home-card-dark .home-card-cta{color:#a78bfa}.home-logo{filter:brightness(0)invert();width:auto;height:4em;margin-top:auto}.admin-page{flex-direction:column;flex:1;gap:1.6em;width:100%;max-width:56em;margin:0 auto;padding:2.667em 1.067em;display:flex;overflow-y:auto}.admin-page h1{font-size:1.467em}.admin-table-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.9em}.admin-table th{background:var(--surface);text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:.8em 1em;font-size:.8em;font-weight:600}.admin-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:.8em 1em}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:#ffffff05}.admin-row-self{opacity:.6}.admin-muted{color:var(--muted);font-size:.9em}.admin-role-tag{background:var(--border);color:var(--muted);border-radius:999px;padding:.2em .6em;font-size:.8em}.admin-role-select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;outline:none;padding:.3em .6em;font-size:.867em;transition:border-color .15s}.admin-role-select:focus{border-color:var(--accent)}.admin-btn-delete{border:1px solid var(--border);color:var(--muted);border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:0 0;padding:.267em .667em;font-size:.8em;transition:border-color .15s,color .15s}.admin-btn-delete:hover{border-color:var(--error);color:var(--error)}.shadowbroker-frame{border:none;flex:1;width:100%;display:block}
