:root{color:#2f3e46;background:#f7f1ea;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}button{border:0;cursor:pointer}.shell{min-height:100vh;background:linear-gradient(135deg,#bee0d2d9,#f7f1eaf2),#f7f1ea}.login-view{display:grid;min-height:100vh;place-items:center;padding:24px}.login-panel{display:grid;width:min(420px,100%);gap:18px;padding:32px;border:1px solid rgba(47,62,70,.12);border-radius:8px;background:#fffcf8eb;box-shadow:0 24px 70px #2f3e461f}.eyebrow{margin:0 0 6px;color:#6b9080;font-size:.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase}h1{margin:0;color:#24333a;font-size:clamp(2rem,5vw,3rem);line-height:1}label{display:grid;gap:8px;color:#43545b;font-weight:700}input{width:100%;border:1px solid rgba(47,62,70,.16);border-radius:8px;padding:13px 14px;color:#24333a;background:#fffdf9}.login-panel button,.controls button{border-radius:8px;padding:12px 16px;color:#fff;background:#6b9080;font-weight:800}.login-panel button:disabled{cursor:progress;opacity:.65}.dashboard{width:min(1180px,100%);margin:0 auto;padding:32px 18px}.topbar{display:flex;gap:20px;align-items:center;justify-content:space-between;margin-bottom:24px}.userbox{display:flex;gap:10px;align-items:center;padding:10px 12px;border:1px solid rgba(47,62,70,.12);border-radius:8px;background:#fffcf8b8}.userbox span{font-weight:800}.userbox small{color:#6b9080;font-weight:700}.ghost{border:1px solid rgba(47,62,70,.14);border-radius:8px;padding:9px 12px;color:#2f3e46;background:#fffdf9}.controls{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.controls button{color:#44615a;background:#ddebd8}.controls button.active{color:#fff;background:#5f7f74}.stats{display:grid;grid-template-columns:repeat(5,minmax(150px,1fr));gap:12px;margin-bottom:16px}.stats article,.chart-panel,.notice{border:1px solid rgba(47,62,70,.12);border-radius:8px;background:#fffcf8d6;box-shadow:0 16px 40px #2f3e4614}.stats article{display:grid;gap:6px;min-height:112px;padding:16px}.stats span{color:#607078;font-size:.9rem;font-weight:700}.stats strong{color:#24333a;font-size:1.8rem}.stats small{color:#7a8a91;font-weight:700}.chart-panel{height:min(58vh,540px);min-height:360px;padding:18px}.notice{padding:18px;color:#775d23;background:#fff4ce}.error{margin:0;color:#9c3d3d;font-weight:800}@media(max-width:840px){.topbar{align-items:flex-start;flex-direction:column}.stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:520px){.stats{grid-template-columns:1fr}.userbox{align-items:stretch;flex-direction:column;width:100%}}
