.calendario-event-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;z-index:1000;padding:0}.calendario-event-modal{background-color:white;border-radius:8px;padding:0;width:90vw;height:90vh;max-width:1202px;max-height:700px;overflow:hidden;display:flex;flex-direction:row;box-shadow:0 10px 40px rgba(0,0,0,.15)}.modal-left-panel{width:60%;height:100%;overflow-y:auto;padding:32px;box-sizing:border-box;background-color:#f1f1f1;display:flex;flex-direction:column;gap:24px}.left-panel-header{gap:15px}.day-box,.left-panel-header{display:flex;align-items:center}.day-box{width:48px;height:48px;background-color:#21b3e7;border-radius:8px;justify-content:center;flex-shrink:0}.day-number-large{font-size:24px;font-weight:700;color:white}.day-text{display:flex;flex-direction:column;gap:4px}.day-month{font-size:12px;font-weight:700;color:#000}.day-name{font-size:12px;font-weight:400;color:#999194}.left-section{display:flex;flex-direction:column;align-items:flex-start;gap:12px;width:100%}.section-header{display:flex;align-items:center;gap:8px;width:100%}.icon-badge.agenda-icon{width:36px;height:36px;border-radius:8px;background:#21B3E7;display:inline-flex;align-items:center;justify-content:center}.section-header svg{width:24px;height:24px;flex-shrink:0}.section-label{font-size:12px;font-weight:700;color:#000;white-space:nowrap}.schedule-item{flex-direction:column;flex:1;cursor:pointer}.schedule-item,.schedule-list{display:flex;gap:16px;width:100%}.schedule-list{flex-direction:column;margin-top:12px}.schedule-time{font-size:12px;font-weight:600;color:#000}.schedule-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:white;border:2px solid #21b3e7;border-radius:8px;gap:12px;height:48px;transition:all .2s}.schedule-card:hover{background-color:#f5faff}.schedule-card.selected{outline:2px solid #2d9cdb;border-radius:10px}.schedule-card.available,.schedule-card.confirmed{border-color:#21b3e7;background-color:white}.schedule-card.reserved{border-color:#ff9800;background-color:#ffccbc;opacity:.6}.schedule-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.schedule-tag{padding:4px 8px;border-radius:8px;font-size:11px;font-weight:600;white-space:nowrap}.schedule-tag.available,.schedule-tag.online{background-color:#c0eab8;color:#2e7d32}.schedule-title{font-size:12px;color:#000;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.schedule-actions{display:flex;align-items:center;gap:16px;white-space:nowrap;margin-left:auto}.participants-count{font-size:12px;color:#000;font-weight:400;white-space:nowrap;text-align:right;width:104px}.empty-section{font-size:12px;color:#999194}.icon-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .2s}.icon-btn svg{width:24px;height:24px}.icon-btn:hover{opacity:.7}.icon-btn.recording-btn.disabled,.icon-btn.recording-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.icon-btn.recording-btn:not(:disabled):hover{opacity:.85}.modal-right-panel{width:40%;height:100%;overflow-y:auto;display:flex;flex-direction:column;box-sizing:border-box;position:relative;background-color:white;padding:32px}.close-btn{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:#000;padding:8px;display:flex;align-items:center;justify-content:center;transition:background-color .2s;z-index:10;width:40px;height:40px;border-radius:8px}.close-btn:hover{background-color:#f5f5f5}.close-btn svg{width:24px;height:24px;stroke:#000}.right-panel-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:16px;padding-top:24px}.status-badge-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-bottom:8px}.status-badge-icon svg{width:100%;height:100%}.service-title{font-size:24px;font-weight:700;color:#000;margin:0}.tag-container{display:flex;gap:8px;flex-wrap:wrap}.tag-online{display:inline-block;background-color:#c0eab8;color:#2e7d32;padding:4px 8px;border-radius:8px;font-size:12px;font-weight:600;white-space:nowrap}.time-info-section{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px;font-weight:400;color:#000}.time-info-left{display:flex;align-items:center;gap:8px}.time-info-actions{display:flex;align-items:center;gap:12px}.time-value{font-weight:600;color:#000}.recording-link,.time-timezone{color:#999194;font-size:12px}.recording-link{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:#f1f1f1;border-radius:8px;font-weight:400;border:none;cursor:pointer;text-align:left}.recording-link svg{flex-shrink:0;width:20px;height:20px}.recording-text{white-space:nowrap}.teams-join-bar{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;margin-top:10px;background:#e8f1ff;border:1px solid #b8d4ff;border-radius:10px;text-decoration:none;color:#1d4ed8;font-size:14px;line-height:1}.teams-join-bar:hover{background:#dbeafe}.teams-join-icon{display:flex;align-items:center;justify-content:center}.teams-join-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.reschedule-link{background:transparent;border:none;padding:0;margin:0;color:#2563eb;font-size:14px;font-weight:500;cursor:pointer;text-decoration:none}.reschedule-link:hover{text-decoration:underline}.reschedule-link:disabled{opacity:.5;cursor:not-allowed;text-decoration:none}.cancel-link{background:transparent;border:none;padding:0;margin:0;color:#dc2626;font-size:14px;font-weight:500;cursor:pointer;text-decoration:none}.cancel-link:hover{text-decoration:underline}.reschedule-hint{font-size:12px;color:#b45309;margin-top:-6px}.host-section,.participants-section{display:flex;flex-direction:column;gap:16px}.section-title{font-size:12px;font-weight:600;color:#000;margin:0}.participant-info{display:flex;align-items:center;gap:12px;padding:0}.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}.name{font-size:12px;font-weight:700;color:#000}.details-actions{margin-top:auto;padding-top:16px;border-top:1px solid #e0e0e0;display:flex;flex-direction:column;gap:12px}.feedback-message{padding:12px 16px;border-radius:6px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px}.feedback-message.success{background-color:#e8f5e9;color:#2e7d32;border-left:4px solid #4caf50}.feedback-message.error{background-color:#ffebee;color:#c62828;border-left:4px solid #f44336}.unavailable-message{padding:12px;background-color:#fff3e0;border-radius:6px;color:#e65100;font-size:13px;font-weight:600;text-align:center}.btn-booking{width:100%;padding:12px 16px;background-color:#21B3E7;color:white;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background-color .3,transform .2s;margin:0}.btn-booking:hover:not(:disabled){background-color:#1a8fb8}.btn-booking:active:not(:disabled){transform:translateY(0)}.btn-booking:disabled{opacity:.6;cursor:not-allowed}.reschedule-booking-overlay{position:fixed;inset:0;background-color:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;z-index:1100;padding:16px}.reschedule-booking-modal{width:min(560px,92vw);max-height:90vh;background-color:#fff;border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.2);display:flex;flex-direction:column;overflow:hidden}.reschedule-booking-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e5e5}.reschedule-booking-title{margin:0;font-size:16px;font-weight:700;color:#111}.reschedule-booking-close{border:none;background:transparent;font-size:22px;line-height:1;cursor:pointer;color:#333}.reschedule-booking-body{padding:16px 20px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.reschedule-booking-empty{margin:0;font-size:12px;color:#666}.reschedule-calendar{border:1px solid #e5e5e5;border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:12px}.reschedule-calendar-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.reschedule-calendar-header h5{margin:0;font-size:13px;font-weight:700;color:#111;text-transform:capitalize}.reschedule-calendar-header button{border:none;background:transparent;cursor:pointer;font-size:18px;color:#21b3e7;padding:4px 8px;border-radius:6px}.reschedule-calendar-header button:hover{background-color:rgba(33,179,231,.1)}.reschedule-calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.reschedule-day-label{font-size:10px;font-weight:700;color:#666;text-align:center}.reschedule-day-empty{min-height:32px}.reschedule-day{min-height:32px;border:1px solid #e0e0e0;background-color:#fff;border-radius:6px;font-size:12px;font-weight:600;color:#333;cursor:pointer;transition:all .2s ease}.reschedule-day.selected{background-color:#21b3e7;color:#fff;border-color:#21b3e7}.reschedule-day:disabled{cursor:not-allowed;color:#c2c2c2;background-color:#f5f5f5}.reschedule-times{display:flex;flex-direction:column;gap:8px}.reschedule-times h5{margin:0;font-size:12px;font-weight:600;color:#111}.reschedule-times-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.reschedule-time{border:1px solid #e0e0e0;border-radius:8px;padding:8px 12px;background-color:#fff;font-size:12px;font-weight:600;color:#333;cursor:pointer;text-align:center;white-space:nowrap}.reschedule-time.selected{background-color:#21b3e7;color:#fff;border-color:#21b3e7}.reschedule-empty,.reschedule-loading{margin:0;font-size:12px;color:#666}.reschedule-booking-actions{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid #e5e5e5}.reschedule-action{min-width:140px;height:40px;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s ease}.reschedule-action.cancel{background-color:#fff;border:1px solid #d9d9d9;color:#333}.reschedule-action.cancel:hover{border-color:#bdbdbd}.reschedule-action.confirm{background-color:#21b3e7;border:none;color:#fff}.reschedule-action.confirm:disabled{background-color:#d9d9d9;cursor:not-allowed;color:#999}@media (max-width:600px){.reschedule-booking-actions{flex-direction:column;align-items:stretch}.reschedule-action{width:100%}}