:root{color-scheme:light dark;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#1e1e1e;background-color:#f9fafb}*{box-sizing:border-box}body{margin:0;min-height:100vh}.app-shell{margin:0 auto;padding:2rem;max-width:960px}header{margin-bottom:2rem}main{background:transparent;padding:0}.page-header{margin-bottom:1.5rem}.page-header h1{margin-bottom:.5rem}.layout{display:grid;gap:1.5rem;grid-template-columns:320px 1fr}.sidebar{display:flex;flex-direction:column;gap:1.5rem}.workspace{background:#fff;border-radius:16px;box-shadow:#0f172a14 0 10px 35px;padding:1.75rem;display:flex;flex-direction:column;gap:1.5rem;min-height:560px}.panel{background:#fff;border-radius:16px;box-shadow:#0f172a14 0 10px 35px;padding:1.5rem}.panel h2{margin-top:0}.panel p{margin-top:.5rem;margin-bottom:0}.panel.guidance ul{padding-left:1.25rem;margin:.75rem 0}.panel.guidance li{margin-bottom:.35rem}.highlight{background:#eef2ff;border-radius:10px;padding:.75rem}.notice{background:#e0f2fe;border-radius:12px;padding:.75rem 1rem;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.notice button{background:transparent;border:none;color:#0369a1;cursor:pointer;font-weight:600}.notice-error{background:#fee2e2}.button{border:none;border-radius:10px;padding:.6rem 1.1rem;font-weight:600;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease;background:#0f172a;color:#fff}.button:disabled{opacity:.5;cursor:not-allowed}.button.primary{background:#2563eb;box-shadow:#2563eb4d 0 10px 20px}.button.secondary{background:#334155;box-shadow:#0f172a33 0 10px 20px}.control-panel{display:flex;flex-direction:column;gap:1rem}.connection-controls{display:flex;align-items:center;gap:1rem}.status{font-weight:600;color:#475569}.status-connected{color:#16a34a}.status-connecting{color:#f59e0b}.message-input{display:flex;gap:.75rem}.message-input input{flex:1;border-radius:10px;border:1px solid #cbd5f5;padding:.6rem .8rem;font-size:1rem}.conversation-log{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.85rem}.conversation-log.empty{display:flex;align-items:center;justify-content:center;color:#64748b;background:#f8fafc;border-radius:12px;min-height:220px}.message{border-radius:12px;padding:.85rem 1rem;background:#f1f5f9}.message-user{align-self:flex-end;background:#2563eb;color:#fff}.message-assistant{align-self:flex-start;background:#f8fafc;border:1px solid #e2e8f0}.message header{display:flex;align-items:center;gap:.5rem;margin:0 0 .5rem}.message header strong{font-size:.95rem}.message p{margin:0;white-space:pre-wrap}.streaming-indicator{font-size:.85rem;color:#64748b}.landing-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.landing-container{max-width:1100px;width:100%}.landing-header{text-align:center;margin-bottom:3rem;color:#fff}.landing-title{font-size:4rem;font-weight:700;margin:0 0 1rem;background:linear-gradient(to right,#fff,#e0e7ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-tagline{font-size:1.5rem;color:#e0e7ff;font-weight:400;max-width:700px;margin:0 auto}.landing-cta{text-align:center;margin-bottom:4rem}.landing-button{font-size:1.25rem;padding:1rem 2.5rem;box-shadow:#0000004d 0 10px 40px;transition:transform .2s ease,box-shadow .2s ease}.landing-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:#0006 0 15px 50px}.landing-button:active:not(:disabled){transform:translateY(0)}.landing-subtext{margin-top:1rem;color:#e0e7ff;font-size:.95rem}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.feature-card{background:#fffffff2;border-radius:16px;padding:2rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease;box-shadow:#0000001a 0 10px 30px}.feature-card:hover{transform:translateY(-4px);box-shadow:#0003 0 15px 40px}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{margin:0 0 .75rem;font-size:1.25rem;color:#1e1e1e}.feature-card p{margin:0;color:#4b5563;line-height:1.6}.landing-footer{text-align:center;color:#e0e7ff;font-size:1.1rem}.landing-footer p{margin:0}.access-denied{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center}.access-denied-content{background:#fff;border-radius:16px;padding:3rem;box-shadow:#0f172a26 0 20px 60px;max-width:500px}.access-denied-content h1{margin-top:0;color:#dc2626}.access-denied-content p{color:#4b5563;margin-bottom:2rem}.toast{position:fixed;top:2rem;right:2rem;min-width:300px;max-width:500px;background:#fff;border-radius:12px;box-shadow:#0003 0 10px 40px;padding:1rem 1.25rem;z-index:1000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;justify-content:space-between;gap:1rem}.toast-message{flex:1;color:#1e1e1e;line-height:1.5}.toast-close{background:transparent;border:none;color:#64748b;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .15s ease,color .15s ease;flex-shrink:0}.toast-close:hover{background:#f1f5f9;color:#1e1e1e}.toast-error{border-left:4px solid #dc2626}.toast-error .toast-message{color:#991b1b}.toast-success{border-left:4px solid #16a34a}.toast-success .toast-message{color:#15803d}.toast-info{border-left:4px solid #2563eb}.toast-info .toast-message{color:#1e40af}@media (max-width: 960px){.layout{grid-template-columns:1fr}.workspace{order:-1}.landing-title{font-size:2.5rem}.landing-tagline{font-size:1.25rem}.landing-features{grid-template-columns:1fr}.toast{top:1rem;right:1rem;left:1rem;min-width:auto}}
