*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-message-user: #0f3460;--bg-message-assistant: #1a1a2e;--bg-message-system: #2d2d44;--text-primary: #eee;--text-secondary: #aaa;--text-muted: #666;--accent: #0f3460;--accent-hover: #1a4a7a;--border: #2d2d44;--error: #e74c3c;--success: #27ae60}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;min-height:100dvh;font-size:16px;line-height:1.5}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;max-width:800px;margin:0 auto;width:100%}.header{padding:.75rem 1rem;background-color:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.header h1{font-size:1.125rem;font-weight:600}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat{display:flex;flex-direction:column;flex:1;overflow:hidden}.chat.loading{align-items:center;justify-content:center;color:var(--text-secondary)}.message-list{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.message-list.empty{align-items:center;justify-content:center;color:var(--text-muted)}.message{padding:.75rem 1rem;border-radius:.5rem;max-width:85%}.message-user{background-color:var(--bg-message-user);align-self:flex-end;margin-left:auto}.message-assistant{background-color:var(--bg-message-assistant);border:1px solid var(--border);align-self:flex-start}.message-system{background-color:var(--bg-message-system);align-self:center;font-style:italic;font-size:.875rem;color:var(--text-secondary)}.message-role{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.05em}.message-content{white-space:pre-wrap;word-break:break-word}.message-input{display:flex;gap:.5rem;padding:.75rem 1rem;background-color:var(--bg-secondary);border-top:1px solid var(--border)}.message-input textarea{flex:1;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;background-color:var(--bg-primary);color:var(--text-primary);font-family:inherit;font-size:1rem;resize:none;min-height:44px;max-height:150px}.message-input textarea:focus{outline:none;border-color:var(--accent-hover)}.message-input textarea::placeholder{color:var(--text-muted)}.message-input button{padding:.75rem 1.25rem;border:none;border-radius:.5rem;background-color:var(--accent);color:var(--text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;min-width:70px}.message-input button:hover:not(:disabled){background-color:var(--accent-hover)}.message-input button:disabled{opacity:.5;cursor:not-allowed}.message-input .cancel-btn{background-color:var(--error)}.message-input .cancel-btn:hover{background-color:#c0392b}.status-bar{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background-color:var(--bg-secondary);border-top:1px solid var(--border);font-size:.75rem;color:var(--text-secondary)}.status-left{display:flex;align-items:center;gap:.5rem}.status-right{display:flex;align-items:center;gap:.75rem}.status-streaming{color:var(--success)}.status-error{color:var(--error)}.status-session{font-family:monospace}.status-cost{font-family:monospace;color:var(--text-muted)}.clear-btn{padding:.25rem .5rem;border:1px solid var(--border);border-radius:.25rem;background:transparent;color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .2s}.clear-btn:hover{border-color:var(--error);color:var(--error)}@media(max-width:600px){.message{max-width:95%}.message-input,.message-input textarea{padding:.5rem}.message-input button{padding:.5rem 1rem}}.message-list::-webkit-scrollbar{width:6px}.message-list::-webkit-scrollbar-track{background:transparent}.message-list::-webkit-scrollbar-thumb{background-color:var(--border);border-radius:3px}.message-list::-webkit-scrollbar-thumb:hover{background-color:var(--text-muted)}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:1rem}.login-box{width:100%;max-width:320px;padding:2rem;background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;text-align:center}.login-box h2{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.login-subtitle{color:var(--text-secondary);font-size:.875rem;margin-bottom:1.5rem}.login-box form{display:flex;flex-direction:column;gap:1rem}.login-box input{padding:.75rem 1rem;border:1px solid var(--border);border-radius:.5rem;background-color:var(--bg-primary);color:var(--text-primary);font-size:1rem;width:100%}.login-box input:focus{outline:none;border-color:var(--accent-hover)}.login-box input::placeholder{color:var(--text-muted)}.login-box button{padding:.75rem 1rem;border:none;border-radius:.5rem;background-color:var(--accent);color:var(--text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.login-box button:hover:not(:disabled){background-color:var(--accent-hover)}.login-box button:disabled{opacity:.5;cursor:not-allowed}.login-error{color:var(--error);font-size:.875rem;text-align:left}.logout-btn{padding:.25rem .5rem;border:1px solid var(--border);border-radius:.25rem;background:transparent;color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .2s}.logout-btn:hover{border-color:var(--error);color:var(--error)}.loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;color:var(--text-secondary)}
