.chat-page{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.chat-empty{margin:auto;text-align:center;color:#555}.chat-empty h3{font-size:1.3rem;color:#777;margin-bottom:.3rem}.chat-msg{max-width:75%;display:flex;flex-direction:column;gap:4px}.chat-msg--user{align-self:flex-end}.chat-msg--assistant{align-self:flex-start}.chat-msg-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#666;padding:0 4px}.chat-msg-body{padding:.75rem 1rem;border-radius:12px;font-size:.92rem;line-height:1.6}.chat-msg--user .chat-msg-body{background:#1a1a2e;color:#d0d0f0;border-bottom-right-radius:4px}.chat-msg--assistant .chat-msg-body{background:#1a1a1a;border:1px solid #2a2a2a;border-bottom-left-radius:4px}.chat-msg--assistant .chat-msg-body p{margin:.4em 0}.chat-msg--assistant .chat-msg-body pre{background:#111;padding:.75rem;border-radius:6px;overflow-x:auto;margin:.5em 0;font-size:.85rem}.chat-msg--assistant .chat-msg-body code{font-family:Cascadia Code,Fira Code,monospace}.chat-msg--assistant .chat-msg-body p code{background:#222;padding:.15em .35em;border-radius:3px;font-size:.88em}.chat-input-bar{display:flex;align-items:flex-end;gap:8px;padding:.75rem 1rem;border-top:1px solid #222;background:#141414}.model-select{background:#1a1a1a;border:1px solid #333;color:#ccc;padding:.5rem;border-radius:6px;font-size:.8rem;cursor:pointer}.chat-input{flex:1;background:#1a1a1a;border:1px solid #333;color:#e0e0e0;padding:.6rem .75rem;border-radius:8px;font-size:.92rem;resize:none;font-family:inherit;outline:none}.chat-input:focus{border-color:#d97706}.chat-input::placeholder{color:#555}.send-btn{background:#d97706;color:#fff;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.92rem;cursor:pointer;white-space:nowrap}.send-btn:hover{background:#b45309}.send-btn:disabled{background:#333;color:#666;cursor:not-allowed}.settings-page{padding:2rem;max-width:600px}.settings-page h2{font-size:1.4rem;color:#fff;margin-bottom:1.5rem}.settings-section{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:10px;padding:1.25rem;margin-bottom:1rem}.settings-section h3{font-size:1rem;color:#ccc;margin-bottom:.75rem}.auth-status-row{display:flex;align-items:center;gap:8px;font-size:.9rem;margin-bottom:1rem}.auth-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.auth-dot.ok{background:#4ade80}.auth-dot.off{background:#f87171}.auth-dot.checking{background:#7b8cde}.token-expiry{font-size:.8rem;color:#999;margin-bottom:.75rem}.token-expiry.expired{color:#f87171}.auth-instructions{background:#111;padding:.75rem;border-radius:6px;font-size:.85rem}.auth-instructions p{color:#999;margin-bottom:.5rem}.auth-instructions ol{color:#bbb;padding-left:1.25rem;margin-bottom:.75rem;line-height:1.6}.auth-instructions li{margin-bottom:.25rem}.auth-command{display:block;background:#0a0a0a;border:1px solid #333;border-radius:6px;padding:.6rem .75rem;color:#4ade80;font-family:monospace;font-size:.8rem;word-break:break-all;margin-bottom:.75rem;-webkit-user-select:all;user-select:all}.creds-input{width:100%;background:#0a0a0a;border:1px solid #333;border-radius:6px;color:#fff;padding:.6rem .75rem;font-family:monospace;font-size:.8rem;resize:vertical;margin-bottom:.5rem;box-sizing:border-box}.creds-input::placeholder{color:#555}.login-btn{background:#d97706;color:#fff;border:none;border-radius:8px;padding:.7rem 1.4rem;font-size:.95rem;cursor:pointer;width:100%}.login-btn:hover{background:#b45309}.login-btn:disabled{background:#333;color:#888;cursor:not-allowed}.settings-hint{color:#666;font-size:.8rem;margin-bottom:.5rem}.apikey-row{display:flex;gap:.5rem}.apikey-row input{flex:1;background:#0a0a0a;border:1px solid #333;border-radius:6px;color:#fff;padding:.5rem .75rem;font-size:.85rem}.apikey-row input::placeholder{color:#555}.apikey-row button{background:#d97706;color:#fff;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;cursor:pointer;white-space:nowrap}.apikey-row button:hover{background:#b45309}.apikey-row button:disabled{background:#333;color:#888;cursor:not-allowed}.polling-status{color:#7b8cde;text-align:center;margin-top:.5rem}.settings-error{color:#f87171;font-size:.85rem;margin-top:.5rem}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f0f0f;color:#e0e0e0;min-height:100vh}a{color:#d97706;text-decoration:none}a:hover{text-decoration:underline}.app{display:flex;height:100vh}.sidebar{background:#141414;border-right:1px solid #222;display:flex;flex-direction:column;transition:width .2s}.sidebar.open{width:220px}.sidebar.closed{width:52px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;gap:8px}.sidebar-header h2{font-size:1rem;color:#fff;white-space:nowrap;overflow:hidden}.sidebar.closed .sidebar-header h2{display:none}.sidebar-toggle{background:none;border:1px solid #333;color:#888;border-radius:4px;width:28px;height:28px;cursor:pointer;font-size:.85rem;flex-shrink:0}.sidebar-toggle:hover{color:#fff;border-color:#555}.sidebar-nav{display:flex;flex-direction:column;padding:0 .5rem;gap:2px}.sidebar-nav a{padding:.6rem .75rem;border-radius:6px;color:#aaa;font-size:.9rem;text-decoration:none}.sidebar-nav a:hover{background:#1f1f1f;color:#fff;text-decoration:none}.sidebar-nav a.active{background:#1a1a2e;color:#d97706}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.auth-banner{background:#2e2000;border-bottom:1px solid #4a3500;color:#f5c542;padding:.6rem 1rem;font-size:.85rem;text-align:center;flex-shrink:0}.auth-banner a{color:#fbbf24;font-weight:600;text-decoration:underline}
