@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--bg-gradient:linear-gradient(135deg, #090d16 0%, #05070c 100%);--panel-bg:#111827bf;--panel-border:#ffffff14;--panel-hover:#ffffff05;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-primary:#8b5cf6;--accent-secondary:#ec4899;--accent-gradient:linear-gradient(135deg, #8b5cf6 0%, #d946ef 100%);--accent-gradient-hover:linear-gradient(135deg, #7c3aed 0%, #c084fc 100%);--success:#10b981;--success-glow:#10b98126;--warning:#f59e0b;--warning-glow:#f59e0b26;--danger:#ef4444;--danger-glow:#ef444426;--info:#0ea5e9;--info-glow:#0ea5e926;--glass-shadow:0 8px 32px 0 #0000005e;--card-shadow:0 4px 20px 0 #00000040;--border-radius-sm:8px;--border-radius-md:14px;--border-radius-lg:24px;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce:all .5s cubic-bezier(.175, .885, .32, 1.275)}[data-theme=light]{--bg-gradient:linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);--panel-bg:#fffc;--panel-border:#0f172a14;--panel-hover:#0f172a05;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--accent-primary:#6366f1;--accent-secondary:#a855f7;--accent-gradient:linear-gradient(135deg, #6366f1 0%, #a855f7 100%);--success-glow:#10b9811a;--warning-glow:#f59e0b1a;--danger-glow:#ef44441a;--info-glow:#0ea5e91a;--glass-shadow:0 8px 32px 0 #0f172a0f;--card-shadow:0 4px 20px 0 #0f172a0a}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg-gradient);color:var(--text-primary);min-height:100vh;line-height:1.5;transition:background .5s,color .3s;overflow-x:hidden}.app-container{flex-direction:column;gap:2rem;max-width:1400px;min-height:100vh;margin:0 auto;padding:2rem 1.5rem;display:flex}.app-header{background:var(--panel-bg);border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(16px);border-radius:var(--border-radius-lg);box-shadow:var(--glass-shadow);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.5rem 2rem;animation:.6s cubic-bezier(.16,1,.3,1) slideDown;display:flex}.brand-section{align-items:center;gap:1rem;display:flex}.brand-logo{background:var(--accent-gradient);border-radius:var(--border-radius-md);color:#fff;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;font-weight:800;display:flex;box-shadow:0 0 20px #8b5cf666}.brand-info h1{background:var(--accent-gradient);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.6rem;font-weight:800}.brand-info p{color:var(--text-secondary);font-size:.85rem}.header-controls{align-items:center;gap:1rem;display:flex}.nav-tabs{border-radius:var(--border-radius-md);border:1px solid var(--panel-border);background:#0003;padding:4px;display:flex}.nav-tab{color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.95rem;font-weight:500;display:flex}.nav-tab:hover{color:var(--text-primary);background:#ffffff0d}.nav-tab.active{color:#fff;background:var(--accent-gradient);box-shadow:0 4px 12px #8b5cf640}.glass-panel{background:var(--panel-bg);border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(16px);border-radius:var(--border-radius-lg);box-shadow:var(--glass-shadow);padding:2rem;animation:.8s cubic-bezier(.16,1,.3,1) fadeIn;overflow:hidden}.panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.panel-title{color:var(--text-primary);align-items:center;gap:.75rem;font-size:1.4rem;font-weight:700;display:flex}.panel-title i{color:var(--accent-primary)}.btn{border-radius:var(--border-radius-md);font-family:var(--font-sans);cursor:pointer;transition:var(--transition-bounce);border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 15px #8b5cf64d}.btn-primary:hover{background:var(--accent-gradient-hover);transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf673}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:var(--text-primary);border-color:var(--panel-border);background:#ffffff0d}.btn-secondary:hover{background:#ffffff1a;transform:translateY(-1px)}.btn-danger{background:var(--danger-glow);color:var(--danger);border-color:#ef444433}.btn-danger:hover{background:var(--danger);color:#fff;transform:translateY(-1px)}.btn-icon{border-radius:50%;width:40px;height:40px;padding:0}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none!important;transform:none!important}.grid-2{grid-template-columns:1fr;gap:2rem;display:grid}@media (width>=900px){.grid-2{grid-template-columns:1.3fr .7fr}}.calendar-wrapper{flex-direction:column;gap:1.5rem;display:flex}.calendar-nav{border-radius:var(--border-radius-md);border:1px solid var(--panel-border);background:#00000026;justify-content:space-between;align-items:center;padding:1rem;display:flex}.calendar-month-year{font-size:1.2rem;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.calendar-weekday{text-align:center;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;padding:.5rem 0;font-size:.85rem;font-weight:600}.calendar-day{aspect-ratio:1/1.1;border:1px solid var(--panel-border);border-radius:var(--border-radius-sm);transition:var(--transition-smooth);background:#ffffff05;flex-direction:column;justify-content:space-between;padding:8px;display:flex;position:relative}.calendar-day:hover:not(.empty-day){box-shadow:var(--card-shadow);background:#ffffff0d;border-color:#ffffff26;transform:translateY(-2px)}.calendar-day.empty-day{pointer-events:none;background:0 0;border-color:#0000}.day-number{color:var(--text-secondary);font-size:.95rem;font-weight:700}.calendar-day.is-today .day-number{color:var(--accent-primary);position:relative}.calendar-day.is-today .day-number:after{content:"";background:var(--accent-primary);border-radius:2px;width:12px;height:2px;position:absolute;bottom:-4px;left:0}.calendar-day.is-weekend{background:#8b5cf605}.calendar-day.is-weekend:hover{background:#8b5cf60d}.day-shifts{flex-direction:column;gap:4px;margin-top:6px;display:flex}.shift-tag{text-align:center;white-space:nowrap;text-overflow:ellipsis;border-radius:6px;justify-content:center;align-items:center;gap:4px;padding:4px 6px;font-size:.75rem;font-weight:600;display:flex;overflow:hidden}.shift-tag-1{color:#c084fc;background:#8b5cf626;border:1px solid #8b5cf640}.shift-tag-2{color:#f472b6;background:#ec489926;border:1px solid #ec489940}.shift-tag-draft{color:#94a3b8;background:#64748b26;border:1px dashed #64748b40}.fairness-card{border:1px solid var(--panel-border);border-radius:var(--border-radius-md);background:#ffffff05;flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex}.fairness-card h3{border-bottom:1px solid var(--panel-border);padding-bottom:.75rem;font-size:1.1rem;font-weight:700}.staff-stat-list{flex-direction:column;gap:1.25rem;display:flex}.staff-stat-item{flex-direction:column;gap:.5rem;display:flex}.staff-stat-info{justify-content:space-between;font-size:.9rem;display:flex}.staff-name{font-weight:600}.staff-counts{color:var(--text-secondary)}.progress-bar-container{background:#ffffff0d;border-radius:4px;height:8px;display:flex;overflow:hidden}.progress-bar-total{background:var(--accent-gradient);border-radius:4px;height:100%;transition:width .6s}.progress-bar-weekend{background:linear-gradient(135deg,#10b981 0%,#059669 100%);border-radius:4px;height:100%;transition:width .6s}.stat-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.stat-box{border:1px solid var(--panel-border);border-radius:var(--border-radius-md);text-align:center;background:#0003;padding:1rem}.stat-box-value{color:var(--accent-primary);font-size:1.6rem;font-weight:800}.stat-box-label{color:var(--text-muted);margin-top:4px;font-size:.8rem}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.form-label{color:var(--text-secondary);font-size:.9rem;font-weight:600}.form-control{border:1px solid var(--panel-border);color:var(--text-primary);border-radius:var(--border-radius-md);font-family:var(--font-sans);transition:var(--transition-smooth);background:#0003;padding:.75rem 1rem;font-size:.95rem}.form-control:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 10px #8b5cf633}select.form-control{cursor:pointer}.request-list{flex-direction:column;gap:1rem;max-height:400px;padding-right:4px;display:flex;overflow-y:auto}.request-card{border:1px solid var(--panel-border);border-radius:var(--border-radius-md);transition:var(--transition-smooth);background:#ffffff05;justify-content:space-between;align-items:center;padding:1rem;display:flex}.request-card:hover{background:#ffffff0a}.request-info{flex-direction:column;gap:4px;display:flex}.request-date{color:var(--text-primary);font-weight:700}.request-staff{color:var(--accent-secondary);font-size:.9rem}.request-reason{color:var(--text-muted);font-size:.85rem;font-style:italic}.toast{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--border-radius-md);box-shadow:var(--glass-shadow);z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);align-items:center;gap:.75rem;padding:1rem 1.5rem;animation:.3s cubic-bezier(.175,.885,.32,1.275) slideIn;display:flex;position:fixed;bottom:24px;right:24px}.toast.toast-success{border-left:4px solid var(--success)}.toast.toast-error{border-left:4px solid var(--danger)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:999;background:#0009;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);width:90%;max-width:500px;box-shadow:var(--glass-shadow);padding:2rem;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleUp}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-close{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;font-size:1.5rem}.modal-close:hover{color:var(--text-primary)}.theme-toggle{border:1px solid var(--panel-border);cursor:pointer;width:42px;height:42px;color:var(--text-primary);transition:var(--transition-bounce);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:#ffffff1a;transform:rotate(30deg)scale(1.1)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--panel-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.admin-actions{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.date-range-inputs{border-radius:var(--border-radius-md);border:1px solid var(--panel-border);background:#00000026;flex-wrap:wrap;align-items:flex-end;gap:1rem;padding:1rem;display:flex}.draft-warning-banner{border-radius:var(--border-radius-md);color:#fbbf24;background:#f59e0b1a;border:1px solid #f59e0b40;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;font-size:.9rem;display:flex}.draft-badge{background:var(--warning);color:#000;text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:.75rem;font-weight:800}.published-badge{background:var(--success);color:#fff;text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:.75rem;font-weight:800}.spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.staff-editor-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.staff-editor-card{border:1px solid var(--panel-border);border-radius:var(--border-radius-md);background:#ffffff05;justify-content:space-between;align-items:center;padding:1rem;display:flex}.staff-editor-card input[type=text]{border:1px solid var(--panel-border);color:#fff;font-family:var(--font-sans);background:#0003;border-radius:6px;width:60%;padding:.4rem .6rem;font-weight:600}
