:root{color-scheme:dark;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--bg-gradient: radial-gradient(circle at 20% -10%, rgba(62, 113, 255, .28), transparent 55%), radial-gradient(circle at 85% 0%, rgba(27, 45, 120, .52), transparent 60%), #050b1d;--surface: rgba(12, 24, 52, .82);--surface-strong: rgba(16, 32, 68, .95);--surface-soft: rgba(255, 255, 255, .04);--border: rgba(92, 132, 255, .16);--glow: rgba(72, 119, 255, .24);--accent: #5a8bff;--accent-strong: #2563eb;--accent-muted: rgba(90, 139, 255, .18);--success: #30e79d;--danger: #ff6774;--warning: #facc15;--text-primary: #f5f7ff;--text-secondary: rgba(223, 229, 255, .76);--timeline-cell-width: 16px}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg-gradient);color:var(--text-primary)}body:before{content:"";position:fixed;inset:0;pointer-events:none;background:linear-gradient(135deg,rgba(255,255,255,.05),transparent 65%);opacity:.35;z-index:-1}.app-shell{min-height:100vh;width:100%;padding:48px clamp(24px,4vw,72px) 64px;display:flex;flex-direction:column;gap:32px}.app-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px}.brand{display:flex;flex-direction:column;gap:6px}.brand-title{font-size:clamp(28px,4vw,36px);font-weight:600;letter-spacing:1px}.brand-subtitle{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:2px}.header-actions{display:flex;gap:12px;align-items:center}.button{border:none;border-radius:14px;padding:12px 22px;font-weight:600;font-size:14px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-strong) 100%);color:var(--text-primary);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;box-shadow:0 15px 35px #2952d659}.button.secondary{background:transparent;border:1px solid var(--border);color:var(--text-secondary);box-shadow:none}.button:disabled{cursor:not-allowed;filter:saturate(.4);box-shadow:none}.button:not(:disabled):hover{transform:translateY(-3px);box-shadow:0 18px 40px #2952d673}.card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:24px;box-shadow:0 24px 60px #080e2073;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.card:after{content:"";position:absolute;inset:0;border-radius:inherit;border:1px solid rgba(255,255,255,.06);pointer-events:none}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.card-title{font-size:14px;letter-spacing:1px;text-transform:uppercase;color:var(--text-secondary)}.card-value{font-size:clamp(26px,3vw,34px);font-weight:600;letter-spacing:.4px}.card-value.success{color:var(--success)}.card-value.danger{color:var(--danger)}.card-value.warning{color:var(--warning)}.timeline-card{padding:0;overflow:hidden}.timeline-card .card-header{padding:24px 24px 16px;margin:0}.timeline-container{overflow-x:auto}.timeline-table{width:max-content;border-collapse:separate;border-spacing:0;font-size:11px;color:var(--text-secondary);background:var(--surface-strong)}.timeline-table thead th{font-weight:600;padding:10px 0;background:#ffffff0d;text-transform:uppercase;letter-spacing:.8px}.timeline-table thead tr:nth-child(2) th,.timeline-table thead tr:nth-child(3) th{padding:6px 0}.timeline-table thead th.weekend{background:#6280e124;color:var(--text-secondary)}.timeline-table thead th.holiday{background:#ffb6572e;color:#ffe7c4}.timeline-table thead th.weekend.holiday{background:linear-gradient(135deg,#ffb65733,#6280e11f);color:#fceedd}.timeline-table thead th.today{background:linear-gradient(180deg,#5a8bff80,#294bb499);color:var(--text-primary);box-shadow:inset 0 -2px #ffffff40}.timeline-table thead th.weekend.today{background:linear-gradient(180deg,#6280e166,#294bb4a6)}.timeline-table thead th.holiday.today{background:linear-gradient(180deg,#ffb65752,#294bb4ad)}.timeline-weekday{font-size:10px;letter-spacing:1.2px}.timeline-table th:not(.timeline-worker),.timeline-table td:not(.timeline-worker){border:1px solid rgba(255,255,255,.07);text-align:center;min-width:var(--timeline-cell-width);width:var(--timeline-cell-width);max-width:var(--timeline-cell-width)}.timeline-table th.timeline-worker,.timeline-table td.timeline-worker{border:1px solid rgba(255,255,255,.07)}.timeline-table tr:first-child th:not(.timeline-worker){padding-top:12px;padding-bottom:12px}.timeline-table th.holiday,.timeline-table td.holiday{background:#ffb6571a;color:#ffdcb3}.timeline-table th.today,.timeline-table td.today{color:var(--text-primary)}.timeline-table th.today{position:relative}.timeline-table thead tr:nth-child(3) th.today:after{content:"";position:absolute;left:50%;bottom:-8px;transform:translate(-50%);width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px #5a8bffcc}.timeline-table tbody td{height:22px}.timeline-worker{position:sticky;left:0;z-index:2;padding:0 12px;background:#050d22eb;color:var(--text-primary);font-weight:600;text-align:left;min-width:160px}.shift-cell{position:relative;overflow:hidden;background:#ffffff05}.shift-cell.empty{background:#ffffff04}.shift-cell.weekend-column:before{content:"";position:absolute;inset:0;background:#5e7ad21f;mix-blend-mode:screen;pointer-events:none}.shift-cell.holiday-column:before{content:"";position:absolute;inset:0;background:#ffb65729;mix-blend-mode:screen;pointer-events:none}.shift-cell.today-column:before{content:"";position:absolute;inset:0;background:#5a8bff4d;mix-blend-mode:screen;pointer-events:none}.shift-cell.subida{background:linear-gradient(140deg,#30e79d29,#30e79d59)}.shift-cell.bajada{background:linear-gradient(140deg,#ff67742e,#ff677459)}.shift-cell.subida.weekend-column:before{background:#5e7ad22e}.shift-cell.bajada.weekend-column:before{background:#5e7ad229}.shift-cell.subida.holiday-column:before{background:#ffd49233}.shift-cell.bajada.holiday-column:before{background:#ffc18533}.shift-cell.subida.today-column:before,.shift-cell.bajada.today-column:before,.shift-cell.empty.today-column:before{background:#5a8bff57}.layout-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1.1fr);gap:24px;align-items:start}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-top:12px}.input-group{display:flex;flex-direction:column;gap:8px}.label{font-size:12px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-secondary)}.input,.select{border-radius:14px;border:1px solid rgba(255,255,255,.05);padding:12px 14px;background:#0a142cdb;color:var(--text-primary);font-size:14px;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.input::placeholder,.select::placeholder{color:#dfe5ff59}.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4b74ff33;background:#0c1c42f2}.divider{height:1px;width:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);margin:26px 0}.form-actions{display:flex;justify-content:flex-end;gap:12px}.table-scroll{max-height:420px;overflow:auto;border-radius:16px;border:1px solid rgba(255,255,255,.07);background:#0a152ea6}.worker-table{width:100%;border-collapse:collapse;font-size:13px}.worker-table thead{background:#ffffff0a}.worker-table th,.worker-table td{padding:14px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,.06)}.worker-table th{font-size:12px;letter-spacing:1.4px;text-transform:uppercase;color:var(--text-secondary)}.worker-table tbody tr:hover{background:#ffffff0d}.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;text-transform:capitalize}.badge.subida{background:#30e79d1f;color:var(--success)}.badge.bajada{background:#ff67741f;color:var(--danger)}.worker-accordion{display:flex;flex-direction:column;gap:14px}.worker-panel{border-radius:18px;border:1px solid rgba(255,255,255,.06);background:#0a152e9e;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease;overflow:hidden}.worker-panel.open{border-color:#5a8bff59;background:#0e1e46bd;box-shadow:0 18px 42px #060e2075}.worker-panel-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;background:transparent;border:none;color:inherit;cursor:pointer;text-align:left;font:inherit}.worker-panel-header:hover{background:#ffffff0a}.worker-panel-header:focus-visible{outline:2px solid rgba(90,139,255,.6);outline-offset:2px}.worker-header-info{display:flex;flex-direction:column;gap:12px}.worker-name{font-size:16px;font-weight:600;letter-spacing:.4px}.worker-summary{display:flex;flex-wrap:wrap;gap:12px}.summary-block{display:grid;gap:4px;min-width:130px;padding:8px 12px;border-radius:12px;background:#ffffff0d}.summary-block .summary-title{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-secondary)}.summary-block .summary-count{font-size:18px;font-weight:600;line-height:1;color:var(--text-primary)}.summary-block.subida .summary-count{color:var(--success)}.summary-block.bajada .summary-count{color:var(--danger)}.summary-block.neutral{background:#ffffff08}.summary-block.neutral .summary-count{color:var(--text-secondary)}.summary-block .summary-average{font-size:12px;color:var(--text-secondary)}.worker-next{font-size:12px;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:6px;align-items:center}.next-type{padding:2px 8px;border-radius:999px;font-size:11px;text-transform:capitalize;font-weight:600;background:#ffffff14;color:var(--text-primary)}.next-type.subida{background:#30e79d2e;color:var(--success)}.next-type.bajada{background:#ff67742e;color:var(--danger)}.next-date{font-weight:500;color:var(--text-primary)}.panel-chevron{display:grid;place-items:center;width:34px;height:34px;border-radius:999px;background:#ffffff0f;color:var(--text-secondary);font-size:18px;font-weight:600}.worker-panel-body{padding:0 22px 20px;display:flex;flex-direction:column;gap:12px;border-top:1px solid rgba(255,255,255,.05)}.shift-entry{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.05)}.shift-entry:last-child{border-bottom:none}.shift-dates{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-secondary)}.shift-date-range{color:var(--text-primary);font-weight:500}.shift-duration{font-size:12px;color:var(--text-secondary)}.empty-worker-shifts{padding:16px 0;text-align:center;font-size:13px;color:var(--text-secondary)}.empty-state{color:var(--text-secondary);font-size:14px;text-align:center;padding:20px 0}.table-scroll::-webkit-scrollbar,.timeline-container::-webkit-scrollbar{height:8px;width:8px}.table-scroll::-webkit-scrollbar-thumb,.timeline-container::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:6px}.table-scroll::-webkit-scrollbar-track,.timeline-container::-webkit-scrollbar-track{background:transparent}@media (max-width: 1024px){.app-shell{padding:40px clamp(18px,5vw,52px) 56px}.layout-grid{grid-template-columns:1fr}}@media (max-width: 720px){.app-shell{padding:32px 16px 44px;gap:28px}.app-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.header-actions .button{flex:1;justify-content:center}.card{padding:20px}.timeline-card .card-header{padding:20px 20px 12px}}
