*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,sans-serif;background:#fafaf9;color:#292524}.shift-grid-wrap{overflow-x:auto;border:1px solid #e7e5e4;border-radius:8px}.shift-table{border-collapse:collapse;min-width:100%}.shift-table th.emp-col,.shift-table td.emp-col{position:sticky;left:0;z-index:2;background:#fff;min-width:120px;max-width:140px}.shift-table th.emp-col{background:#f5f5f4;z-index:3}.shift-table thead th{position:sticky;top:0;z-index:1}.shift-table th.emp-col{z-index:4}.shift-table th{background:#f5f5f4;padding:6px 4px;text-align:center;font-weight:500;font-size:12px;color:#57534e;border-bottom:1px solid #e7e5e4;white-space:nowrap}.shift-table th.weekend{background:#fef3c7;color:#92400e}.shift-table th.sunday{background:#fee2e2;color:#991b1b}.shift-table td{padding:3px;border-bottom:1px solid #f5f5f4;border-left:1px solid #f5f5f4;vertical-align:top;min-height:44px;height:44px;cursor:pointer;background:#fff}.shift-table td.weekend{background:#fffbeb}.shift-table td.sunday{background:#fff1f2}.shift-table td:hover{background:#f0f9ff!important}.shift-block{border-radius:4px;padding:2px 4px;font-size:11px;line-height:1.35;cursor:pointer;-webkit-user-select:none;user-select:none}.shift-block.draft{background:#fed7aa;border:1px solid #fb923c;color:#9a3412}.shift-block.published{background:#c2410c;color:#fff}.shift-block:hover{opacity:.85}.add-hint{display:none;align-items:center;justify-content:center;height:38px;color:#d4d4d4}.shift-table td:hover .add-hint{display:flex}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}.modal-card{background:#fff;border-radius:12px;padding:24px;width:100%;max-width:480px;box-shadow:0 20px 60px #00000040;max-height:90vh;overflow-y:auto}:root{--border: #e7e5e4;--muted: #78716c;--primary: #c2410c;--primary-hover: #9a3412}
