:root{--color-bg-base:#0f172a;--color-bg-glass:#1e293bb3;--color-bg-glass-hover:#1e293be6;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-accent:#10b981;--color-danger:#ef4444;--color-warning:#f59e0b;--color-text-main:#f8fafc;--color-text-muted:#94a3b8;--color-border:#ffffff1a;--color-surface:#0f172a66;--font-main:"Inter", system-ui, -apple-system, sans-serif;--shadow-glass:0 8px 32px 0 #0000005e;--border-radius-xl:16px;--border-radius-lg:12px;--border-radius-md:8px;--border-radius-sm:4px;--transition-fast:.2s ease;scrollbar-width:thin;scrollbar-color:var(--color-primary) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);background:var(--color-bg-base);color:var(--color-text-main);background-image:radial-gradient(at 0 0,#3b82f626 0,#0000 50%),radial-gradient(at 100% 100%,#10b9811a 0,#0000 50%);background-attachment:fixed;justify-content:center;align-items:flex-start;min-height:100vh;padding:2rem;display:flex}#root{width:100%;max-width:1200px}h1,h2,h3{letter-spacing:-.02em;font-weight:600}h1{background:linear-gradient(135deg,#fff 0%,#94a3b8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:2.5rem}p{color:var(--color-text-muted);line-height:1.6}.glass-panel{-webkit-backdrop-filter:blur(16px);border-radius:var(--border-radius-lg);background:#ffffff0d;border:1px solid #ffffff1a;padding:1.5rem;transition:transform .3s,box-shadow .3s;box-shadow:0 10px 30px -10px #00000080}.glass-panel:hover{box-shadow:0 15px 35px -5px #0009}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}label{color:var(--color-text-main);font-size:.9rem;font-weight:500}input[type=number],input[type=date],select{border:1px solid var(--color-border);border-radius:var(--border-radius-md);width:100%;color:var(--color-text-main);font-family:var(--font-main);transition:all var(--transition-fast);background:#0f172a99;outline:none;padding:.75rem 1rem;font-size:1rem}input[type=number]:focus,input[type=date]:focus,select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f633}.btn{background:var(--color-surface);color:var(--color-text-main);border:1px solid var(--color-border);border-radius:var(--border-radius-md);cursor:pointer;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.95rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn:hover:not(:disabled){background:#ffffff1a;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:#3b82f6;border-color:#3b82f6;box-shadow:0 0 15px #3b82f666}.delete-btn{color:var(--color-danger);border-radius:var(--border-radius-sm);cursor:pointer;background:0 0;border:1px solid #ef44444d;padding:.4rem .8rem;font-size:.85rem;transition:all .2s}.delete-btn:hover{border-color:var(--color-danger);background:#ef44441a;transform:translateY(-1px)}.grid{gap:2rem;display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}@media (width<=768px){body{padding:.5rem}main{border-radius:var(--border-radius-md)!important}.grid-cols-2{grid-template-columns:1fr!important;gap:1rem!important}.glass-panel{padding:1rem!important}header{text-align:center;flex-direction:column!important;gap:1rem!important}header>div{width:100%!important}.glass-panel>div:first-child{flex-direction:column;align-items:stretch!important;gap:.75rem!important}form{display:flex;flex-wrap:wrap!important;gap:.5rem!important;width:100%!important}form input[type=text],form input[type=number],form select{box-sizing:border-box;flex:100%!important;width:100%!important;max-width:100%!important}form button[type=submit]{flex:100%!important;width:100%!important}h1{font-size:1.5rem!important}h2,h3{font-size:1.2rem!important}.calendar-header{flex-wrap:wrap;justify-content:center;gap:.5rem}.calendar-header h3{text-align:center;order:-1;width:100%;margin-bottom:.25rem!important}.calendar-grid{gap:.25rem}.calendar-day{border-radius:var(--border-radius-sm);font-size:.8rem}div[style*="background: rgba(15, 23, 42, 0.4)"][style*="justify-content: space-between"]{flex-direction:column!important;align-items:flex-start!important;gap:.75rem!important}div[style*="background: rgba(15, 23, 42, 0.4)"][style*="justify-content: space-between"]>div:last-child{border-top:1px solid #ffffff0d;width:100%;padding-top:.5rem;justify-content:space-between!important}div[style*="display: flex"][style*="flex-wrap: wrap"]>button.btn,div[style*="display: flex"][style*="gap: 1rem"]>button.btn{flex:100%!important;max-width:100%!important;margin:0!important}}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:.5rem;display:grid}.calendar-day-header{text-align:center;color:var(--color-text-muted);padding-bottom:.5rem;font-size:.85rem;font-weight:600}.calendar-day{aspect-ratio:1;border:1px solid var(--color-border);border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;background:#0f172a99;justify-content:center;align-items:center;font-weight:500;display:flex}.calendar-day:hover{border-color:var(--color-text-muted);transform:scale(1.05)}.calendar-day.empty{cursor:default;background:0 0;border:none}.calendar-day.empty:hover{transform:none}.calendar-day.state-normal{background:var(--color-primary);border-color:var(--color-primary-hover);color:#fff}.calendar-day.state-holiday-normal{background:var(--color-warning);color:#fff;border-color:#d97706}.calendar-day.state-holiday-irrenunciable{background:var(--color-danger);color:#fff;border-color:#b91c1c}.calendar-day.state-occupied-other{color:var(--color-text-muted);cursor:not-allowed;background:#ffffff0d repeating-linear-gradient(45deg,#0000,#0000 5px,#ffffff0d 5px 10px);border-color:#ffffff1a}input,select{border:1px solid var(--color-border);color:var(--color-text-main);border-radius:var(--border-radius-md);font-family:var(--font-main);transition:all var(--transition-fast);background:#0003;outline:none;padding:.6rem}input:focus,select:focus{border-color:var(--color-primary);background:#0000004d;box-shadow:0 0 0 2px #6366f133}select option{color:#f8fafc;background:#1e293b}.worker-tab{border:1px solid var(--color-border);border-radius:var(--border-radius-md);transition:all var(--transition-fast);background:#0f172a66;align-items:center;display:flex;overflow:hidden}.worker-tab.active{border-color:var(--color-primary);background:#3b82f633;box-shadow:0 0 10px #3b82f633}.worker-tab:hover:not(.active){background:#0f172acc}.partial-indicator{font-size:.75rem;line-height:1;position:absolute;bottom:2px;right:2px}.calendar-day{position:relative}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.modal-content{box-shadow:0 20px 50px #00000080}
