*{box-sizing:border-box;margin:0;padding:0;font-family:system-ui,Segoe UI,sans-serif}body{background:#eef2ff;padding:20px}.loading{text-align:center;padding:60px;font-size:1.2rem;color:#64748b}.container{max-width:98vw;margin:0 auto;background:#fff;border-radius:24px;box-shadow:0 10px 25px -5px #0000001a;overflow:hidden}.header{padding:16px 20px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.header h1{font-size:1.3rem;background:linear-gradient(135deg,#1e3a8a,#3b82f6);background-clip:text;-webkit-background-clip:text;color:transparent}.sub{font-size:.75rem;color:#475569;margin-top:2px}.month-nav{display:flex;gap:6px;align-items:center;background:#f1f5f9;padding:6px 14px;border-radius:40px;-webkit-user-select:none;user-select:none}.nav-arrow{background:#fff;border:1px solid #cbd5e1;padding:6px 12px;border-radius:30px;cursor:pointer;font-weight:700;font-size:.9rem;color:#1e293b;transition:all .15s}.nav-arrow:hover{background:#e2e8f0;border-color:#94a3b8}.month-display{font-weight:700;font-size:.95rem;min-width:130px;text-align:center;cursor:pointer;padding:6px 10px;border-radius:8px;color:#1e293b;position:relative}.month-display:hover{background:#e2e8f0}.month-picker-hidden{position:absolute;left:50%;top:50%;width:0;height:0;opacity:0;pointer-events:none}.today-btn{background:#10b981!important;color:#fff!important;padding:6px 14px;border-radius:30px;font-weight:600;font-size:.8rem}.legend{display:flex;gap:14px;padding:8px 20px;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.7rem;flex-wrap:wrap;align-items:center}.legend span{display:inline-flex;align-items:center;gap:4px}.legend .dot{width:10px;height:10px;border-radius:4px;display:inline-block}.phase-tag{display:inline-block;font-size:.65rem;padding:2px 10px;border-radius:20px;font-weight:600}.info-panel{background:#f9fafb;padding:6px 16px;border-radius:48px;display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:8px 20px;font-size:.7rem}.badge{color:#fff;padding:2px 10px;border-radius:32px;font-size:.65rem;white-space:nowrap}.storage-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.table-wrapper{overflow-x:auto;padding:0 0 8px}table{border-collapse:collapse;font-size:.65rem;width:100%;table-layout:fixed}th,td{border:1px solid #eef2ff;padding:4px 2px;text-align:center}th{background:#f1f5f9;font-weight:600;position:sticky;top:0;z-index:2;font-size:.7rem}.staff-name-col{position:sticky;left:0;z-index:3;background:#f1f5f9;width:90px;text-align:left;padding:4px 8px;font-size:.8rem;font-weight:600;border-right:2px solid #cbd5e1}.team-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}.date-col{padding:4px 0!important;cursor:pointer}.date-col .day-num{font-weight:700;font-size:.68rem;white-space:nowrap}.date-col .weekday{font-size:.58rem;color:#64748b}.date-col.weekend .day-num{color:#ef4444}.date-col .lunar-mini{font-size:.55rem;color:#8b5cf6;line-height:1.1}.date-col .holiday-mini{font-size:.55rem;color:#dc2626;line-height:1.1}.shift-badge{display:inline-block;padding:4px 8px;border-radius:20px;font-size:.75rem;font-weight:600;min-width:38px}.day{background:#dbeafe;color:#1e40af}.afternoon{background:#ffedd5;color:#9a3412}.off{background:#f1f5f9;color:#94a3b8}.leave{background:#f3e8ff;color:#7c3aed}.holiday-shift{background:#fecaca;color:#991b1b}.override-indicator{outline:2px solid #f59e0b;outline-offset:-1px}.staff-row:hover td{background:#f8fafc}.staff-row td.staff-name-col{background:#fff;border-right:2px solid #cbd5e1}.staff-row:hover td.staff-name-col{background:#f8fafc}.popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:999;background:#0000004d}.popup-menu{position:fixed;z-index:1000;background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000040;padding:10px 0;min-width:200px}.popup-title{padding:10px 20px 8px;font-size:.85rem;color:#475569;border-bottom:1px solid #eef2ff;margin-bottom:6px}.popup-title strong{color:#0f172a;font-size:.95rem}.opt{padding:10px 20px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:10px;border:none;background:none;width:100%;text-align:left;font-weight:500;color:#1e293b}.opt:hover{background:#f1f5f9}.opt.active-opt{font-weight:700;color:#1e40af}.opt-dot{width:12px;height:12px;border-radius:50%;display:inline-block;flex-shrink:0}.holiday-input-row{display:none;padding:8px 16px 12px;border-top:1px solid #eef2ff;margin-top:4px}.holiday-input-row.show{display:flex;gap:8px;align-items:center}.holiday-input-row input{flex:1;border:1px solid #cbd5e1;border-radius:8px;padding:6px 10px;font-size:.85rem;font-family:inherit;outline:none}.holiday-input-row input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.notes-section{padding:12px 20px;border-top:1px solid #eef2ff}.notes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.notes-header label{font-size:.75rem;font-weight:600;color:#1e293b}.notes-count{font-size:.6rem;color:#94a3b8}.notes-section textarea{width:100%;border:1px solid #e2e8f0;border-radius:12px;padding:10px 14px;font-size:.75rem;font-family:inherit;resize:vertical;min-height:60px;background:#fafbfc;line-height:1.6}.notes-section textarea:focus{outline:none;border-color:#3b82f6;background:#fff}button{background:#3b82f6;border:none;padding:4px 10px;border-radius:30px;color:#fff;cursor:pointer;font-size:.7rem}.danger-btn{background:#ef4444;padding:2px 8px;font-size:.6rem}.export-btn{background:#059669;padding:2px 8px;font-size:.6rem}.confirm-btn{background:#dc2626;padding:4px 10px;border-radius:8px;font-size:.7rem;white-space:nowrap}.group-separator td{height:6px;background:#f1f5f9;border:none;padding:0}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;background:#0006;display:flex;justify-content:center;align-items:flex-start;padding-top:40px;overflow-y:auto}.modal-content{background:#fff;border-radius:20px;width:90%;max-width:640px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eef2ff}.modal-header h3{font-size:1.1rem;color:#1e293b}.close-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#94a3b8;padding:0 4px}.close-btn:hover{color:#1e293b}.staff-mgr-btn{background:#6366f1;padding:2px 10px;font-size:.65rem}.staff-list{padding:8px 0}.staff-group-block{margin-bottom:2px}.group-header-row{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background:#f8fafc;margin:0 8px;border-radius:8px}.group-header-row input[type=color]{width:26px;height:26px;border:2px solid #e2e8f0;border-radius:50%;cursor:pointer;padding:0;background:none}.group-header-row input[type=color]::-webkit-color-swatch-wrapper{padding:0}.group-header-row input[type=color]::-webkit-color-swatch{border-radius:50%;border:none}.group-name{font-weight:700;font-size:.85rem;display:flex;align-items:center;gap:6px}.group-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.group-count{font-size:.65rem;color:#94a3b8}.staff-item{display:flex;align-items:center;padding:6px 16px 6px 28px;gap:8px;font-size:.8rem}.staff-item:hover{background:#f8fafc}.staff-name{font-weight:600;min-width:80px;color:#1e293b}.staff-patterns{flex:1;font-size:.65rem;color:#64748b}.staff-actions{display:flex;gap:4px;align-items:center}.staff-actions select{font-size:.65rem;padding:2px 6px;border:1px solid #e2e8f0;border-radius:6px;color:#64748b}.danger-sm{background:#ef4444;border:none;color:#fff;padding:2px 8px;border-radius:6px;cursor:pointer;font-size:.7rem}.add-group-btn,.add-staff-btn{background:none;border:2px dashed #cbd5e1;color:#64748b;padding:8px;margin:4px 16px;border-radius:10px;cursor:pointer;font-size:.75rem;width:calc(100% - 32px)}.add-group-btn:hover,.add-staff-btn:hover{border-color:#3b82f6;color:#3b82f6}.add-staff-form{margin:8px 16px;padding:12px;background:#f8fafc;border-radius:12px;border:1px solid #eef2ff}.add-staff-form h4{font-size:.85rem;margin-bottom:10px;color:#1e293b}.form-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.form-row label{min-width:80px;font-size:.7rem;font-weight:600;color:#64748b}.form-row input{flex:1;border:1px solid #cbd5e1;border-radius:8px;padding:6px 10px;font-size:.8rem;font-family:inherit}.form-row input:focus{outline:none;border-color:#3b82f6}.form-row select{border:1px solid #cbd5e1;border-radius:8px;padding:6px 10px;font-size:.8rem;font-family:inherit}.day-toggles{display:flex;gap:4px;flex-wrap:wrap}.toggle-btn{background:#e2e8f0;color:#64748b;border:none;padding:4px 8px;border-radius:8px;cursor:pointer;font-size:.7rem;font-weight:500}.toggle-btn.active{background:#3b82f6;color:#fff}.form-btns{display:flex;gap:8px;margin-top:10px}.primary-btn{background:#3b82f6;padding:6px 16px}.secondary-btn{background:#e2e8f0;color:#1e293b;padding:6px 16px}.modal-footer{display:flex;gap:8px;padding:12px 20px;border-top:1px solid #eef2ff;justify-content:flex-end}.footer{padding:8px 20px;font-size:.65rem;color:#4b5563;border-top:1px solid #eef2ff;background:#fefefe}
