#root{height:100%;width:100%;display:flex;flex-direction:column}body{margin:0;padding:0;height:100%;width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.fc-direction-ltr .fc-timegrid-col-events{margin:2px 10% 0 2px}.fc-event-time{white-space:normal;float:left}.fc-event-title{margin-top:0;white-space:normal}.fc-v-event .fc-event-main-frame{display:block}.fc-v-event .fc-event-title-container{max-width:45%;float:left}.fc-timegrid-event .fc-event-time{white-space:normal}.custom-event-container{height:100%;width:100%;overflow:hidden;padding:2px;box-sizing:border-box;text-align:center;font-size:.75rem}.custom-event-title{font-weight:700}.custom-event-time{margin-bottom:10px}.calendar-day-header{padding:.75rem;font-size:.875rem;font-weight:600;color:#4b5563;text-align:center}.shift-table-title{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:1.5rem}.table-scroll-container{overflow-x:auto;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;border-radius:.5rem}.shift-table{min-width:100%;background-color:#fff;border:1px solid #E5E7EB;border-collapse:collapse}.shift-table-head{background-color:#f3f4f6}.th-day,.th-worker{padding:.75rem;font-size:.875rem;font-weight:600;color:#4b5563;border-bottom:1px solid #E5E7EB}.th-day{text-align:left;width:8rem;position:sticky;left:0;z-index:10;background-color:#f3f4f6}.th-worker{text-align:center;border-left:1px solid #E5E7EB}.tr-body{border-bottom:1px solid #E5E7EB;transition:background-color .2s ease-in-out}.tr-body:hover .td-day{background-color:#f9fafb}.td-day,.td-worker{padding:.1rem;border-bottom:1px solid #E5E7EB}.td-day{font-size:.875rem;font-weight:500;color:#374151;white-space:nowrap;position:sticky;left:0;z-index:10;background-color:#fff;transition:background-color .2s ease-in-out}.td-worker{border-left:1px solid #E5E7EB;text-align:center;vertical-align:top}.cell-container{display:flex;flex-direction:column;gap:.25rem}.turno-card{padding:.5rem;border-radius:.375rem;color:#fff;font-size:.75rem;cursor:pointer;transition:box-shadow .2s ease-in-out}.turno-card:hover{box-shadow:0 4px 8px #0003}.turno-time{font-weight:700}.turno-duration{color:#e5e7eb}.empty-cell{color:#d1d5db}.shift-table-container{background-color:#f9fafb;min-height:100%}.turnos-container{background-color:#f9fafb;min-height:100%;margin:1rem}.main-header{display:flex;justify-content:space-between;align-items:center;padding:0 1rem;margin-bottom:1.5rem;background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.header-title{font-size:1.5rem;font-weight:600;color:#1f2937;text-align:center;flex-grow:1}.header-nav,.header-view-toggle,.header-period-toggle{display:flex;gap:.5rem;align-items:center}.header-nav button,.header-view-toggle button{padding:.5rem 1rem;border:1px solid #D1D5DB;border-radius:.375rem;background-color:#fff;cursor:pointer;font-weight:500;transition:background-color .2s,color .2s,border-color .2s}.header-nav button:hover,.header-view-toggle button:hover{background-color:#f9fafb;border-color:#9ca3af}.header-view-toggle button.active{background-color:#2a9d8f;color:#fff;border-color:#2a9d8f}.turnos-page-container{background-color:#fff;padding:24px;border-radius:8px}.main-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding-bottom:1rem;margin-bottom:1.5rem;border-bottom:1px solid #f0f0f0}.header-title{font-size:1.5rem;font-weight:600;color:#1f2937;text-align:center;flex-grow:1;margin:.5rem 1rem}.header-controls{display:flex;gap:.5rem;align-items:center}.main-content-area{display:flex;gap:1.5rem;align-items:flex-start}.view-container{flex:3;min-width:0}.cost-panel-container{flex:1;position:sticky;top:1.5rem}.loading-placeholder{text-align:center;padding:4rem;font-size:1.25rem;color:#6b7280}.cost-panel-layout{display:flex;gap:24px}.cost-details-table-container{flex:3;overflow-x:auto}.cost-grand-total{flex:1;display:flex;align-items:center;justify-content:center}.cost-details-table{width:100%;border-collapse:collapse;font-size:.875rem}.cost-details-table th,.cost-details-table td{padding:8px 12px;text-align:right;border-bottom:1px solid #f0f0f0;white-space:nowrap}.cost-details-table thead th{background-color:#fafafa;font-weight:600}.cost-details-table .total-row td{background-color:#f5f5f5;font-size:.9rem}@media (max-width: 1024px){.main-content-area{flex-direction:column}.cost-panel-container{width:100%;position:static}}
