*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.dashboard-header{background-color:#524fa1;color:#fff;padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:200}.event-list-modal{background:#fff;border-radius:16px;max-width:600px;width:90%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #211d5726}.event-list-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #E8E7F5}.event-list-title{font-size:20px;font-weight:700;color:#2e2a5c;margin:0}.event-list-add-button{width:40px;height:40px;border-radius:20px;background:#524fa1;border:none;color:#fff;font-size:24px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #524fa14d;transition:transform .2s,box-shadow .2s}.event-list-add-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #524fa166}.event-list-add-button:active{transform:translateY(0)}.event-list-content{flex:1;overflow-y:auto;padding:16px 20px;min-height:200px}.event-list-items{display:flex;flex-direction:column;gap:12px}.event-list-item{display:flex;align-items:center;background:#fff;border-radius:12px;padding:16px;cursor:pointer;border:1px solid rgba(82,79,161,.08);box-shadow:0 2px 8px #211d5714;transition:transform .2s,box-shadow .2s}.event-list-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #211d571f}.event-list-color-bar{width:4px;height:48px;border-radius:2px;margin-right:14px;flex-shrink:0}.event-list-item-content{flex:1}.event-list-item-title{font-size:16px;font-weight:600;color:#2e2a5c;margin-bottom:6px}.event-list-item-time{display:flex;align-items:center;font-size:14px;color:#6d6a9e;font-weight:500}.event-list-time-icon{font-size:14px;margin-right:6px}.event-list-chevron{font-size:24px;color:#524fa1;font-weight:300;margin-left:8px}.event-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.event-list-empty-icon{font-size:64px;margin-bottom:16px}.event-list-empty-text{font-size:16px;font-weight:600;color:#2e2a5c;margin:0 0 8px}.event-list-empty-subtext{font-size:14px;color:#6d6a9e;margin:0}.event-list-close-button{margin:0 20px 20px;padding:12px;background:#f5f6fa;border:none;border-radius:8px;font-size:15px;font-weight:600;color:#524fa1;cursor:pointer;transition:background .2s}.event-list-close-button:hover{background:#e8e9f0}.calendar-container{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000000d;position:relative}.month-title{color:#524fa1;font-size:20px;font-weight:600}.month-nav-button{background-color:#524fa1;color:#fff;border:none;border-radius:6px;padding:6px 12px;cursor:pointer}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.weekday-cell{text-align:center;font-weight:600;color:#666;padding:6px 0}.week-list{display:flex;flex-direction:column;gap:12px}.week-row{border:1px solid #E8E9F0;border-radius:10px;overflow:hidden;position:relative;background:#fff;height:154px}.week-days{display:grid;grid-template-columns:repeat(7,1fr);position:relative;z-index:1;height:100%}.calendar-day{border-right:1px solid #f1f2f6;height:100%;padding:6px;position:relative;overflow:hidden;cursor:pointer;transition:background-color .2s;display:flex;flex-direction:column}.calendar-day:hover{background-color:#524fa10d}.calendar-day *{pointer-events:none}.calendar-day:last-child{border-right:none}.calendar-day.other-month{background-color:#fafafa;color:#999}.calendar-day.today{background-color:#eef2ff}.day-number{font-weight:600;font-size:13px;color:#333}.day-inline-events{margin-top:4px;display:flex;gap:4px}.inline-dot{width:6px;height:6px;border-radius:50%;display:inline-block}.week-events-layer{position:absolute;left:0;right:0;top:0;bottom:0;pointer-events:none;z-index:2}.week-event-bar{position:absolute;height:18px;border-radius:4px;color:#fff;font-size:11px;display:flex;align-items:center;padding:0 6px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;pointer-events:auto;box-sizing:border-box;margin:0 2px}.calendar-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:20px 40px;border-radius:8px;box-shadow:0 4px 20px #0000001a;color:#524fa1;font-weight:600}.event-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#100f2e73;z-index:1200}.event-modal-card{background:#fff;border-radius:16px;padding:24px;width:min(420px,90vw);display:flex;flex-direction:column;gap:12px;box-shadow:0 20px 60px #00000026}.event-modal-subtitle{margin:0;color:#666;font-size:14px}.event-modal-actions{display:flex;justify-content:flex-end}.day-events-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0f0f2373;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1001}.day-events-modal-card{background-color:#fff;border-radius:16px;width:min(500px,95vw);max-height:80vh;border:1px solid #E8E9F0;box-shadow:0 20px 70px #18103926;display:flex;flex-direction:column}.day-events-modal-header{padding:20px 24px;border-bottom:1px solid #E8E9F0;display:flex;align-items:center;justify-content:space-between}.day-events-modal-header h3{margin:0;font-size:18px;color:#333}.day-events-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.day-events-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.day-event-item{display:flex;gap:12px;padding:12px;border:1px solid #E8E9F0;border-radius:8px;cursor:pointer;transition:background-color .2s,border-color .2s}.day-event-item:hover{background-color:#f9f9fc;border-color:#524fa1}.day-event-color{width:4px;border-radius:2px;flex-shrink:0}.day-event-content{flex:1}.day-event-title{margin:0 0 4px;font-weight:600;color:#333;font-size:15px}.day-event-description{margin:0 0 6px;color:#666;font-size:13px}.day-event-time{margin:0;color:#888;font-size:13px}.day-events-modal-footer{padding:16px 24px;border-top:1px solid #E8E9F0;display:flex;justify-content:flex-end}.shift-input-page{padding:20px;min-height:calc(100vh - 140px);background-color:#f5f6fa;display:flex;flex-direction:column;gap:20px;overflow-y:auto}.unsubmitted-warning-banner{background-color:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:12px 16px}.unsubmitted-warning-banner p{margin:0;color:#856404}.unsubmitted-warning-banner .unsubmitted-names{font-size:13px;margin-top:4px;word-break:break-all}.unsubmitted-warning-banner .unsubmitted-note{font-size:12px;margin-top:8px;color:#666}.shift-input-header{display:flex;align-items:center;justify-content:space-between;gap:20px;background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 10px #0000000d}.shift-input-header h2{color:#524fa1;margin-top:0;margin-bottom:0}.page-subtitle{margin:4px 0 0;color:#666;font-size:14px}.submission-period{display:inline-block;margin-left:8px;padding:2px 8px;background:#e8e9f0;border-radius:4px;font-size:12px;color:#524fa1;font-weight:600}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.month-title{color:#524fa1;font-size:20px;font-weight:600;margin:0}.member-panel{display:flex;justify-content:space-between;gap:20px;padding:20px;border-radius:12px;background:#fff;box-shadow:0 2px 10px #0000000d;flex-wrap:wrap}.member-info{flex:1}.panel-label{margin:0 0 8px;font-size:13px;font-weight:600;color:#666}.member-selector-button{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:linear-gradient(135deg,#524fa1,#6965b8);border:none;border-radius:12px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #524fa133}.member-selector-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #524fa14d}.member-selector-button:active{transform:translateY(0)}.member-selector-icon{font-size:24px}.member-selector-content{display:flex;flex-direction:column;align-items:flex-start;flex:1;gap:2px}.member-selector-label{font-size:10px;font-weight:600;color:#fffc;text-transform:uppercase;letter-spacing:.05em}.member-selector-name{font-size:16px;font-weight:700;color:#fff;display:flex;align-items:center;gap:8px}.member-inline-badge{font-size:10px;font-weight:600;padding:2px 6px;background-color:#e05b43e6;color:#fff;border-radius:4px}.member-selector-arrow{font-size:12px;color:#fffc}.member-name{font-size:16px;font-weight:600;margin:8px 0 0}.member-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.shift-calendar-wrapper{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000000d;position:relative}.shift-calendar-wrapper .weekday-row{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.shift-calendar-wrapper .weekday-row span{text-align:center;font-weight:600;color:#666;padding:6px 0}.shift-calendar-grid{display:flex;flex-direction:column;gap:12px}.shift-week-row{border:1px solid #E8E9F0;border-radius:10px;overflow:hidden;position:relative;background:#fff;isolation:isolate;height:154px}.shift-week-days{display:grid;grid-template-columns:repeat(7,1fr);overflow:visible;position:relative;z-index:1}.shift-day{border:none;border-right:1px solid #f1f2f6;border-bottom:1px solid #f1f2f6;height:154px;padding:6px;position:relative;overflow:visible;cursor:pointer;transition:background-color .2s;display:flex;flex-direction:column;width:100%;min-width:0;background:transparent;font-family:inherit;font-size:inherit;text-align:left}.shift-day:hover{background-color:#524fa10d}.shift-day *{pointer-events:none}.shift-day:last-child{border-right:none}.shift-day.other-month{background-color:#fafafa;color:#999}.shift-day.today{background-color:#eef2ff;border:1px solid #524FA1}.shift-day.is-disabled{cursor:not-allowed;opacity:.6}.shift-day.is-disabled:hover{background-color:#524fa10d}.shift-day.is-disabled:not(.other-month){background-color:#f0f1f6}.shift-day.is-disabled:not(.other-month):hover{background-color:#f0f1f6}.shift-day .day-number{font-weight:600;font-size:13px;color:#333}.shift-day .day-number.holiday{color:#e60012}.shift-day .day-number.saturday{color:#06c}.shift-day .holiday-bar{background-color:#e60012;color:#fff;font-size:10px;font-weight:600;padding:2px 4px;border-radius:3px;text-align:center;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shift-status-list{margin-top:4px;display:flex;flex-direction:column;gap:6px}.shift-day.not-work-day{background-color:#fff5f5}.shift-day.not-work-day:hover{background-color:#fff0f0}.shift-pill{display:inline-flex;align-items:center;justify-content:space-between;gap:6px;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600}.shift-pill.is-available{background-color:#524fa126;color:#3c3a80}.shift-pill.is-unavailable{background-color:#e74c3c1f;color:#b3392d}.calendar-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fffffff2;padding:20px 30px;border-radius:12px;box-shadow:0 12px 40px #0000001a;font-weight:600;color:#524fa1}.empty-state{padding:30px;border:2px dashed #E8E9F0;border-radius:12px;text-align:center;color:#666;background-color:#fdfdfe}.submit-button{padding:10px 24px;font-size:14px;font-weight:600;color:#fff;background-color:#524fa1;border:none;border-radius:8px;cursor:pointer;transition:all .2s;min-width:80px}.submit-button:hover:not(:disabled){background-color:#433f8c;transform:translateY(-1px);box-shadow:0 4px 12px #524fa14d}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.submit-button.has-changes{background-color:#e74c3c;animation:pulse-attention 2s infinite}.submit-button.has-changes:hover:not(:disabled){background-color:#c0392b}@keyframes pulse-attention{0%,to{box-shadow:0 0 #e74c3c66}50%{box-shadow:0 0 0 8px #e74c3c00}}.sync-status-indicator{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;background-color:#f8f9fa;min-height:40px}.sync-spinner{width:16px;height:16px;border:2px solid #E8E9F0;border-top-color:#524fa1;border-radius:50%;animation:spin .8s linear infinite}.sync-dot{width:8px;height:8px;border-radius:50%}.sync-dot.pending{background-color:#f39c12}.sync-dot.saved{background-color:#27ae60}.sync-text{font-size:14px;font-weight:500}.sync-text.saving{color:#524fa1}.sync-text.pending{color:#f39c12}.sync-text.saved{color:#27ae60}.shift-calendar-wrapper .calendar-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:20px}.shift-calendar-wrapper .calendar-header{display:flex;justify-content:center;align-items:center;gap:16px}.shift-calendar-wrapper.staff-list-view{overflow:visible;flex:1;display:flex;flex-direction:column}.shift-input-staff-list{overflow-x:auto;overflow-y:auto;width:100%;max-width:100%;flex:1;-webkit-overflow-scrolling:touch;position:relative}.staff-list-legend{display:flex;gap:16px;margin-bottom:16px;font-size:13px;color:#555;flex-wrap:wrap;align-items:center}.staff-list-legend .legend-divider{width:1px;height:20px;background-color:#e8e9f0;margin:0 8px}.legend-item{display:flex;align-items:center;gap:6px}.legend-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:700;border-radius:4px}.legend-badge.available.shift-1{background-color:#524fa133;color:#3c3a80;border-left:3px solid #524FA1}.legend-badge.available.shift-2{background-color:#4caf5033;color:#2e7d32;border-left:3px solid #4CAF50}.legend-badge.available.shift-3{background-color:#ff980033;color:#e65100;border-left:3px solid #FF9800}.legend-badge.available{background-color:#524fa126;color:#3c3a80}.legend-badge.unavailable{background-color:#e74c3c1f;color:#b3392d}.legend-empty{color:#b8b5d1;font-size:14px}.staff-list-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;font-size:13px;background-color:#fff;table-layout:auto}.staff-list-table thead{position:-webkit-sticky;position:sticky;top:0;background-color:#f2f1fb;z-index:8}.staff-list-table thead th{background-color:#f2f1fb}.staff-list-table th{padding:12px 8px;text-align:center;border:1px solid #E8E9F0;font-weight:600;color:#2e2a5c}.staff-list-table th.member-column{position:-webkit-sticky;position:sticky;left:0;background-color:#f2f1fb;z-index:10;min-width:120px;max-width:150px;text-align:left;padding-left:16px;box-shadow:2px 0 4px #00000014}.staff-list-table th.date-column{min-width:60px;transition:background-color .2s ease}.staff-list-table th.date-column.is-today{background-color:#4caf5026}.staff-list-table th.date-column.is-not-work-day{background-color:#fff5f5}.staff-list-table tbody tr{border-bottom:1px solid #E8E9F0}.staff-list-table tbody tr:hover{background-color:#524fa105}.staff-list-table td{padding:10px 8px;text-align:center;border:1px solid #E8E9F0}.staff-list-table tbody tr:hover .member-cell{background-color:#524fa1;color:#fff;font-weight:700}.staff-list-table tbody tr:hover .member-cell .member-name-text{color:#fff}.member-name-text{color:#2e2a5c;font-size:14px}.shift-cell.not-work-day-cell{background-color:#fff5f5}.shift-statuses{display:flex;flex-direction:column;gap:2px;justify-content:center;align-items:center}.shift-status-badge{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:18px;padding:0 4px;font-size:10px;font-weight:600;border-radius:4px}.shift-status-badge.available.shift-1{background-color:#524fa133;color:#3c3a80;border-left:3px solid #524FA1}.shift-status-badge.unavailable.shift-1{background-color:#524fa114;color:#8a88b8;border-left:3px solid #B8B5D1}.shift-status-badge.available.shift-2{background-color:#4caf5033;color:#2e7d32;border-left:3px solid #4CAF50}.shift-status-badge.unavailable.shift-2{background-color:#4caf5014;color:#81c784;border-left:3px solid #a5d6a7}.shift-status-badge.available.shift-3{background-color:#ff980033;color:#e65100;border-left:3px solid #FF9800}.shift-status-badge.unavailable.shift-3{background-color:#ff980014;color:#ffb74d;border-left:3px solid #ffcc80}.shift-status-badge.available{background-color:#524fa126;color:#3c3a80}.shift-status-badge.unavailable{background-color:#e74c3c1f;color:#b3392d}.no-data,.not-work-day-mark{color:#b8b5d1;font-size:14px}@media (max-width: 900px){.shift-input-header{flex-direction:column;align-items:flex-start}.member-panel{flex-direction:column}.shift-calendar-wrapper .calendar-controls{flex-direction:column;gap:12px}}.shift-create-page{display:flex;flex-direction:column;gap:20px;min-height:calc(100vh - 140px)}.shift-create-header{display:flex;justify-content:space-between;gap:20px;align-items:center}.shift-create-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}.draft-notice{background-color:#e3f2fd;border:1px solid #2196F3;border-radius:8px;padding:12px 16px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.draft-notice p{margin:0;color:#1565c0}.draft-notice .draft-note{font-size:13px;margin-top:4px;color:#1976d2}.discard-draft-btn{background-color:transparent;border:1px solid #1976D2;color:#1976d2;padding:6px 12px;font-size:13px;border-radius:6px;cursor:pointer;white-space:nowrap}.discard-draft-btn:hover{background-color:#2196f31a}.unsubmitted-warning{background-color:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:12px 16px;margin-bottom:8px}.unsubmitted-warning p{margin:0;color:#856404}.unsubmitted-warning .unsubmitted-names{font-size:13px;margin-top:4px;word-break:break-all}.unsubmitted-warning .unsubmitted-note{font-size:12px;margin-top:8px;color:#666}.shift-create-legend{display:flex;gap:12px;flex-wrap:wrap;font-size:13px;color:#555;align-items:center}.shift-create-legend .legend-divider{width:1px;height:20px;background-color:#e8e9f0;margin:0 4px}.legend-shift{padding:4px 10px;border-radius:12px;font-weight:600;font-size:12px}.legend-shift.shift-1{background-color:#524fa133;color:#3c3a80}.legend-shift.shift-2{background-color:#4caf5033;color:#2e7d32}.legend-shift.shift-3{background-color:#ff980033;color:#e65100}.legend-available{color:#2c8c53}.legend-unavailable{color:#b3392d}.legend-required{color:#524fa1}.legend-preferred{padding:2px 8px;border-radius:4px;background-color:#4caf5033;color:#2e7d32;font-weight:600}.legend-not-preferred{padding:2px 8px;border-radius:4px;background-color:#ff980033;color:#e65100;font-weight:500}.legend-constraint-violated{padding:2px 8px;border-radius:4px;background-color:#f4433633;color:#c62828;font-weight:600}.capacity-warning{border:1px solid #ffcf88;background-color:#fff7e8;border-radius:12px;padding:12px 16px;margin-bottom:8px}.capacity-warning h4{margin:0 0 6px;color:#a05b00}.capacity-warning ul{margin:8px 0;padding-left:20px;color:#6c4b00;font-size:13px}.capacity-warning p{margin:8px 0;color:#6c4b00;font-size:13px}.capacity-warning.unsubmitted-warning{border-color:#f44336;background-color:#ffebee}.capacity-warning.unsubmitted-warning h4{color:#c62828}.capacity-warning.unsubmitted-warning p,.capacity-warning.unsubmitted-warning ul{color:#b71c1c}.unregistered-badge{display:inline-block;margin-left:8px;padding:2px 6px;background-color:#e05b4333;color:#c62828;border-radius:4px;font-size:11px;font-weight:600}.capacity-warning .note{margin-top:12px;padding-top:8px;border-top:1px solid rgba(0,0,0,.1);font-style:italic;font-size:12px}.shift-create-content{display:grid;grid-template-columns:1fr 300px;gap:20px;flex:1}.shift-create-content.month-view-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:20px;align-items:start;flex:1;min-height:0}.shift-create-calendar-wrapper{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000000d;position:relative;min-width:0}.month-view-layout .shift-create-calendar-wrapper{max-width:100%;display:flex;flex-direction:column;min-height:0}.shift-create-calendar-wrapper.is-disabled{opacity:.6;pointer-events:none}.calendar-disabled-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#fffffff2;display:flex;align-items:center;justify-content:center;border-radius:12px;z-index:10}.disabled-message{text-align:center;padding:20px}.disabled-message p{margin:0;font-size:16px;font-weight:600;color:#c62828}.disabled-message p.small{margin-top:8px;font-size:13px;font-weight:400;color:#666}.shift-create-calendar-wrapper .weekday-row{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.shift-create-calendar-wrapper .weekday-row span{text-align:center;font-weight:600;color:#666;padding:6px 0}.shift-create-calendar-grid{display:flex;flex-direction:column;gap:12px}.shift-create-week-row{border:1px solid #E8E9F0;border-radius:10px;overflow:hidden;position:relative;background:#fff;isolation:isolate;height:200px}.shift-create-week-days{display:grid;grid-template-columns:repeat(7,1fr);overflow:visible;position:relative;z-index:1}.shift-create-day{border:none;border-right:1px solid #f1f2f6;border-bottom:1px solid #f1f2f6;height:200px;padding:6px;position:relative;overflow:visible;cursor:pointer;transition:background-color .2s;display:flex;flex-direction:column;width:100%;min-width:0;background:transparent;font-family:inherit;font-size:inherit;text-align:left}.shift-create-day:hover:not(:disabled){background-color:#524fa10d}.shift-create-day:disabled{cursor:not-allowed;opacity:.5}.shift-create-day *{pointer-events:none}.shift-create-day:last-child{border-right:none}.shift-create-day.other-month{background-color:#fafafa;color:#999}.shift-create-day.today{background-color:#eef2ff;border:1px solid #524FA1}.shift-create-day.is-selected{background-color:#524fa12e;border:2px solid #524FA1;box-shadow:0 0 0 2px #524fa133}.shift-create-day.has-deficit{background-color:#f443360d}.shift-create-day .day-number{font-weight:600;font-size:15px;color:#333}.shift-create-day .day-number.holiday{color:#e60012}.shift-create-day .day-number.saturday{color:#06c}.shift-create-day .holiday-bar{background-color:#e60012;color:#fff;font-size:10px;font-weight:600;padding:2px 4px;border-radius:3px;text-align:center;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shift-create-shifts{margin-top:4px;display:flex;flex-direction:column;gap:4px;overflow:hidden}.shift-placeholder.not-work-day-label{color:#e74c3c;font-weight:600}.shift-create-day.not-work-day{background-color:#fff5f5;cursor:default}.shift-create-day.not-work-day:hover{background-color:#fff0f0}.create-shift-pill{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:3px 4px;border-radius:4px;font-size:9px;background-color:#524fa11a;overflow:hidden;width:100%;max-width:100%;box-sizing:border-box;height:auto;min-height:56px;flex-shrink:0}.create-shift-pill .shift-label{font-weight:600;color:#524fa1;font-size:11px;white-space:nowrap}.create-shift-pill .shift-names{color:#555;width:100%;font-size:11px;display:flex;flex-wrap:wrap;gap:2px;align-items:flex-start}.create-shift-pill .member-name{display:inline-block;padding:1px 4px;border-radius:3px;font-size:11px;font-weight:400}.create-shift-pill .member-name.preferred{background-color:#4caf5033;color:#2e7d32;font-weight:600}.create-shift-pill .member-name.not-preferred{background-color:#ff980033;color:#e65100;font-weight:500}.create-shift-pill .member-name.constraint-violated{background-color:#f4433633;color:#c62828;font-weight:600}.member-name{display:inline-block;padding:2px 6px;border-radius:4px;margin-right:4px;font-size:11px}.member-name.preferred{background-color:#4caf5033;color:#2e7d32;font-weight:600}.member-name.not-preferred{background-color:#ff980033;color:#e65100;font-weight:500}.member-name.constraint-violated{background-color:#f4433633;color:#c62828;font-weight:600}.create-shift-pill.has-constraint-violation{border:1px solid rgba(244,67,54,.3);background-color:#f4433614}.constraint-warning-icon{color:#c62828;font-size:12px;font-weight:600;margin-left:4px}.shift-assign-body{display:flex;flex-direction:column;gap:16px;max-height:60vh}.assign-section h4{margin:0 0 8px;font-size:14px;color:#444}.assign-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto}.assign-list label{display:flex;align-items:center;gap:8px;font-size:14px;color:#333}.capacity-info{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#555}.badge{padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600}.badge-ok{background-color:#4caf5026;color:#2e7d32}.badge-alert{background-color:#f4433626;color:#c62828}.label-summary{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.side-panels{display:flex;flex-direction:column;gap:16px;position:sticky;top:20px;height:fit-content;min-width:0;width:100%}.request-panel,.history-panel{border:1px solid #E8E9F0;border-radius:12px;background:linear-gradient(to bottom,#fafbff,#fff);padding:20px;display:flex;flex-direction:column;gap:16px;box-shadow:0 2px 8px #524fa114}.request-panel h3,.history-panel h3{margin:0;font-size:17px;font-weight:700;color:#2e2a5c;padding-bottom:12px;border-bottom:2px solid #F2F1FB}.request-panel-date{margin:0;color:#524fa1;font-size:15px;font-weight:600;padding:8px 12px;background-color:#f2f1fb;border-radius:8px;text-align:center}.edit-shifts-list{display:flex;flex-direction:column;gap:12px}.edit-shift-item{border:1px solid #E8E9F0;border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:10px;background-color:#fff;transition:all .2s ease}.edit-shift-item:hover{border-color:#524fa1;box-shadow:0 2px 6px #524fa11f}.edit-shift-header{display:flex;justify-content:space-between;align-items:center;font-size:14px}.shift-index{font-weight:700;color:#2e2a5c;display:flex;align-items:center;gap:6px}.shift-available-count{color:#6d6a9e;font-size:13px;font-weight:600;padding:4px 10px;background-color:#f2f1fb;border-radius:12px}.edit-shift-members{font-size:13px;color:#555;min-height:24px;max-height:80px;display:flex;flex-wrap:wrap;gap:6px;align-items:flex-start;overflow-y:auto;padding-right:4px}.empty-members{color:#b8b5d1;font-style:italic;font-size:13px}.edit-shift-members .member-name{font-size:13px;margin:0;padding:4px 10px;border-radius:6px;font-weight:500;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-names{display:block;word-wrap:break-word}.edit-button{align-self:flex-end;padding:8px 16px;font-size:14px;font-weight:600;background-color:#524fa1;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.edit-button:hover{background-color:#423d8a;transform:translateY(-1px);box-shadow:0 4px 8px #524fa133}.edit-button:active{transform:translateY(0)}.stats-summary{margin-top:16px;padding:16px;background-color:#f9fafb;border-radius:8px;border:1px solid #E8E9F0}.stats-summary h4{margin:0 0 12px;font-size:15px;font-weight:700;color:#2e2a5c}.stats-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:#2e2a5c;border-bottom:1px solid #E8E9F0}.stats-row:last-child{border-bottom:none}.stats-row span:first-child{font-weight:500}.text-ok{color:#2e7d32;font-weight:700;display:inline-flex;align-items:center;gap:4px}.text-alert{color:#c62828;font-weight:700;display:inline-flex;align-items:center;gap:4px}.panel-disabled-message{padding:20px;text-align:center;color:#666;font-size:13px;border:1px dashed #E8E9F0;border-radius:10px;background-color:#fafafa}.panel-disabled-message p{margin:0}.request-slot{border:1px solid #f0f1f5;border-radius:10px;padding:10px}.request-slot-head{display:flex;justify-content:space-between;font-size:13px;color:#444;margin-bottom:6px}.request-slot ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.request-slot li{display:flex;justify-content:space-between;font-size:13px}.status-available{color:#2c8c53}.status-unavailable{color:#b3392d}.history-panel ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.history-panel li{border-bottom:1px solid #f0f1f5;padding-bottom:8px}.history-panel li:last-child{border-bottom:none}.history-time{font-size:12px;color:#888}.history-panel p{margin:4px 0 0;font-size:13px;color:#444}@media (max-width: 1024px){.shift-create-content,.shift-create-content.month-view-layout{grid-template-columns:1fr}.side-panels,.month-view-layout .side-panels{position:static;width:100%}}@media (max-width: 768px){.shift-create-header{flex-direction:column;align-items:flex-start}.shift-create-actions{justify-content:flex-start}}.adjustment-history-modal{max-width:800px;max-height:80vh;width:90%}.adjustment-history-modal .modal-body{max-height:60vh;overflow-y:auto}.adjustment-description{font-size:14px;color:#6d6a9e;margin-bottom:20px;line-height:1.6;text-align:center}.adjustment-list{display:flex;flex-direction:column;gap:12px}.adjustment-item{background-color:#fff8f6;border-radius:12px;padding:16px;border-left:4px solid #E05B43}.adjustment-text{font-size:14px;color:#2e2a5c;line-height:1.8;margin:0;white-space:pre-wrap;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.shift-create-month-view{overflow-x:auto;overflow-y:auto;width:100%;max-width:100%;-webkit-overflow-scrolling:touch;position:relative}.month-view-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;font-size:13px;background-color:#fff;table-layout:auto}.month-view-table thead{position:-webkit-sticky;position:sticky;top:0;background-color:#f2f1fb;z-index:8}.month-view-table thead th{background-color:#f2f1fb}.month-view-table th.member-column{position:-webkit-sticky;position:sticky;left:0;background-color:#f2f1fb;z-index:10;min-width:120px;max-width:150px;text-align:left;padding-left:16px;box-shadow:2px 0 4px #00000014}.month-view-table th.date-column{min-width:50px;transition:background-color .2s ease}.month-view-table th.date-column:hover{background-color:#524fa126}.month-view-table th.date-column.is-selected{background-color:#524fa1;box-shadow:inset 0 -3px #3c3a80}.month-view-table th.date-column.is-selected .date-day,.month-view-table th.date-column.is-selected .date-weekday{color:#fff}.month-view-table th.date-column.is-today{background-color:#4caf5026}.month-view-table th.date-column.is-today.is-selected{background-color:#524fa1}.month-view-table th.date-column.has-deficit{background-color:#ff980026}.month-view-table th.date-column.has-deficit.is-selected{background-color:#524fa1}.date-day{font-size:18px;font-weight:700;color:#2e2a5c}.date-weekday{font-size:12px;color:#6d6a9e;font-weight:500}.member-cell{position:-webkit-sticky;position:sticky;left:0;background-color:#fff;z-index:5;text-align:left!important;padding-left:16px!important;font-weight:500;min-width:120px;max-width:150px;transition:all .2s ease;box-shadow:2px 0 4px #00000014}.shift-cell.clickable{cursor:pointer;transition:background-color .15s ease}.shift-cell.clickable:hover{background-color:#f5f3ff}.shift-cell.is-selected{background-color:#524fa10f}.shift-cell.not-work-day-cell{background-color:#f9f0f0}.not-work-day-mark{color:#e74c3c;font-size:12px}.shift-num-badge.shift-1{background-color:#524fa1}.shift-num-badge.shift-1.preferred{background-color:#524fa1;box-shadow:0 0 0 2px #4caf5080}.shift-num-badge.shift-1.not-preferred{background-color:#8a88b8;box-shadow:0 0 0 2px #ff980080}.shift-num-badge.shift-1.constraint-violated{background-color:#524fa1;box-shadow:0 0 0 2px #f44336b3}.shift-num-badge.shift-2{background-color:#4caf50}.shift-num-badge.shift-2.preferred{background-color:#4caf50;box-shadow:0 0 0 2px #4caf5080}.shift-num-badge.shift-2.not-preferred{background-color:#81c784;box-shadow:0 0 0 2px #ff980080}.shift-num-badge.shift-2.constraint-violated{background-color:#4caf50;box-shadow:0 0 0 2px #f44336b3}.shift-num-badge.shift-3{background-color:#ff9800}.shift-num-badge.shift-3.preferred{background-color:#ff9800;box-shadow:0 0 0 2px #4caf5080}.shift-num-badge.shift-3.not-preferred{background-color:#ffb74d;box-shadow:0 0 0 2px #ff980080}.shift-num-badge.shift-3.constraint-violated{background-color:#ff9800;box-shadow:0 0 0 2px #f44336b3}.shift-num-badge.preferred{background-color:#4caf50;color:#fff}.shift-num-badge.not-preferred{background-color:#ff9800;color:#fff}.shift-num-badge.constraint-violated{background-color:#f44336;color:#fff}.comments-modal-card{background-color:#fff;border-radius:20px;box-shadow:0 12px 24px #211d572e;width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.comments-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #F0F0F5}.comments-modal-title{font-size:18px;font-weight:700;color:#211d57;margin:0}.modal-close-button{background:none;border:none;font-size:24px;color:#6b6b89;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background-color .2s ease}.modal-close-button:hover{background-color:#6b6b891a}.comments-scroll-area{flex:1;overflow-y:auto;padding:20px 24px;max-height:50vh;min-height:200px}.comments-scroll-area::-webkit-scrollbar{width:6px}.comments-scroll-area::-webkit-scrollbar-track{background:#f7f7ff;border-radius:3px}.comments-scroll-area::-webkit-scrollbar-thumb{background:#524fa14d;border-radius:3px}.comments-scroll-area::-webkit-scrollbar-thumb:hover{background:#524fa180}.comments-loading,.comments-empty{text-align:center;color:#9ea2b3;font-size:14px;padding:40px 20px}.comments-list{display:flex;flex-direction:column;gap:16px}.comment-bubble{display:flex;flex-direction:column;max-width:75%;position:relative}.comment-bubble.my-comment{align-self:flex-end;align-items:flex-end}.comment-bubble.other-comment{align-self:flex-start;align-items:flex-start}.comment-username{font-size:12px;font-weight:600;color:#6b6b89;margin-bottom:4px}.comment-text{background-color:#f7f7ff;padding:12px 16px;border-radius:16px;font-size:14px;color:#211d57;line-height:1.5;word-wrap:break-word;white-space:pre-wrap}.comment-bubble.my-comment .comment-text{background-color:#524fa1;color:#fff;border-bottom-right-radius:4px}.comment-bubble.other-comment .comment-text{border-bottom-left-radius:4px}.comment-meta{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:11px;color:#9ea2b3}.comment-timestamp{font-size:11px}.edited-badge{font-size:11px;color:#9ea2b3;font-style:italic}.comment-menu-button{background:none;border:none;font-size:16px;color:#9ea2b3;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s ease}.comment-menu-button:hover{color:#524fa1}.comment-menu{position:absolute;right:0;top:100%;background:#fff;border:1px solid #E8E9F0;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:10;margin-top:4px;overflow:hidden}.comment-menu button{display:block;width:100%;padding:10px 16px;border:none;background:#fff;color:#211d57;font-size:14px;text-align:left;cursor:pointer;transition:background-color .2s ease}.comment-menu button:hover{background-color:#f7f7ff}.comment-menu button.delete-option{color:#c62828}.comment-menu button.delete-option:hover{background-color:#f443361a}.comment-edit-area{width:100%;display:flex;flex-direction:column;gap:8px}.comment-edit-input{width:100%;min-height:80px;padding:12px;border:1px solid rgba(82,79,161,.2);border-radius:8px;font-size:14px;color:#211d57;font-family:inherit;resize:vertical}.comment-edit-input:focus{outline:none;border-color:#524fa1}.comment-edit-buttons{display:flex;justify-content:flex-end;gap:8px}.cancel-button,.save-button{padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-button{background-color:#fff;border:1px solid rgba(82,79,161,.25);color:#524fa1}.cancel-button:hover{background-color:#f7f7ff}.save-button{background-color:#524fa1;border:none;color:#fff}.save-button:hover{background-color:#423d8a}.comments-input-area{display:flex;gap:12px;padding:16px 24px;border-top:1px solid #F0F0F5;background-color:#fafbff}.comment-input{flex:1;height:44px;border-radius:22px;background-color:#fff;border:1px solid rgba(82,79,161,.2);padding:0 16px;font-size:14px;color:#211d57;transition:border-color .2s ease}.comment-input:focus{outline:none;border-color:#524fa1}.comment-input::placeholder{color:#9ea2b3}.comment-send-button{height:44px;padding:0 24px;border-radius:22px;background-color:#524fa1;border:none;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.comment-send-button:hover:not(:disabled){background-color:#423d8a}.comment-send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.comments-modal-card{max-width:100%;max-height:90vh}.comments-modal-header,.comments-scroll-area{padding:16px 20px}.comments-input-area{padding:12px 20px}.comment-bubble{max-width:85%}}.shift-result-page{padding:20px;min-height:calc(100vh - 140px);background-color:#f5f6fa;display:flex;flex-direction:column;gap:20px}.shift-result-header{display:flex;align-items:center;justify-content:space-between;gap:20px;background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 10px #0000000d}.shift-result-header h2{color:#524fa1;margin-top:0;margin-bottom:0}.shift-result-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end;background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000000d}.info-banner{padding:14px 18px;border-radius:10px;background-color:#fff7e8;border:1px solid #ffd187;color:#8a5600;font-size:14px}.shift-result-calendar-wrapper{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000000d;position:relative}.calendar-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:20px}.calendar-header{display:flex;justify-content:center;align-items:center;gap:16px}.month-title{color:#524fa1;font-size:20px;font-weight:600;margin:0;min-width:140px;text-align:center}.shift-result-calendar-wrapper .weekday-row{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.shift-result-calendar-wrapper .weekday-row span{text-align:center;font-weight:600;color:#666;padding:6px 0}.shift-result-calendar-grid{display:flex;flex-direction:column;gap:12px}.shift-result-week-row{border:1px solid #E8E9F0;border-radius:10px;overflow:hidden;position:relative;background:#fff;isolation:isolate;height:200px}.shift-result-week-days{display:grid;grid-template-columns:repeat(7,1fr);overflow:visible;position:relative;z-index:1}.shift-result-day{border:none;border-right:1px solid #f1f2f6;border-bottom:1px solid #f1f2f6;height:200px;padding:6px;position:relative;overflow:visible;cursor:pointer;transition:background-color .2s;display:flex;flex-direction:column;width:100%;min-width:0;background:transparent;font-family:inherit;font-size:inherit;text-align:left}.shift-result-day:hover{background-color:#524fa10d}.shift-result-day *{pointer-events:none}.shift-result-day:last-child{border-right:none}.shift-result-day.other-month{background-color:#fafafa;color:#999}.shift-result-day.today{background-color:#eef2ff;border:1px solid #524FA1}.shift-result-day.is-empty{opacity:.6}.shift-result-day .day-number{font-weight:600;font-size:13px;color:#333;display:flex;align-items:center;gap:4px}.shift-result-day .day-number.holiday{color:#e60012}.shift-result-day .day-number.saturday{color:#06c}.shift-result-day .holiday-bar{background-color:#e60012;color:#fff;font-size:10px;font-weight:600;padding:2px 4px;border-radius:3px;text-align:center;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-badge{background-color:#ff5722;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;line-height:1}.shift-result-shifts{margin-top:4px;display:flex;flex-direction:column;gap:4px}.shift-placeholder{font-size:12px;color:#999}.result-shift-pill{display:flex;flex-direction:column;align-items:flex-start;padding:3px 4px;border-radius:4px;background-color:#f6f7ff;font-size:9px;color:#3a3882;gap:2px;overflow:hidden;width:100%;box-sizing:border-box;height:56px;flex-shrink:0}.result-shift-pill>span:first-child{font-weight:600;font-size:10px;color:#524fa1}.result-names{color:#555;width:100%;font-size:10px;display:flex;flex-wrap:wrap;gap:2px;align-items:flex-start}.result-names .member-name{display:inline-block;padding:1px 4px;border-radius:3px;font-size:10px;background-color:#524fa11a;color:#524fa1}.overlay-loading{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:#f5f6fab3;font-weight:600;z-index:900;color:#524fa1}.history-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#100f2e80;z-index:1000}.history-modal-card{background:#fff;border-radius:16px;padding:24px;width:min(480px,90vw);max-height:80vh;display:flex;flex-direction:column;gap:12px;box-shadow:0 20px 60px #00000026}.history-modal-card ul{list-style:none;margin:0;padding:0;max-height:50vh;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.history-modal-card li{border:1px solid #f0e4d7;border-radius:10px;padding:10px 12px;background:#fffaf5}.history-badges{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}.history-modal-subtitle{margin:0;color:#666;font-size:14px}@media (max-width: 768px){.shift-result-header{flex-direction:column;align-items:flex-start}.shift-result-actions{justify-content:flex-start}}.info-banner.success{border-color:#a5d6a7;background-color:#f1fbf1;color:#2e7d32}.view-mode-switcher{display:flex;gap:4px;background-color:#f0f0f5;padding:4px;border-radius:8px}.view-mode-btn{padding:6px 16px;border:none;background-color:transparent;color:#6d6a9e;font-size:14px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s ease}.view-mode-btn:hover{background-color:#524fa11a}.view-mode-btn.active{background-color:#524fa1;color:#fff}.shift-result-month-view{overflow-x:auto;overflow-y:auto;width:100%;max-width:100%;-webkit-overflow-scrolling:touch;position:relative}.month-view-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:13px;background-color:#fff}.month-view-table thead{position:sticky;top:0;background-color:#f2f1fb;z-index:2}.month-view-table th{padding:12px 8px;text-align:center;border:1px solid #E8E9F0;font-weight:600;color:#2e2a5c}.month-view-table th.member-column{position:sticky;left:0;background-color:#f2f1fb;z-index:3;min-width:120px;text-align:left;padding-left:16px}.month-view-table th.date-column{min-width:50px}.date-header{display:flex;flex-direction:column;align-items:center;gap:2px}.date-day{font-size:16px;font-weight:700;color:#2e2a5c}.date-weekday{font-size:11px;color:#6d6a9e;font-weight:500}.date-day.holiday,.date-weekday.holiday{color:#e60012}.date-day.saturday,.date-weekday.saturday{color:#06c}.date-holiday{font-size:9px;font-weight:600;color:#e60012;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50px}.month-view-table tbody tr{border-bottom:1px solid #E8E9F0}.month-view-table tbody tr:hover{background-color:#524fa105}.month-view-table td{padding:10px 8px;text-align:center;border:1px solid #E8E9F0}.member-cell{position:sticky;left:0;background-color:#fff;z-index:1;text-align:left!important;padding-left:16px!important;font-weight:500;min-width:120px;transition:all .2s ease}.month-view-table tbody tr:hover .member-cell{background-color:#524fa1;color:#fff;font-weight:700}.member-name-full{color:#2e2a5c;font-size:14px}.unregistered-badge-small{display:inline-block;margin-left:6px;padding:2px 6px;background-color:#ff9800;color:#fff;font-size:10px;font-weight:600;border-radius:4px}.shift-cell{background-color:#fff}.shift-numbers{display:flex;gap:4px;justify-content:center;align-items:center;flex-wrap:wrap}.shift-num-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background-color:#524fa1;color:#fff;font-size:11px;font-weight:700;border-radius:10px}.no-shift{color:#b8b5d1;font-size:16px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#100f2e59;display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background-color:#fff;border-radius:20px;padding:28px 24px;box-shadow:0 12px 24px #211d572e;max-height:90vh;width:100%;max-width:600px;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.modal-header{margin-bottom:20px}.modal-title{font-size:18px;font-weight:700;color:#211d57;margin:0 0 8px}.modal-description{font-size:13px;color:#6b6b89;margin:0;line-height:1.5}.modal-scroll-area{flex:1;overflow-y:auto;margin:0 -8px;padding:0 8px;max-height:60vh}.modal-scroll-area::-webkit-scrollbar{width:6px}.modal-scroll-area::-webkit-scrollbar-track{background:#f7f7ff;border-radius:3px}.modal-scroll-area::-webkit-scrollbar-thumb{background:#524fa14d;border-radius:3px}.modal-scroll-area::-webkit-scrollbar-thumb:hover{background:#524fa180}.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid #F0F0F5}.modal-button{min-width:110px;padding:12px 16px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;outline:none}.modal-button.primary{background-color:#524fa1;color:#fff}.modal-button.primary:hover{background-color:#423d8a}.modal-button.primary:active{transform:scale(.98)}.modal-button.secondary{background-color:#fff;color:#524fa1;border:1px solid rgba(82,79,161,.25)}.modal-button.secondary:hover{background-color:#f7f7ff}.modal-button.secondary:active{transform:scale(.98)}.modal-input,.modal-select{width:100%;height:48px;border-radius:10px;background-color:#f7f7ff;border:1px solid rgba(82,79,161,.2);padding:0 14px;font-size:16px;color:#211d57;transition:border-color .2s ease}.modal-input:focus,.modal-select:focus{outline:none;border-color:#524fa1}.modal-input::placeholder{color:#9ea2b3}.field-label{display:flex;flex-direction:column;gap:8px;font-size:14px;color:#211d57;font-weight:500}.day-card{margin-bottom:18px;padding:16px;background-color:#fafbff;border-radius:12px;border:1px solid rgba(82,79,161,.1)}.day-title{font-size:15px;font-weight:600;color:#524fa1;margin:0 0 12px}.label-row{display:flex;gap:8px;margin-top:12px}.label-input-group{flex:1;display:flex;flex-direction:column;gap:4px}.label-input-title{font-size:12px;color:#6b6b89;font-weight:500}.label-input{height:40px;border-radius:8px;background-color:#fff;border:1px solid rgba(82,79,161,.2);padding:0 10px;font-size:14px;color:#211d57;transition:border-color .2s ease}.label-input:focus{outline:none;border-color:#524fa1}.member-card{border-radius:14px;border:1px solid rgba(82,79,161,.12);background-color:#f9f8ff;padding:14px;margin-bottom:12px}.member-name{font-size:15px;font-weight:600;color:#211d57;margin:0 0 4px}.current-label{font-size:13px;color:#6b6b89;margin:0 0 12px}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:6px 12px;border-radius:999px;border:1px solid rgba(82,79,161,.18);background-color:#f7f7ff;font-size:13px;color:#211d57;cursor:pointer;transition:all .2s ease}.chip:hover{background-color:#524fa114}.chip.selected{background-color:#524fa11f;border-color:#524fa1;color:#524fa1;font-weight:600}.shift-inputs{display:flex;flex-direction:column;gap:20px;margin-top:20px}.shift-input-group{padding:16px;background-color:#fafbff;border-radius:12px;border:1px solid rgba(82,79,161,.1)}.shift-input-title{font-size:16px;font-weight:600;color:#211d57;margin:0 0 4px}.shift-input-description{font-size:13px;color:#6b6b89;margin:0 0 12px}.time-inputs{display:flex;align-items:center;gap:12px;margin-bottom:12px}.time-label{flex:1;display:flex;flex-direction:column;gap:6px;font-size:13px;color:#6b6b89;font-weight:500}.time-input{height:44px;border-radius:8px;background-color:#fff;border:1px solid rgba(82,79,161,.2);padding:0 12px;font-size:15px;color:#211d57;transition:border-color .2s ease}.time-input:focus{outline:none;border-color:#524fa1}.time-separator{font-size:14px;color:#6b6b89;margin-top:24px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b6b89;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#524FA1}.break-inputs{display:flex;gap:16px}.break-label{flex:1;display:flex;flex-direction:column;gap:8px;font-size:14px;color:#211d57;font-weight:500}.closing-day-options{display:flex;flex-direction:column;gap:12px}.closing-day-option{width:100%;padding:16px;background-color:#fafbff;border:2px solid rgba(82,79,161,.15);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left}.closing-day-option:hover{background-color:#524fa10d;border-color:#524fa14d}.closing-day-option.selected{background-color:#524fa114;border-color:#524fa1}.closing-day-option-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.closing-day-radio{font-size:16px;color:#524fa1;font-weight:700}.closing-day-label{font-size:15px;font-weight:600;color:#211d57}.closing-day-description{font-size:13px;color:#6b6b89;margin:0 0 0 26px;line-height:1.5}.pattern-requirements-modal{max-width:700px}.day-pattern-card{margin-bottom:20px;padding:16px;background-color:#fafbff;border-radius:12px;border:1px solid rgba(82,79,161,.1)}.day-pattern-title{font-size:16px;font-weight:600;color:#524fa1;margin:0 0 14px}.pattern-requirements-grid{display:flex;flex-direction:column;gap:14px}.pattern-requirement-item{padding:12px;background-color:#fff;border-radius:8px;border:1px solid rgba(82,79,161,.08)}.pattern-requirement-header{display:flex;align-items:baseline;gap:8px;margin-bottom:10px}.pattern-name-label{font-size:14px;font-weight:600;color:#211d57}.pattern-time-label{font-size:12px;color:#6b6b89}.pattern-requirement-inputs{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.pattern-req-label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#6b6b89;font-weight:500}.pattern-req-input{width:70px;height:36px;border-radius:6px;background-color:#f7f7ff;border:1px solid rgba(82,79,161,.2);padding:0 10px;font-size:14px;color:#211d57;transition:border-color .2s ease}.pattern-req-input:focus{outline:none;border-color:#524fa1}.pattern-label-counts{display:flex;gap:8px;flex-wrap:wrap}.pattern-label-input{display:flex;flex-direction:column;gap:4px;font-size:11px;color:#6b6b89;font-weight:500}.pattern-label-input-field{width:50px;height:32px;border-radius:6px;background-color:#f7f7ff;border:1px solid rgba(82,79,161,.15);padding:0 8px;font-size:13px;color:#211d57;transition:border-color .2s ease}.pattern-label-input-field:focus{outline:none;border-color:#524fa1}.work-days-modal{max-width:480px}.work-days-month-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px}.month-nav-button{width:36px;height:36px;border-radius:8px;border:1px solid rgba(82,79,161,.2);background-color:#f7f7ff;color:#524fa1;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.month-nav-button:hover{background-color:#524fa11a}.month-nav-label{font-size:16px;font-weight:600;color:#211d57;min-width:120px;text-align:center}.work-days-calendar{background-color:#fafbff;border-radius:12px;border:1px solid rgba(82,79,161,.1);padding:16px}.work-days-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.work-days-weekday{font-size:12px;font-weight:600;color:#6b6b89;text-align:center;padding:8px 0}.work-days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.work-days-cell{aspect-ratio:1;border:none;border-radius:8px;background-color:#fff;color:#211d57;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.work-days-cell:hover:not(.empty){background-color:#524fa11a}.work-days-cell.empty{background-color:transparent;cursor:default}.work-days-cell.selected{background-color:#524fa1;color:#fff}.work-days-cell.selected:hover{background-color:#423d8a}.work-days-cell.saturday{color:#4a90e2}.work-days-cell.saturday.selected{color:#fff}.work-days-cell.sunday{color:#e05b43}.work-days-cell.sunday.selected{color:#fff}.work-days-info{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding:12px 16px;background-color:#524fa10d;border-radius:8px}.work-days-count{font-size:14px;font-weight:600;color:#524fa1}.work-days-actions{display:flex;gap:8px}.work-days-action-button{padding:6px 12px;border-radius:6px;border:1px solid rgba(82,79,161,.2);background-color:#fff;color:#524fa1;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}.work-days-action-button:hover{background-color:#524fa114}@media (max-width: 768px){.modal-overlay{padding:16px}.modal-card{padding:20px 16px;max-width:100%}.label-row{flex-direction:column}.time-inputs{flex-direction:column;align-items:stretch}.time-separator{margin:0;text-align:center}.break-inputs{flex-direction:column}.modal-footer{flex-direction:column-reverse}.modal-button{width:100%}}.merge-member-modal{max-width:500px;width:90%;max-height:80vh;display:flex;flex-direction:column}.merge-info-box{background-color:#fff8f6;border-radius:12px;padding:16px;margin-bottom:16px;border:1px solid rgba(224,91,67,.2)}.merge-info-label{font-size:12px;font-weight:600;color:#666;margin:0 0 4px}.merge-info-value{font-size:16px;font-weight:700;color:#1a1a1a;margin:0}.merge-arrow{text-align:center;margin:8px 0}.merge-arrow span{font-size:24px;color:#524fa1;font-weight:700}.merge-select-label{font-size:14px;font-weight:600;color:#1a1a1a;margin:0 0 12px}.merge-member-list{max-height:250px;overflow-y:auto;margin-bottom:16px}.merge-member-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;margin-bottom:8px;background-color:#f7f7ff;border-radius:12px;border:1px solid rgba(82,79,161,.1);cursor:pointer;transition:all .2s ease;width:100%;text-align:left}.merge-member-item:hover{background-color:#f0f0ff;border-color:#524fa133}.merge-member-item.selected{background-color:#e8e7f5;border:2px solid #524fa1}.merge-member-name{font-size:15px;font-weight:500;color:#1a1a1a}.merge-member-item.selected .merge-member-name{font-weight:700;color:#524fa1}.merge-checkmark{font-size:18px;font-weight:700;color:#524fa1}.merge-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#ffffffe6;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:12px;z-index:10}.merge-loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #524fa1;border-radius:50%;animation:merge-spin 1s linear infinite}@keyframes merge-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.merge-loading-text{margin-top:12px;font-size:14px;font-weight:600;color:#1a1a1a}.work-pattern-modal{max-width:540px}.patterns-list{display:flex;flex-direction:column;gap:16px}.pattern-edit-card{padding:16px;background-color:#fafbff;border-radius:12px;border:1px solid rgba(82,79,161,.12)}.pattern-edit-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}.pattern-name-input{flex:1;height:44px;border-radius:8px;background-color:#fff;border:1px solid rgba(82,79,161,.2);padding:0 14px;font-size:15px;font-weight:600;color:#211d57;transition:border-color .2s ease}.pattern-name-input:focus{outline:none;border-color:#524fa1}.pattern-name-input::placeholder{color:#9ea2b3;font-weight:400}.pattern-remove-button{width:32px;height:32px;border-radius:8px;border:1px solid rgba(229,83,83,.3);background-color:#e5535314;color:#e55353;font-size:18px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.pattern-remove-button:hover{background-color:#e5535326;border-color:#e5535380}.pattern-time-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.pattern-time-label{flex:1;display:flex;flex-direction:column;gap:6px;font-size:13px;color:#6b6b89;font-weight:500}.pattern-time-separator{font-size:14px;color:#6b6b89;margin-top:24px}.pattern-options-row{display:flex;align-items:center;justify-content:space-between}.pattern-checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b6b89;cursor:pointer;-webkit-user-select:none;user-select:none}.pattern-checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#524FA1}.pattern-duration{font-size:13px;color:#524fa1;font-weight:500}.add-pattern-button{width:100%;padding:14px;margin-top:12px;border-radius:10px;border:2px dashed rgba(82,79,161,.25);background-color:transparent;color:#524fa1;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-pattern-button:hover:not(:disabled){background-color:#524fa10d;border-color:#524fa166}.add-pattern-button:disabled{color:#9ea2b3;border-color:#9ea2b340;cursor:not-allowed}.pattern-info-box{margin-top:20px;padding:14px;background-color:#524fa10f;border-radius:10px;border:1px solid rgba(82,79,161,.1)}.pattern-info-title{font-size:13px;font-weight:600;color:#524fa1;margin:0 0 8px}.pattern-info-list{margin:0;padding-left:18px;font-size:12px;color:#6b6b89;line-height:1.6}.pattern-info-list li{margin-bottom:4px}.pattern-info-list li:last-child{margin-bottom:0}.time-picker-custom{display:flex;align-items:center;gap:4px;background-color:#fff;border:1px solid rgba(82,79,161,.2);border-radius:8px;padding:8px 12px;transition:border-color .2s ease}.time-picker-custom:focus-within{border-color:#524fa1}.time-select{border:none;background-color:transparent;font-size:16px;font-weight:500;color:#211d57;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .15s ease}.time-select:hover{background-color:#524fa114}.time-select:focus{outline:none;background-color:#524fa11f}.time-colon{font-size:16px;font-weight:600;color:#211d57}@media (max-width: 768px){.work-pattern-modal{max-width:100%}.pattern-time-row{flex-direction:column;align-items:stretch}.pattern-time-separator{margin:0;text-align:center}.pattern-options-row{flex-direction:column;align-items:flex-start;gap:10px}}.staff-pattern-modal{max-width:600px}.staff-pattern-search{margin-bottom:12px}.search-input{width:100%;height:44px;border-radius:10px;background-color:#f7f7ff;border:1px solid rgba(82,79,161,.2);padding:0 14px;font-size:14px;color:#211d57;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:#524fa1}.search-input::placeholder{color:#9ea2b3}.pattern-legend{display:flex;flex-wrap:wrap;gap:8px;padding:12px;background-color:#524fa10a;border-radius:8px;margin-bottom:16px}.pattern-legend-item{font-size:13px;color:#524fa1;font-weight:500}.pattern-legend-time{color:#6b6b89;font-weight:400;margin-left:4px}.staff-patterns-list{display:flex;flex-direction:column;gap:12px}.staff-pattern-card{padding:14px;background-color:#fafbff;border-radius:12px;border:1px solid rgba(82,79,161,.1)}.staff-pattern-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.staff-info{display:flex;align-items:center;gap:8px}.staff-name{font-size:15px;font-weight:600;color:#211d57}.unregistered-badge{font-size:11px;padding:2px 6px;background-color:#ff98001f;color:#e67700;border-radius:4px;font-weight:500}.select-all-button{padding:6px 12px;border-radius:6px;border:1px solid rgba(82,79,161,.2);background-color:#fff;color:#524fa1;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}.select-all-button:hover{background-color:#524fa114}.pattern-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.pattern-chip{padding:8px 14px;border-radius:999px;border:1px solid rgba(82,79,161,.18);background-color:#fff;font-size:13px;color:#211d57;cursor:pointer;transition:all .2s ease}.pattern-chip:hover{background-color:#524fa114}.pattern-chip.selected{background-color:#524fa1;border-color:#524fa1;color:#fff;font-weight:600}.pattern-chip.selected:hover{background-color:#423d8a}.staff-pattern-summary{font-size:12px;color:#6b6b89}.staff-pattern-summary .warning-text{color:#e67700}.no-members-message{text-align:center;padding:40px 20px;color:#6b6b89;font-size:14px}@media (max-width: 768px){.staff-pattern-modal{max-width:100%}.staff-pattern-header{flex-direction:column;align-items:flex-start;gap:8px}.select-all-button{align-self:flex-end}}.staff-order-modal{width:min(480px,95vw);max-height:85vh}.order-mode-section{margin-bottom:20px}.section-label{margin:0 0 12px;font-weight:600;color:#333}.radio-option{display:flex;align-items:center;gap:8px;padding:10px 12px;margin-bottom:8px;border-radius:8px;cursor:pointer;transition:background-color .2s}.radio-option:hover{background-color:#f5f6fa}.radio-option input[type=radio]{width:18px;height:18px;accent-color:#524FA1}.radio-option span{font-size:15px;color:#333}.manual-order-section,.preview-section{border-top:1px solid #E8E9F0;padding-top:16px;margin-top:8px}.section-hint{margin:0 0 12px;font-size:13px;color:#888}.sortable-list,.preview-list{display:flex;flex-direction:column;gap:6px;max-height:350px;overflow-y:auto}.sortable-item,.preview-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background-color:#f8f8fc;border:1px solid #E8E9F0;border-radius:8px;-webkit-user-select:none;user-select:none}.sortable-item{cursor:grab;transition:background-color .2s,box-shadow .2s}.sortable-item:hover{background-color:#f0effa}.sortable-item-dragging{box-shadow:0 8px 24px #524fa133;background-color:#fff}.sortable-item:active{cursor:grabbing}.drag-handle{font-size:18px;color:#999;font-weight:700}.item-number{font-size:14px;color:#888;min-width:24px}.item-name{flex:1;font-size:15px;color:#333}.item-badge{font-size:11px;background-color:#e8e9f0;color:#666;padding:2px 8px;border-radius:10px}.constraint-settings-modal{max-width:640px;max-height:85vh;display:flex;flex-direction:column;background-color:#fff;border-radius:20px;padding:28px 24px;box-shadow:0 12px 24px #211d572e;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.constraint-settings-modal .modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.constraint-settings-modal .modal-header h3{font-size:18px;font-weight:700;color:#211d57;margin:0}.constraint-settings-modal .modal-close{width:32px;height:32px;border:none;background-color:#f7f7ff;border-radius:8px;font-size:14px;color:#6b6b89;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.constraint-settings-modal .modal-close:hover{background-color:#524fa11a;color:#211d57}.constraint-settings-modal .modal-body{flex:1;overflow-y:auto;margin:0 -8px;padding:0 8px}.constraint-settings-modal .modal-body::-webkit-scrollbar{width:6px}.constraint-settings-modal .modal-body::-webkit-scrollbar-track{background:#f7f7ff;border-radius:3px}.constraint-settings-modal .modal-body::-webkit-scrollbar-thumb{background:#524fa14d;border-radius:3px}.constraint-settings-modal .modal-body::-webkit-scrollbar-thumb:hover{background:#524fa180}.constraint-section{margin-bottom:24px}.constraint-section h4{font-size:15px;font-weight:600;color:#524fa1;margin:0 0 6px}.constraint-section .section-description{font-size:13px;color:#6b6b89;margin:0 0 16px;line-height:1.5}.constraint-list{display:flex;flex-direction:column;gap:8px}.constraint-item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background-color:#fafbff;border-radius:10px;border:1px solid rgba(82,79,161,.1);transition:all .2s ease}.constraint-item.disabled{opacity:.5;background-color:#f5f5f8}.constraint-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.constraint-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#524FA1}.constraint-label{font-size:14px;font-weight:500;color:#211d57}.constraint-value{display:flex;align-items:center;gap:6px}.constraint-value input[type=number]{width:64px;height:36px;border-radius:8px;background-color:#fff;border:1px solid rgba(82,79,161,.2);padding:0 10px;font-size:14px;color:#211d57;text-align:center;transition:border-color .2s ease}.constraint-value input[type=number]:focus{outline:none;border-color:#524fa1}.constraint-value input[type=number]:disabled{background-color:#f0f0f5;color:#9ea2b3;cursor:not-allowed}.constraint-unit{font-size:13px;color:#6b6b89;min-width:24px}.time-range-inputs{display:flex;align-items:center;gap:4px}.time-range-inputs input[type=number]{width:52px;height:36px;border-radius:8px;background-color:#fff;border:1px solid rgba(82,79,161,.2);padding:0 8px;font-size:14px;color:#211d57;text-align:center;transition:border-color .2s ease}.time-range-inputs input[type=number]:focus{outline:none;border-color:#524fa1}.time-range-inputs input[type=number]:disabled{background-color:#f0f0f5;color:#9ea2b3;cursor:not-allowed}.time-range-inputs span{font-size:13px;color:#6b6b89}.toggle-only{font-size:13px;font-weight:600;color:#524fa1;min-width:30px;text-align:center}.custom-rules-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.custom-rule-item{padding:14px;background-color:#fafbff;border-radius:10px;border:1px solid rgba(82,79,161,.1);transition:all .2s ease}.custom-rule-item.disabled{opacity:.5;background-color:#f5f5f8}.custom-rule-header{display:flex;align-items:center;justify-content:space-between}.delete-rule-btn{padding:4px 10px;border-radius:6px;border:1px solid rgba(224,91,67,.3);background-color:#fff;color:#e05b43;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.delete-rule-btn:hover{background-color:#e05b4314;border-color:#e05b43}.custom-rule-config{margin-top:12px;padding-top:12px;border-top:1px solid rgba(82,79,161,.08);display:flex;flex-direction:column;gap:10px}.custom-rule-config label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#6b6b89;font-weight:500}.custom-rule-config select{height:40px;border-radius:8px;background-color:#fff;border:1px solid rgba(82,79,161,.2);padding:0 10px;font-size:14px;color:#211d57;transition:border-color .2s ease}.custom-rule-config select[multiple]{height:80px;padding:8px 10px}.custom-rule-config select:focus{outline:none;border-color:#524fa1}.custom-rule-config input[type=number]{width:80px;height:36px;border-radius:8px;background-color:#fff;border:1px solid rgba(82,79,161,.2);padding:0 10px;font-size:14px;color:#211d57;text-align:center;transition:border-color .2s ease}.custom-rule-config input[type=number]:focus{outline:none;border-color:#524fa1}.custom-rule-config input[type=range]{width:100%;accent-color:#524FA1;margin-top:4px}.range-labels{display:flex;justify-content:space-between;font-size:11px;color:#9ea2b3;margin-top:2px}.add-rule-form{display:flex;gap:10px;align-items:center}.add-rule-form select{flex:1;height:40px;border-radius:8px;background-color:#f7f7ff;border:1px solid rgba(82,79,161,.2);padding:0 10px;font-size:14px;color:#211d57;transition:border-color .2s ease}.add-rule-form select:focus{outline:none;border-color:#524fa1}.constraint-settings-modal .modal-footer{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:1px solid #F0F0F5}.modal-footer-right{display:flex;gap:10px}.ghost-button{padding:10px 16px;border-radius:10px;border:1px solid rgba(82,79,161,.25);background-color:#fff;color:#524fa1;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.ghost-button:hover{background-color:#f7f7ff}.ghost-button:active{transform:scale(.98)}.primary-button{padding:10px 20px;border-radius:10px;border:none;background-color:#524fa1;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.primary-button:hover{background-color:#423d8a}.primary-button:active{transform:scale(.98)}.primary-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.constraint-settings-modal{padding:20px 16px;max-width:100%}.constraint-item{flex-direction:column;align-items:flex-start;gap:8px}.add-rule-form{flex-direction:column}.add-rule-form select{width:100%}.constraint-settings-modal .modal-footer{flex-direction:column-reverse;gap:10px}.modal-footer-right{width:100%}.modal-footer-right .ghost-button,.modal-footer-right .primary-button{flex:1}}.ng-pairs-list{margin-bottom:8px}.ng-pair-item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:#f5f4ff;border-radius:6px;margin-bottom:4px;font-size:13px;color:#2e2a5c}.delete-pair-btn{background:none;border:1px solid rgba(224,91,67,.3);color:#e05b43;border-radius:4px;padding:2px 8px;font-size:11px;cursor:pointer}.delete-pair-btn:hover{background:#e05b430d}.ng-pair-add{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.ng-pair-add select{flex:1;min-width:100px;padding:6px 8px;border:1px solid rgba(82,79,161,.2);border-radius:6px;font-size:13px;color:#2e2a5c;background:#fff}.ng-pair-separator{color:#6d6a9e;font-size:14px}.mypage-container{display:flex;flex-direction:column;gap:20px}.settings-section,.members-section,.profile-section,.invite-section,.unregistered-section,.group-management-section{border:1px solid #E8E9F0;border-radius:12px;padding:20px;background-color:#fff;display:flex;flex-direction:column;gap:16px}.section-description{font-size:14px;color:#6b6b89;margin:0 0 12px;line-height:1.6}.profile-actions{display:flex;gap:12px;flex-wrap:wrap}.field-block{display:flex;flex-direction:column;gap:8px}.status-text{margin:0;color:#524fa1;font-size:14px}.action-list{display:flex;flex-direction:column;gap:12px}.action-button{width:100%;background-color:#fff;border-radius:16px;padding:18px 20px;border:1px solid rgba(82,79,161,.06);box-shadow:0 4px 12px #211d570d;cursor:pointer;transition:all .2s ease;text-align:left}.action-button:hover{box-shadow:0 6px 16px #211d571a;transform:translateY(-2px);border-color:#524fa126}.action-button:active{transform:translateY(0)}.action-content{display:flex;flex-direction:column;gap:4px}.action-title{font-size:16px;font-weight:600;color:#211d57;margin:0 0 4px}.action-subtitle{font-size:13px;color:#6b6b89;margin:0;line-height:1.5}.current-setting{font-size:12px;color:#524fa1;margin:6px 0 0;font-weight:500}.action-button-highlight{background:linear-gradient(135deg,#524fa114,#524fa10a);border:2px solid rgba(82,79,161,.2)}.action-button-highlight:hover{border-color:#524fa166;background:linear-gradient(135deg,#524fa11f,#524fa10f)}.action-button-highlight .action-title{color:#524fa1}.action-button-highlight:disabled{opacity:.6;cursor:not-allowed;transform:none}.action-button-secondary{background-color:#f5f5f5;border:1px solid #E0E0E0}.action-button-secondary:hover{background-color:#eee;border-color:#bdbdbd}.action-button-secondary .action-title{color:#666}.action-button-secondary .action-subtitle{color:#888}.members-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.members-section li{display:flex;justify-content:space-between;border:1px solid #E8E9F0;border-radius:8px;padding:10px 12px;flex-wrap:wrap;gap:8px}.member-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.member-role{color:#666;font-size:14px}.role-select{padding:6px 10px;border:1px solid #E8E9F0;border-radius:6px;font-size:13px;color:#211d57;background-color:#fff;cursor:pointer;transition:border-color .2s ease}.role-select:hover{border-color:#524fa1}.role-select:focus{outline:none;border-color:#524fa1}.role-select:disabled{opacity:.6;cursor:not-allowed}.self-badge{padding:2px 8px;background-color:#524fa11a;color:#524fa1;border-radius:4px;font-size:11px;font-weight:600}.member-label{padding:4px 10px;background-color:#524fa11a;border-radius:12px;font-size:12px;color:#524fa1;font-weight:500}.member-name-container{display:flex;align-items:center;gap:8px}.unregistered-badge-inline{display:inline-block;padding:2px 8px;background-color:#e05b4326;color:#c62828;border-radius:4px;font-size:11px;font-weight:600}.border-button.danger{border-color:#d64545;color:#d64545}.border-button.danger:hover{background-color:#d64545;color:#fff}.qr-invite-section{border:1px solid #E8E9F0;border-radius:12px;padding:20px;background-color:#fff;display:flex;flex-direction:column;gap:16px}.qr-code-container{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px;background-color:#f8f8fc;border-radius:12px}.invite-code-display{display:flex;flex-direction:column;align-items:center;gap:4px}.invite-code-label{font-size:12px;color:#6b6b89}.invite-code-value{font-size:20px;font-weight:700;color:#524fa1;letter-spacing:2px;font-family:monospace}.invite-link-actions{display:flex;justify-content:center;gap:12px}.invite-form{display:flex;gap:12px;flex-wrap:wrap}.invite-form input{flex:1;min-width:200px}.invite-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.invite-list li{display:flex;justify-content:space-between;align-items:center;border:1px solid #E8E9F0;border-radius:8px;padding:8px 10px;gap:10px;flex-wrap:wrap}.invite-status{color:#666;font-size:13px}.member-meta{display:block;font-size:12px;color:#888;margin-top:4px}.empty-copy{color:#888;font-size:14px;margin:0}.group-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.group-item{display:flex;flex-direction:column;padding:12px 16px;border:1px solid #E8E9F0;border-radius:8px;background-color:#fff;transition:all .2s ease}.group-item.active{border-color:#524fa1;background-color:#524fa10d}.group-info{display:flex;flex-direction:column;gap:4px}.group-name{font-size:15px;font-weight:600;color:#211d57}.group-meta{font-size:12px;color:#6b6b89}.active-badge{display:inline-block;padding:2px 8px;background-color:#524fa126;color:#524fa1;border-radius:4px;font-size:11px;font-weight:600;margin-top:4px}.group-main-content{display:flex;justify-content:space-between;align-items:center;width:100%}.group-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #E8E9F0}.group-action-button{padding:6px 14px;font-size:13px;font-weight:600;border:1px solid rgba(82,79,161,.2);border-radius:6px;background-color:transparent;color:#524fa1;cursor:pointer;transition:all .2s ease}.group-action-button:hover{background-color:#524fa114;border-color:#524fa1}.group-action-button.danger{border-color:#c81e1e4d;color:#c81e1e;background-color:#fff8f6}.group-action-button.danger:hover{background-color:#fee;border-color:#c81e1e}.group-action-button:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;border-radius:16px;padding:24px;max-width:400px;width:90%;box-shadow:0 4px 24px #0003}.modal-content h3{margin:0 0 8px;font-size:18px;color:#211d57}.modal-description{font-size:14px;color:#6b6b89;margin:0 0 16px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}@media (max-width: 768px){.profile-actions{flex-direction:column}.action-button{padding:16px 18px}.action-title{font-size:15px}.action-subtitle{font-size:12px}.invite-form{flex-direction:column}.invite-form input{width:100%}.group-action-buttons{flex-direction:column}}.group-action-buttons{display:flex;gap:12px;flex-wrap:wrap}.group-action-buttons .primary-button{flex:1;min-width:200px}.group-action-buttons .primary-button.secondary{background-color:#fff;color:#524fa1;border:1px solid #524FA1}.group-action-buttons .primary-button.secondary:hover{background-color:#f2f1fb}.qr-scan-modal{max-width:450px}.qr-scanner-container{width:100%;max-width:300px;aspect-ratio:1;margin:16px auto;border-radius:12px;overflow:hidden;background-color:#000}.qr-scanner-container video{width:100%;height:100%;object-fit:cover}.qr-scan-error{color:#d64545;font-size:14px;margin:8px 0;text-align:center}.qr-scan-status{color:#524fa1;font-size:14px;margin:8px 0;text-align:center}.register-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.register-card{background:#fff;border-radius:20px;padding:40px;box-shadow:0 10px 40px #0003;max-width:500px;width:100%}.register-card h1{font-size:28px;font-weight:700;color:#211d57;margin:0 0 8px;text-align:center}.register-subtitle{font-size:14px;color:#6b6b89;text-align:center;margin:0 0 32px}.register-form{display:flex;flex-direction:column;gap:20px}.error-message{background-color:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:8px;padding:12px;color:#c62828;font-size:14px;text-align:center}.role-toggle{display:flex;gap:8px;background-color:#f7f7ff;border-radius:12px;padding:4px}.role-button{flex:1;padding:12px;border:none;border-radius:8px;font-size:15px;font-weight:600;color:#6b6b89;background-color:transparent;cursor:pointer;transition:all .2s ease}.role-button:hover{background-color:#524fa114}.role-button.active{background-color:#524fa1;color:#fff}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#211d57}.form-group input{height:48px;border-radius:10px;background-color:#f7f7ff;border:1px solid rgba(82,79,161,.2);padding:0 14px;font-size:16px;color:#211d57;transition:border-color .2s ease}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder{color:#9ea2b3}.form-hint{font-size:12px;color:#6b6b89;margin:0;line-height:1.5}.register-button{height:52px;border-radius:12px;background-color:#524fa1;border:none;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.register-button:hover:not(:disabled){background-color:#423d8a;transform:translateY(-1px);box-shadow:0 4px 12px #524fa14d}.register-button:active:not(:disabled){transform:translateY(0)}.register-button:disabled{opacity:.6;cursor:not-allowed}.register-footer{text-align:center;margin-top:8px}.register-footer p{font-size:14px;color:#6b6b89;margin:0}.register-footer a{color:#524fa1;text-decoration:none;font-weight:600}.register-footer a:hover{text-decoration:underline}.current-user-info{background-color:#f7f7ff;border-radius:12px;padding:16px;margin-bottom:24px;text-align:center}.current-user-info p{margin:0;font-size:14px;color:#211d57}.current-user-info strong{font-size:16px;font-weight:600}.current-user-info .current-user-email{color:#6b6b89;margin-top:4px}.text-button{background:none;border:none;color:#524fa1;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none}.text-button:hover{text-decoration:underline}.choice-text{font-size:14px;color:#6b6b89;text-align:center;line-height:1.6;margin-bottom:16px}.register-button.secondary{background-color:transparent;border:1px solid #524FA1;color:#524fa1;margin-top:12px}.register-button.secondary:hover:not(:disabled){background-color:#524fa114}.webview-warning{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#ff9800,#f57c00);padding:16px 20px;z-index:1000;box-shadow:0 2px 12px #00000026}.webview-warning-content{max-width:500px;margin:0 auto;text-align:center;color:#fff}.webview-warning-content strong{display:block;font-size:16px;margin-bottom:8px}.webview-warning-content p{font-size:13px;margin:0 0 12px;line-height:1.5;opacity:.95}.copy-url-button{background-color:#fff;color:#f57c00;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.copy-url-button:hover{background-color:#fff3e0;transform:translateY(-1px)}.copy-url-button:active{transform:translateY(0)}.register-container:has(.webview-warning){padding-top:140px}@media (max-width: 768px){.register-card{padding:24px}.register-card h1{font-size:24px}.webview-warning{padding:12px 16px}.webview-warning-content strong{font-size:14px}.webview-warning-content p{font-size:12px}.register-container:has(.webview-warning){padding-top:160px}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:#f5f6fa}.spinner{width:50px;height:50px;border:4px solid #E8E9F0;border-top-color:#524fa1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:400px}.login-card h1{color:#524fa1;margin-bottom:8px;font-size:28px}.subtitle{color:#666;margin-bottom:32px;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px;text-align:left}.form-group label{color:#333;font-weight:600;font-size:14px}.form-group input{padding:12px 16px;border:2px solid #E8E9F0;border-radius:8px;font-size:16px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#524fa1}.login-button{background-color:#524fa1;color:#fff;padding:14px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s;margin-top:8px}.login-button:hover{background-color:#433d85}.error-message{color:#e74c3c;font-size:14px;margin:-8px 0 0;text-align:left;white-space:pre-line}.success-message{color:#27ae60;font-size:14px;margin:-8px 0 0;text-align:left}.text-button{background:none;border:none;color:#524fa1;font-size:14px;cursor:pointer;text-decoration:underline;padding:0;margin-top:8px}.text-button:hover{color:#433d85}.text-button:disabled{color:#999;cursor:not-allowed}.info-text{margin-top:24px;text-align:center}.info-text p{color:#666;font-size:13px}.qr-section{margin-top:32px;padding-top:24px;border-top:1px solid #E8E9F0;text-align:center}.qr-title{color:#666;font-size:14px;margin-bottom:16px}.qr-codes{display:flex;justify-content:center;gap:24px}.qr-item{display:flex;flex-direction:column;align-items:center;gap:8px}.qr-item span{font-size:12px;color:#666;font-weight:500}.dashboard-container{min-height:100vh;background-color:#f5f6fa}.dashboard-header{background-color:#524fa1;color:#fff;padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.dashboard-header h1{margin:0;font-size:24px}.logout-button{background-color:#fff3;color:#fff;padding:10px 20px;border:1px solid white;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .3s}.logout-button:hover{background-color:#ffffff4d}.dashboard-content{max-width:800px;margin:0 auto;padding:40px 20px;display:flex;flex-direction:column;gap:20px}.welcome-card,.info-card{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 10px #0000000d}.welcome-card h2{color:#524fa1;margin-top:0;margin-bottom:16px;font-size:24px}.welcome-card p{color:#666;margin:8px 0;font-size:15px}.info-card h3{color:#333;margin-top:0;margin-bottom:12px;font-size:18px}.info-card p{color:#666;margin:8px 0;font-size:14px;line-height:1.6}.app-layout{min-height:100vh;display:flex;flex-direction:column;background-color:#f5f6fa}.tab-nav{display:flex;background-color:#fff;border-bottom:2px solid #E8E9F0;box-shadow:0 2px 4px #0000000d;position:sticky;top:64px;z-index:100}.tab-item{flex:1;padding:16px;text-align:center;color:#666;text-decoration:none;font-weight:600;border-bottom:3px solid transparent;transition:all .3s}.tab-item:hover{background-color:#f5f6fa;color:#524fa1}.tab-item.active{color:#524fa1;border-bottom-color:#524fa1;background-color:#f5f6fa}.app-main{flex:1;padding:20px;background-color:#f5f6fa;overflow-y:auto}.main-content{padding:20px;min-height:calc(100vh - 140px);background-color:#f5f6fa}.page-container{max-width:100%;width:100%;margin:0;background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 10px #0000000d;box-sizing:border-box}.page-container h2{color:#524fa1;margin-top:0;margin-bottom:20px}.info-box{background:linear-gradient(135deg,#524fa1,#6b67c8);border-radius:12px;padding:16px 14px;margin-bottom:0;box-shadow:0 2px 8px #524fa126}.info-box p{margin:0;padding:6px 0;font-size:13px;color:#fff;font-weight:500;line-height:1.5;word-break:break-all}.info-box p:first-child{font-weight:600;font-size:14px;margin-bottom:4px}.home-layout{display:flex;gap:16px;width:100%}.home-sidebar{flex:0 0 200px;display:flex;flex-direction:column}.home-main{flex:1;min-width:0}@media (max-width: 1024px){.home-layout{flex-direction:column}.home-sidebar{flex:0 0 auto;width:100%}}.calendar-placeholder{background:#f9f9fc;border:2px dashed #E8E9F0;border-radius:8px;padding:40px;text-align:center;margin-top:20px}.calendar-placeholder h3{color:#524fa1;margin-top:0}.note{color:#999;font-size:14px;font-style:italic}.user-info{display:flex;align-items:center;gap:16px}.user-info span{font-weight:600}.primary-button{background-color:#524fa1;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #524fa133}.primary-button:hover{background-color:#433d85;transform:translateY(-1px);box-shadow:0 4px 8px #524fa14d}.primary-button:active{transform:translateY(0)}.primary-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.ghost-button{background-color:#fff;border:1px solid #E8E9F0;border-radius:8px;padding:10px 16px;font-weight:600;color:#524fa1;cursor:pointer;transition:background-color .2s,border-color .2s}.ghost-button:hover:not(:disabled){background-color:#f5f6fa;border-color:#d5d7e2}.ghost-button:disabled{opacity:.5;cursor:not-allowed}.border-button{background-color:transparent;border:1px solid #C8C9D7;border-radius:8px;padding:10px 16px;font-weight:600;color:#524fa1;cursor:pointer;transition:border-color .2s}.border-button:hover{border-color:#524fa1}.plain-button{background:none;border:none;color:#666;font-size:14px;cursor:pointer;padding:4px 8px}.field-label{font-size:13px;font-weight:600;color:#555;margin-bottom:6px}.text-input{width:100%;padding:12px 14px;border-radius:10px;border:2px solid #E8E9F0;font-size:14px}.text-input:focus{outline:none;border-color:#524fa1}.spaced-column{display:flex;flex-direction:column;gap:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0f0f2373;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.modal-card{background-color:#fff;border-radius:16px;width:min(520px,95vw);max-height:90vh;display:flex;flex-direction:column;border:1px solid #E8E9F0;box-shadow:0 20px 70px #18103926}.modal-header{padding:20px 24px;border-bottom:1px solid #E8E9F0;display:flex;align-items:center;justify-content:space-between;gap:20px}.modal-eyebrow{margin:0 0 4px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#888}.modal-title{margin:0;font-size:20px;color:#333}.modal-body{padding:20px 24px;overflow-y:auto}.modal-footer{border-top:1px solid #E8E9F0;padding:16px 24px;display:flex;justify-content:flex-end;gap:12px}.shift-status-modal{width:min(640px,95vw)}.shift-slot-list{display:flex;flex-direction:column;gap:16px}.shift-slot-card{border:1px solid #E8E9F0;border-radius:12px;padding:16px;background-color:#f8f8fc}.slot-headline{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.slot-badge{background-color:#524fa1;color:#fff;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:600}.slot-time{margin:0;color:#666;font-size:14px}.status-options{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.status-indicator{flex:1 1 100%;margin-bottom:8px;text-align:center}.status-default{color:#2c8c53;font-weight:600;font-size:14px}.status-unavailable-text{color:#b3392d;font-weight:600;font-size:14px}.status-chip{flex:1 1 140px;min-width:140px;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-weight:600;background-color:#fff;transition:border-color .2s,transform .1s}.status-chip.status-available{border-color:#524fa14d;color:#3a3882}.status-chip.status-unavailable{border-color:#e74c3c4d;color:#a03a2f}.status-chip.is-selected{transform:translateY(-1px);border-color:#524fa1;background-color:#524fa114}.status-icon{font-size:16px}.empty-copy{margin:16px 0;text-align:center;color:#777;font-size:14px}.shift-detail-body{max-height:60vh}.shift-detail-list{display:flex;flex-direction:column;gap:12px}.shift-detail-card{border:1px solid #E8E9F0;border-radius:12px;padding:12px 16px;background-color:#fff}.shift-detail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.shift-count{font-size:12px;color:#666}.shift-detail-card ul{margin:0;padding-left:18px;color:#333}.event-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0f0f2373;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.event-modal-card{background-color:#fff;border-radius:16px;width:min(450px,95vw);border:1px solid #E8E9F0;box-shadow:0 20px 70px #18103926;display:flex;flex-direction:column}.event-modal-header{padding:20px 24px;border-bottom:1px solid #E8E9F0;display:flex;align-items:center;justify-content:space-between}.event-modal-header h3{margin:0;font-size:20px;color:#333}.event-modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:16px}.event-detail-row{display:flex;flex-direction:column;gap:6px}.event-detail-label{font-size:12px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.05em}.event-detail-value{font-size:15px;color:#333;line-height:1.5}.event-detail-badge{margin-top:8px}.badge-private{display:inline-block;background-color:#4caf50;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.event-modal-actions{padding:16px 24px;border-top:1px solid #E8E9F0;display:flex;justify-content:flex-end}.shift-assign-body{max-height:60vh}.assign-section{margin-bottom:20px}.assign-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#524fa1}.assign-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.assign-list li{border:1px solid #E8E9F0;border-radius:8px;padding:10px 14px;background-color:#fff}.assign-list li label{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.assign-list li input[type=checkbox]{width:18px;height:18px;cursor:pointer}.status-available{color:#2e7d32;font-weight:600}.status-unavailable{color:#d32f2f;font-weight:600}.home-user-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;margin:-30px -30px 20px;background:linear-gradient(135deg,#524fa1,#6b67c8);border-radius:12px 12px 0 0;box-shadow:0 2px 8px #524fa126}.user-welcome{font-size:14px;font-weight:600;color:#fff}.user-group-id{font-size:12px;font-weight:500;color:#ffffffe6;background:#ffffff26;padding:4px 12px;border-radius:12px;word-break:break-all}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #E8E9F0}.home-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.home-calendar-container{width:100%}.month-switcher{display:flex;align-items:center;gap:16px}.month-switcher span{font-size:18px;font-weight:600;color:#524fa1;min-width:120px;text-align:center}.month-switcher .month-nav-button{background-color:#524fa1;color:#fff;border:none;border-radius:6px;padding:6px 12px;cursor:pointer;transition:background-color .2s;font-size:14px}.month-switcher .month-nav-button:hover{background-color:#433d85}.add-event-modal{width:min(600px,95vw)}.event-form{display:flex;flex-direction:column;gap:16px}.field-block{display:flex;flex-direction:column;gap:6px}.field-label{font-size:13px;font-weight:600;color:#555}.text-input[type=date],.text-input[type=time]{max-width:100%}textarea.text-input{resize:vertical;min-height:80px}.date-time-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.color-picker{display:flex;gap:12px;flex-wrap:wrap}.color-option{width:40px;height:40px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:transform .2s,border-color .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#333;transform:scale(1.15);box-shadow:0 0 0 2px #fff,0 0 0 4px #333}.checkbox-field{display:flex;align-items:center;gap:10px;padding:12px;background-color:#f5f6fa;border-radius:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-field input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-field span{font-size:14px;color:#333}.multi-date-section{display:flex;flex-direction:column;gap:12px}.multi-date-picker{background:#f5f6fa;border-radius:12px;padding:16px;border:1px solid #E8E9F0}.multi-date-picker .calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.multi-date-picker .month-nav-btn{background:#fff;border:1px solid #E8E9F0;border-radius:6px;width:32px;height:32px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s}.multi-date-picker .month-nav-btn:hover{background:#524fa1;color:#fff;border-color:#524fa1}.multi-date-picker .month-label{font-weight:600;font-size:14px;color:#333}.multi-date-picker .calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.multi-date-picker .weekday{text-align:center;font-size:11px;font-weight:600;color:#888;padding:4px 0}.multi-date-picker .calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.multi-date-picker .calendar-day{aspect-ratio:1;border:none;background:#fff;border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;color:#333}.multi-date-picker .calendar-day:hover:not(:disabled){background:#e8e9f0}.multi-date-picker .calendar-day.other-month{color:#ccc;background:transparent}.multi-date-picker .calendar-day.selected{background:#524fa1;color:#fff;font-weight:600}.multi-date-picker .calendar-day.start-date{background:#4caf50;color:#fff;font-weight:600}.multi-date-picker .calendar-day:disabled{cursor:default}.selected-dates-info{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid #E8E9F0}.selected-count{font-size:13px;color:#524fa1;font-weight:600}.clear-dates-btn{background:none;border:none;color:#888;font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.clear-dates-btn:hover{background:#e8e9f0;color:#333}.info-banner{background-color:#fff3cd;border:1px solid #FFC107;border-radius:8px;padding:16px;margin-bottom:16px}.info-banner p{margin:0 0 8px;color:#856404}.info-banner p:last-child{margin-bottom:0}.info-banner .note{font-size:13px;color:#666}.event-display{padding:16px;background-color:#f5f6fa;border-radius:8px}.event-display p{margin:8px 0;color:#333}.ghost-button.danger{color:#f44336;border-color:#f44336}.ghost-button.danger:hover:not(:disabled){background-color:#ffebee;border-color:#d32f2f}.member-selector-modal{max-height:85vh}.add-member-button{display:flex;align-items:center;justify-content:center;width:100%;padding:18px;margin-bottom:16px;background-color:#524fa1;border:none;border-radius:12px;box-shadow:0 2px 4px #211d5726;cursor:pointer;transition:all .2s}.add-member-button:hover{background-color:#433d8c;box-shadow:0 4px 8px #211d5733}.add-member-button:active{transform:scale(.98)}.add-member-icon{font-size:22px;font-weight:700;color:#fff;margin-right:8px}.add-member-text{font-size:16px;font-weight:700;color:#fff}.member-list{display:flex;flex-direction:column;gap:8px}.member-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px;background-color:#f7f7ff;border:1px solid rgba(82,79,161,.1);border-radius:12px;cursor:pointer;transition:all .2s;text-align:left}.member-item:hover{background-color:#ededf9;border-color:#524fa133}.member-item-selected{background-color:#e8e7f5;border:2px solid #524FA1;border-color:#524fa1}.member-info{display:flex;align-items:center;flex:1;gap:8px}.member-name{font-size:16px;font-weight:500;color:#333}.member-name-selected{font-weight:600;color:#524fa1}.member-badge{padding:2px 8px;background-color:#fff8f6;border:1px solid rgba(224,91,67,.3);border-radius:6px;font-size:11px;font-weight:600;color:#e05b43}.checkmark{font-size:20px;font-weight:700;color:#524fa1}.copy-event-modal{width:min(500px,95vw)}.copy-modal-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.copy-modal-instruction{margin:0;font-size:14px;color:#666}.copy-modal-selected-count{margin:0;font-size:14px;font-weight:600;color:#524fa1}.copy-calendar{background-color:#f5f6fa;border-radius:12px;padding:16px}.copy-calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.copy-calendar-nav{background-color:#524fa1;color:#fff;border:none;border-radius:6px;padding:6px 12px;cursor:pointer;transition:background-color .2s;font-size:12px}.copy-calendar-nav:hover:not(:disabled){background-color:#433d85}.copy-calendar-nav:disabled{opacity:.5;cursor:not-allowed}.copy-calendar-month{font-size:16px;font-weight:600;color:#524fa1}.copy-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.copy-calendar-weekday{text-align:center;font-size:12px;font-weight:600;color:#666;padding:4px 0}.copy-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.copy-calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;background-color:#fff;font-size:14px;color:#333;cursor:pointer;transition:all .2s}.copy-calendar-day:hover:not(:disabled):not(.selected):not(.original){background-color:#e8e7f5}.copy-calendar-day.other-month{color:#ccc;background-color:transparent}.copy-calendar-day.selected{background-color:#524fa1;color:#fff;font-weight:600}.copy-calendar-day.original{background-color:#4caf50;color:#fff;cursor:not-allowed}.copy-calendar-day:disabled:not(.original){cursor:default}.copy-selected-dates{margin-top:16px}.copy-selected-label{margin:0 0 8px;font-size:13px;font-weight:600;color:#555}.copy-selected-list{display:flex;flex-wrap:wrap;gap:8px}.copy-selected-date-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background-color:#e8e7f5;border-radius:16px;font-size:13px;color:#524fa1}.copy-chip-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;border-radius:50%;background-color:#524fa1;color:#fff;font-size:12px;cursor:pointer;transition:background-color .2s}.copy-chip-remove:hover{background-color:#433d85}
