@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;700&family=DM+Mono:wght@400;500&display=swap";:root{--bg:#F5F3EE;--surface:#FFF;--surface2:#F0EDE6;--border:#D8D4CB;--border2:#E8E4DD;--text:#1A1916;--text2:#6B6760;--text3:#9E9A94;--accent:#2B5F3E;--accent-light:#E8F2EC;--accent-mid:#4A8A64;--r:10px;--rsm:6px;--sh:0 1px 3px rgba(0,0,0,.07),0 4px 12px rgba(0,0,0,.04);--ssh:0 1px 2px rgba(0,0,0,.06)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Noto Sans TC,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.6;display:flex;align-items:center;justify-content:center}.app{width:100%;max-width:920px;padding:32px 20px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:36px;width:380px;box-shadow:var(--sh);margin:auto}.brand{display:flex;align-items:center;gap:12px;margin-bottom:22px}.logo-mark{width:36px;height:36px;background:var(--accent);border-radius:var(--rsm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700}.brand .ttl{font-size:15px;font-weight:700}.brand .sub{font-size:11px;color:var(--text3);margin-top:1px}.fl{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:4px;display:block}.input{width:100%;font-size:13px;padding:9px 11px;border:1px solid var(--border);border-radius:var(--rsm);background:var(--bg);color:var(--text);font-family:Noto Sans TC,sans-serif;margin-bottom:12px}.input.code{font-family:DM Mono,monospace}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2b5f3e1a}.btn-primary{width:100%;height:38px;border-radius:var(--rsm);border:1px solid var(--accent);background:var(--accent);color:#fff;font-size:13px;cursor:pointer;font-family:Noto Sans TC,sans-serif;font-weight:600}.btn-primary:hover{background:#234e33}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.err{font-size:11px;color:#d42020;margin-bottom:8px;min-height:14px}.msg{font-size:12px;color:var(--text2);margin-bottom:16px;line-height:1.6}.menu-shell{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}.menu-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border2);background:var(--surface)}.menu-hdr-left{display:flex;align-items:center;gap:12px}.user-pill{font-size:11px;padding:3px 10px;border-radius:20px;background:var(--accent-light);color:var(--accent);border:1px solid #C4DECE;font-weight:500}.user-name{font-size:13px;font-weight:600}.user-role{font-size:11px;color:var(--text3);margin-left:6px}.btn-logout{padding:6px 14px;border-radius:var(--rsm);border:1px solid var(--border);background:transparent;color:var(--text2);font-size:12px;cursor:pointer;font-family:Noto Sans TC,sans-serif}.btn-logout:hover{background:var(--surface2);color:var(--text)}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;padding:24px}.svc-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r);padding:18px 20px;cursor:pointer;transition:all .15s;text-align:left;font-family:inherit;color:inherit;display:flex;flex-direction:column;gap:8px}.svc-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #2b5f3e1f;transform:translateY(-2px)}.svc-card:active{transform:translateY(0)}.svc-icon{font-size:28px;line-height:1;width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center}.svc-name{font-size:14px;font-weight:700;margin-top:6px}.svc-desc{font-size:11px;color:var(--text3);line-height:1.5}.svc-card.busy{opacity:.6;cursor:wait}.menu-foot{padding:14px 24px;background:var(--surface2);border-top:1px solid var(--border2);font-size:11px;color:var(--text3);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.empty-msg{padding:40px;text-align:center;color:var(--text3);font-size:12px}
