:root{color:#18202b;background:#f4f6f8;font-family:Inter,Noto Sans TC,Microsoft JhengHei,system-ui,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;gap:18px;align-items:center;padding:16px 20px;background:#fffffff5;border-bottom:1px solid #d9dee6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar h1,.login-panel h1{margin:0;font-size:24px;line-height:1.15}.topbar p{margin:5px 0 0;color:#647080}.actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.month-picker{display:inline-flex;align-items:center;gap:7px;min-height:38px;border-radius:7px;padding:0 10px;font-weight:700;color:#1f2937;background:#f5f7fa;border:1px solid #d8dee8}.month-picker input{width:132px;min-height:30px;border:0;background:transparent;color:inherit;font-weight:700}.primary,.ghost,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:38px;border-radius:7px;padding:0 13px;font-weight:700}.primary{color:#fff;background:#276749}.ghost{color:#1f2937;background:#e9edf2}.small{min-height:30px;padding:0 9px;font-size:13px}.icon-button{width:30px;min-height:30px;padding:0;background:#ffffff8c;color:#172033}.error-bar{margin:12px 20px 0;padding:10px 12px;border-left:4px solid #b42318;background:#fff1f0;color:#7a271a;border-radius:6px}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:#eef2f6}.login-panel{width:min(380px,100%);display:grid;gap:14px;padding:24px;border:1px solid #d8dee8;border-radius:8px;background:#fff;box-shadow:0 20px 60px #0f172a14}.login-panel label{display:grid;gap:6px;font-weight:700}.login-panel input,.swap-inline select{width:100%;min-height:38px;border:1px solid #cfd6df;border-radius:7px;padding:0 10px;background:#fff}.workspace{padding:16px 20px 28px}.legend{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}.legend-item{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid #d8dee8;border-radius:8px;background:#fff}.legend-item span:last-child{color:#647080}.shift-dot{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:6px;font-weight:900}.grid-wrap{overflow:auto;border:1px solid #d1d8e2;background:#fff}.schedule-grid{display:grid;min-width:2220px}.grid-head,.employee-name,.grid-cell{min-height:68px;border-right:1px solid #d8dee6;border-bottom:1px solid #d8dee6}.grid-head{display:grid;place-items:center;background:#f8fafc;color:#2b3442;font-size:13px}.grid-head strong{font-size:17px}.grid-head span{color:#6c7685}.weekend{background:#fff0bf}.sticky-name{position:sticky;left:0;z-index:2;box-shadow:1px 0 #d8dee6}.employee-name{display:flex;align-items:center;padding:0 12px;font-weight:800;background:#f7f9fb}.grid-cell{display:flex;align-items:stretch;justify-content:center;padding:5px;background:#fff}.grid-cell.is-over{outline:3px solid #1f7a56;outline-offset:-3px}.assignment-card{width:100%;min-height:58px;display:grid;align-content:center;justify-items:center;gap:2px;border-radius:6px;color:#122033;touch-action:none;-webkit-user-select:none;user-select:none;box-shadow:inset 0 -1px #00000014}.assignment-card strong{font-size:20px}.assignment-card span{font-size:12px;font-weight:700}.assignment-card.dragging{opacity:.72;z-index:20}.shift-A{background:#f8b84e}.shift-B{background:#5fc181}.shift-C{background:#5d89db}.swap-inline{width:100%;display:grid;grid-template-columns:1fr 30px;gap:4px;padding:3px}.swap-inline select{min-height:30px;font-size:12px;padding:0 4px}.lower-panels{display:grid;grid-template-columns:minmax(420px,2fr) minmax(240px,1fr) minmax(240px,1fr);gap:14px;margin-top:14px}.panel{border:1px solid #d8dee8;border-radius:8px;background:#fff;padding:14px}.panel h2{margin:0 0 12px;font-size:17px}.coverage-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:7px}.coverage-pill{display:flex;justify-content:space-between;gap:6px;padding:8px;border-radius:7px;background:#eef2f6}.coverage-pill.ok{background:#e4f6ec;color:#155238}.coverage-pill.short{background:#fff0d5;color:#7a4a00}.coverage-pill.over{background:#ffe4e0;color:#8a1f11}.hours-list,.swap-list{display:grid;gap:8px}.hours-row,.swap-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #edf0f4}.hours-row:last-child,.swap-row:last-child{border-bottom:0}.muted{color:#778293}.empty-state{display:grid;place-items:center;min-height:320px}@media(max-width:920px){.topbar{align-items:flex-start;flex-direction:column}.actions{justify-content:flex-start}.lower-panels{grid-template-columns:1fr}}
