:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Noto Sans TC,sans-serif;color:#0f172a;background:#f1f5f9}*{box-sizing:border-box}body{margin:0}a{color:inherit;text-decoration:none}.shell{display:flex;min-height:100vh}.sidebar{width:220px;background:#0f172a;color:#e2e8f0;display:flex;flex-direction:column;padding:1rem;gap:1rem}.brand{font-weight:700;font-size:1rem}.sidebar nav{display:flex;flex-direction:column;gap:.25rem}.sidebar nav a{padding:.5rem .75rem;border-radius:6px}.sidebar nav a.active{background:#334155}.logout{margin-top:auto;padding:.5rem;background:#1e293b;color:#e2e8f0;border:none;border-radius:6px;cursor:pointer}.main{flex:1;padding:1.5rem}.card{background:#fff;border-radius:10px;padding:1.25rem;box-shadow:0 1px 3px #0f172a14;margin-bottom:1rem}.grid2{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.stat{font-size:1.75rem;font-weight:700}.muted{color:#64748b;font-size:.875rem}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{text-align:left;padding:.5rem .4rem;border-bottom:1px solid #e2e8f0}button.primary{background:#2563eb;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer}input,textarea,select{width:100%;padding:.45rem .5rem;border:1px solid #cbd5e1;border-radius:6px}.form-row{margin-bottom:.75rem}.error{color:#b91c1c;font-size:.875rem}.login-wrap{max-width:360px;margin:4rem auto}.messages{max-height:420px;overflow:auto;border:1px solid #e2e8f0;border-radius:8px;padding:.75rem;background:#f8fafc}.msg-in{margin:.35rem 0;padding:.35rem .5rem;background:#fff;border-radius:6px}.msg-out{margin:.35rem 0;padding:.35rem .5rem;background:#dbeafe;border-radius:6px}
