*{box-sizing:border-box}body{color:#e2e8f0;background-color:#0f172a;min-height:100vh;margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{flex-direction:column;min-height:100vh;display:flex}.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#0f172a,#1e293b)}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#0f172acc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(148,163,184,.1)}.header-left{display:flex;align-items:center;gap:1rem}.logo{font-size:2.5rem;line-height:1}.header-left h1{margin:0;font-size:1.5rem;font-weight:700;color:#f1f5f9}.subtitle{margin:.25rem 0 0;font-size:.875rem;color:#94a3b8}.header-right{display:flex;align-items:center;gap:1rem}.btn-secondary{padding:.625rem 1.25rem;background:transparent;border:1px solid #475569;border-radius:.5rem;color:#e2e8f0;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#334155;border-color:#64748b}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.status-bar{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem;background:#22c55e1a;border-bottom:1px solid rgba(34,197,94,.2);font-size:.875rem;color:#86efac}.status-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-bar .separator{color:#475569}.status-bar .size{color:#94a3b8}.error-banner{padding:1rem 1.5rem;background:#ef44441a;border-bottom:1px solid rgba(239,68,68,.2);color:#fca5a5;font-size:.875rem}.error-banner strong{color:#f87171}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}.welcome-icon{font-size:5rem;margin-bottom:1.5rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.welcome h2{margin:0 0 .75rem;font-size:2rem;font-weight:700;color:#f1f5f9}.welcome p{margin:0;font-size:1.125rem;color:#94a3b8}.welcome .note{margin-top:1.5rem;padding:1rem 1.5rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:.75rem;font-size:.875rem;color:#93c5fd;line-height:1.6}.footer{padding:1rem;text-align:center;font-size:.875rem;color:#64748b;border-top:1px solid rgba(148,163,184,.1)}.footer a{color:#60a5fa;text-decoration:none;font-weight:500}.footer a:hover{text-decoration:underline}.model-loader{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.loader-icon{font-size:4rem;margin-bottom:2rem;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loader-title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#f1f5f9}.loader-subtitle{margin:0 0 2rem;color:#94a3b8}.progress-container{width:100%;max-width:400px;margin-bottom:1rem}.progress-bar{height:8px;background:#1e293b;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:4px;transition:width .3s ease}.progress-text{margin-top:.75rem;font-size:.875rem;color:#94a3b8;text-align:center}.progress-percent{font-size:1.25rem;font-weight:600;color:#60a5fa}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.messages-area{flex:1;overflow-y:auto;padding:1rem}.messages-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#64748b}.messages-empty svg{width:4rem;height:4rem;margin-bottom:1rem;opacity:.5}.messages-empty p{margin:.25rem 0}.messages-list{display:flex;flex-direction:column;gap:.5rem}.message{display:flex;gap:.75rem;max-width:85%;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-user{flex-direction:row-reverse;margin-left:auto}.message-assistant{margin-right:auto}.message-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.message-user .message-avatar{background:#3b82f6}.message-assistant .message-avatar{background:#8b5cf6}.message-content{padding:.875rem 1rem;border-radius:1rem;line-height:1.5;word-break:break-word}.message-user .message-content{background:#3b82f6;color:#fff;border-bottom-right-radius:.25rem}.message-assistant .message-content{background:#334155;color:#e2e8f0;border-bottom-left-radius:.25rem}.message-content pre{margin:.5rem 0;padding:.75rem;background:#0000004d;border-radius:.5rem;overflow-x:auto}.message-content code{font-family:SF Mono,Monaco,Consolas,monospace;font-size:.875rem}.typing-indicator{display:inline-flex;gap:4px;padding:4px 0}.typing-indicator span{width:6px;height:6px;background:#94a3b8;border-radius:50%;animation:bounce 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}.input-area{padding:1rem;border-top:1px solid rgba(148,163,184,.1);background:#0f172a80}.input-form{display:flex;gap:.75rem}.input-textarea{flex:1;padding:.875rem 1rem;background:#1e293b;border:1px solid #334155;border-radius:.75rem;color:#e2e8f0;font-size:1rem;font-family:inherit;resize:none;outline:none;transition:border-color .2s}.input-textarea::-moz-placeholder{color:#64748b}.input-textarea::placeholder{color:#64748b}.input-textarea:focus{border-color:#3b82f6}.input-textarea:disabled{opacity:.5;cursor:not-allowed}.btn-send{padding:0 1.5rem;background:#3b82f6;border:none;border-radius:.75rem;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-send:hover:not(:disabled){background:#2563eb}.btn-send:disabled{opacity:.5;cursor:not-allowed}.btn-stop{padding:0 1.5rem;background:#ef4444;border:none;border-radius:.75rem;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-stop:hover{background:#dc2626}.model-selector{position:relative;min-width:200px}.model-select{width:100%;padding:.625rem 2.5rem .625rem 1rem;background:#1e293b;border:1px solid #334155;border-radius:.5rem;color:#e2e8f0;font-size:.875rem;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;transition:border-color .2s}.model-select:focus{border-color:#3b82f6}.model-select:disabled{opacity:.5;cursor:not-allowed}.model-select option{background:#1e293b;color:#e2e8f0}.model-select optgroup{font-weight:600;color:#94a3b8}.selector-arrow{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);pointer-events:none;color:#64748b}@media(max-width:640px){.header{flex-direction:column;gap:1rem;padding:1rem}.header-left{width:100%;justify-content:center}.header-right{width:100%;flex-direction:column}.model-selector,.btn-secondary{width:100%}.message{max-width:95%}.welcome h2{font-size:1.5rem}}
