.custom-calendar{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.calendar-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;margin-bottom:20px;display:flex}.calendar-controls{gap:10px;display:flex}.calendar-date-display{text-align:center;flex:1;min-width:200px}.ws-status-dot{vertical-align:super;color:#2ecc71;margin-left:6px;font-size:10px;transition:color .3s}.calendar-date-display h2{color:#333;margin:0;font-size:24px;font-weight:600}.calendar-view-toggle{gap:10px;display:flex}.calendar-right-controls{align-items:center;gap:16px;display:flex}.zoom-controls{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;align-items:center;gap:2px;padding:3px;display:flex}.zoom-btn{color:#fff;cursor:pointer;background:#3b7ddd;border:none;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;font-weight:600;line-height:1;transition:background .15s,transform .1s;display:flex}.zoom-btn:hover:not(:disabled){background:#326abc;transform:translateY(-1px)}.zoom-btn:active:not(:disabled){transform:translateY(0)}.zoom-btn:disabled{cursor:not-allowed;background:#adb5bd}.zoom-reset{font-size:13px}.zoom-indicator{color:#555;text-align:center;min-width:36px;padding:0 4px;font-size:11px;font-weight:600}.btn{cursor:pointer;border:1px solid #ccc;border-radius:4px;padding:8px 16px;font-size:14px;transition:all .3s}.btn-primary{color:#fff;background-color:#06c;border-color:#06c}.btn-primary:hover{background-color:#0052a3;border-color:#0052a3}.btn-secondary{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-secondary:hover{background-color:#5a6268;border-color:#5a6268}.btn-outline-primary{color:#06c;background-color:#fff;border-color:#06c}.btn-outline-primary:hover{background-color:#f0f5ff}.btn-sm{padding:6px 12px;font-size:12px}.btn-danger{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-danger:hover{background-color:#c82333}.calendar-loading{justify-content:center;align-items:center;padding:40px;display:flex}.spinner-border{border:3px solid #f3f3f3;border-top-color:#06c;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.calendar-week-view{overflow-x:auto}.week-layout{border:1px solid #dee2e6;border-radius:6px;display:flex;overflow:hidden}.wt-time-column{z-index:2;background:#f8f9fa;border-right:2px solid #dee2e6;flex-shrink:0;width:64px}.wt-time-column-header{box-sizing:border-box;border-bottom:2px solid #dee2e6}.wt-time-slot{color:#888;white-space:nowrap;border-bottom:1px solid #eee;justify-content:center;align-items:flex-start;height:56px;padding-top:4px;font-size:11px;font-weight:500;display:flex}.wt-time-slot:last-child{border-bottom:none}.week-table-wrapper{flex:1;min-width:0;overflow-x:auto}.week-table{border-collapse:collapse;width:100%}.week-table thead{z-index:10;background:#f8f9fa;position:sticky;top:0}.wt-day-header{text-align:center;background:#f8f9fa;border-bottom:1px solid #dee2e6;border-right:2px solid #dee2e6;padding:6px 4px 4px;font-weight:600}.wt-day-header.wt-today{color:#06c;background:#e8f0fe}.wt-day-name{color:#666;text-transform:uppercase;letter-spacing:.5px;font-size:11px;display:block}.wt-day-date{margin-top:2px;font-size:14px;font-weight:700;display:block}.wt-today .wt-day-date{color:#06c}.wt-res-header{text-align:center;color:#555;white-space:nowrap;text-overflow:ellipsis;background:#fafafa;border-bottom:2px solid #dee2e6;border-right:1px solid #e0e3e8;min-width:90px;padding:5px 4px;font-size:11px;font-weight:500;overflow:hidden}.wt-cell{cursor:pointer;vertical-align:top;border-bottom:1px solid #eee;border-right:1px solid #e0e3e8;height:56px;padding:2px;transition:background-color .15s;position:relative}.wt-cell:hover{filter:brightness(.96)}.week-table tr:last-child .wt-cell{border-bottom:none}.wt-day-sep{border-right:2px solid #b0b8c4!important}.now-indicator{pointer-events:none;z-index:5;background:#e53935;height:2px;position:absolute}.now-indicator__dot{background:#e53935;border-radius:50%;width:10px;height:10px;position:absolute;top:-4px;left:-5px}.week-header,.week-grid{display:none}.time-column{background:#f8f9fa;border-right:2px solid #dee2e6}.time-slot{text-align:center;border-bottom:1px solid #dee2e6;height:60px;padding:4px 0}.time-label{color:#666;padding:0 4px;font-size:11px;font-weight:500}.hour-cell{cursor:pointer;border-bottom:1px solid #dee2e6;height:60px;padding:4px 2px;transition:background-color .2s;position:relative;overflow:hidden}.hour-cell:hover{background-color:#f0f5ff}.hour-events{flex-direction:column;gap:2px;height:100%;display:flex}.resource-events{flex-direction:column;gap:2px;display:flex}.calendar-day-view{width:100%}.day-header{border-bottom:2px solid #dee2e6;padding:20px 0}.day-title{color:#333;margin:0;font-size:24px;font-weight:600}.day-grid{width:100%;margin-top:20px;overflow-x:auto}.resources-header{z-index:10;background:#f8f9fa;border:1px solid #dee2e6;border-bottom-width:2px;grid-template-columns:80px repeat(auto-fit,minmax(150px,1fr));gap:0;width:100%;display:grid;position:sticky;top:0}.resource-header{text-align:center;border-right:1px solid #dee2e6;padding:12px 8px;font-weight:600}.resource-header:last-child{border-right:none}.resource-name{color:#333;margin-bottom:4px;font-size:13px}.resource-number{color:#666;font-size:11px}.day-schedule{background:#fff;border:1px solid #dee2e6;grid-template-columns:80px repeat(auto-fit,minmax(150px,1fr));gap:0;width:100%;display:grid}.resource-column{border-right:2px solid #dee2e6;flex-direction:column;display:flex}.resource-column:last-child{border-right:none}.event-card{color:#fff;cursor:pointer;border-radius:4px;margin-bottom:2px;padding:4px 6px;font-size:11px;transition:all .2s;overflow:hidden;box-shadow:0 2px 4px #00000026}.event-card:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000040}.event-card-inner{align-items:flex-start;gap:5px;display:flex}.event-avatar{flex-shrink:0}.event-avatar-img{object-fit:cover;border:1px solid #ffffff59;border-radius:50%;width:24px;height:24px}.event-avatar-default{color:#fff;background:#fff3;border:1px solid #ffffff59;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:9px;font-weight:700;line-height:1;display:flex}.event-card.compact .event-avatar-img,.event-card.compact .event-avatar-default{width:20px;height:20px;font-size:8px}.event-info{flex:1;min-width:0;overflow:hidden}.event-top-row{justify-content:space-between;align-items:baseline;gap:4px;margin-bottom:1px;display:flex}.event-time{color:#ffffffe6;white-space:nowrap;font-size:10px;font-weight:500}.event-card-number{color:#ffffffbf;white-space:nowrap;font-size:9px}.event-patient{color:#fff;white-space:nowrap;text-overflow:ellipsis;margin-bottom:1px;font-size:11px;font-weight:500;line-height:1.2;overflow:hidden}.event-doctor{color:#fffc;white-space:nowrap;text-overflow:ellipsis;margin-bottom:1px;font-size:9px;line-height:1.2;overflow:hidden}.event-comment{color:#ffffffb3;white-space:nowrap;text-overflow:ellipsis;font-size:9px;line-height:1.2;overflow:hidden}.modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.modal-header{border-bottom:1px solid #dee2e6;justify-content:space-between;align-items:center;padding:20px;display:flex}.modal-header h3{margin:0;font-size:20px;font-weight:600}.close-btn{cursor:pointer;color:#666;background:0 0;border:none;padding:0;font-size:28px;line-height:1}.close-btn:hover{color:#333}.event-form{padding:20px}.form-group{margin-bottom:16px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group label{color:#333;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-control{border:1px solid #ccc;border-radius:4px;width:100%;padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.form-control:focus{border-color:#06c;outline:none;box-shadow:0 0 0 3px #0066cc1a}.form-control:required:valid{border-color:#28a745}.form-control:required:invalid{border-color:#dc3545}.modal-footer{border-top:1px solid #dee2e6;justify-content:flex-end;gap:10px;padding:20px;display:flex}.alert{border-radius:4px;margin-bottom:16px;padding:12px 16px;font-size:14px}.alert-danger{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb}.alert-info{color:#0c5460;background-color:#d1ecf1;border:1px solid #bee5eb}.alert-success{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb}.search-input-wrapper{position:relative}.search-list{z-index:1001;background:#fff;border:1px solid #ccc;border-top:none;border-radius:0 0 4px 4px;max-height:250px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 8px #0000001a}.search-item{cursor:pointer;border-bottom:1px solid #f0f0f0;padding:12px 16px;transition:background-color .2s}.search-item:hover{background-color:#f0f5ff}.search-item:last-child{border-bottom:none}.search-item-name{color:#333;margin-bottom:4px;font-size:14px;font-weight:500}.search-item-info{color:#666;font-size:12px}.text-muted{color:#6c757d}@media (max-width:768px){.calendar-header{flex-direction:column;align-items:stretch}.calendar-controls{justify-content:center}.form-row{grid-template-columns:1fr}.week-header,.week-grid{grid-template-columns:60px repeat(3,1fr)!important}.day-column-header:nth-child(n+5),.day-column:nth-child(n+5){display:none}.resources-header,.day-schedule{grid-template-columns:60px repeat(2,1fr)!important}.modal-content{width:95%}}@media (max-width:480px){.custom-calendar{padding:10px}.calendar-header{gap:10px}.btn{padding:6px 10px;font-size:12px}.week-header,.week-grid{grid-template-columns:50px 1fr!important}.day-column-header:nth-child(n+3),.day-column:nth-child(n+3){display:none}.time-slot,.hour-cell{height:50px}.time-label{font-size:10px}.event-card{padding:4px;font-size:10px}.modal-content{border-radius:0;max-width:100%}}
