.loading-screen,.login{min-height:100vh;display:grid;place-items:center}.login-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 24px #00000014;width:min(400px,92vw)}.login-card h1{margin:0 0 .25rem}.subtitle{margin:0 0 1.5rem;color:#666}.login form{display:flex;flex-direction:column;gap:1rem}.login label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:#444}.login input{padding:.65rem .75rem;border:1px solid #d0d4dc;border-radius:8px}.login button,.composer button{padding:.65rem 1rem;border:none;border-radius:8px;background:#2563eb;color:#fff;cursor:pointer}.login button:disabled,.composer button:disabled{opacity:.6;cursor:not-allowed}.error{color:#b91c1c;margin:0;font-size:.9rem}.layout{min-height:100vh;display:flex;flex-direction:column}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e5e7eb}.header h1{margin:0;font-size:1.25rem}.user-name{font-size:.85rem;color:#666}.header-actions{display:flex;gap:.5rem}.ghost{background:transparent;border:1px solid #d0d4dc;border-radius:8px;padding:.45rem .75rem;cursor:pointer}.main{flex:1;display:flex;gap:0;overflow:hidden}.chat{flex:1;display:flex;flex-direction:column;min-width:0}.messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.empty,.empty-list{color:#888;text-align:center;margin:2rem 0}.bubble{max-width:75%;padding:.75rem 1rem;border-radius:12px;line-height:1.45;white-space:pre-wrap}.bubble.user{align-self:flex-end;background:#2563eb;color:#fff;border-bottom-right-radius:4px}.bubble.assistant{align-self:flex-start;background:#fff;border:1px solid #e5e7eb;border-bottom-left-radius:4px}.bubble.typing{color:#666;font-style:italic}.composer{display:flex;gap:.5rem;padding:1rem 1.5rem;background:#fff;border-top:1px solid #e5e7eb}.composer input{flex:1;padding:.75rem 1rem;border:1px solid #d0d4dc;border-radius:8px}.list-panel{width:280px;background:#fff;border-left:1px solid #e5e7eb;padding:1rem 1.25rem;overflow-y:auto}.list-panel-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:1rem}.list-panel h2{margin:0;font-size:1rem}.ghost.small{padding:.25rem .5rem;font-size:.75rem;white-space:nowrap}.past-cycles{margin-bottom:1rem}.past-cycles-label{display:block;font-size:.8rem;color:#666;margin-bottom:.35rem}.past-cycles select{width:100%;padding:.5rem;border:1px solid #d0d4dc;border-radius:8px;font-size:.85rem;background:#fff}.list-panel ul.read-only{opacity:.9}.list-panel ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.list-panel li{display:flex;flex-wrap:wrap;gap:.35rem;align-items:baseline;font-size:.95rem}.qty{font-weight:600;color:#2563eb;min-width:1.5rem}.notes{width:100%;font-size:.8rem;color:#888}@media(max-width:768px){.main{flex-direction:column}.list-panel{width:100%;border-left:none;border-top:1px solid #e5e7eb;max-height:200px}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f4f5f7;color:#1a1a1a}button,input{font:inherit}
