.motion-btn{position:relative;overflow:hidden}.motion-btn__ripple{position:absolute;width:24px;height:24px;margin-left:-12px;margin-top:-12px;border-radius:50%;pointer-events:none;animation:motion-ripple-expand .55s ease-out forwards}.motion-btn--ripple-light .motion-btn__ripple{background:#ffffff6b}.motion-btn--ripple-dark .motion-btn__ripple{background:#0f172a1f}@keyframes motion-ripple-expand{to{transform:scale(22);opacity:0}}@media (prefers-reduced-motion: reduce){.motion-btn__ripple{animation:none;opacity:0}}:root{--emp-bg: #0f172a;--emp-bg-soft: #1e293b;--emp-surface: #ffffff;--emp-surface-2: #f8fafc;--emp-text: #0f172a;--emp-muted: #64748b;--emp-accent: #DA7756;--emp-accent-2: #c4684a;--emp-danger: #f87171;--emp-success: #4ade80;--emp-tab-h: calc(3.5rem + env(safe-area-inset-bottom, 0px)) }.emp-shell{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:linear-gradient(165deg,#0f172a,#1e293b 42%,#f1f5f9 42%);background-attachment:fixed;color:var(--emp-text);padding-bottom:var(--emp-tab-h)}.emp-topbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:max(.65rem,env(safe-area-inset-top)) 1rem .65rem;color:#f8fafc}.emp-brand-row{display:flex;align-items:center;gap:.5rem;min-width:0}.emp-logo{height:32px;width:auto;max-width:140px;object-fit:contain;flex-shrink:0;display:block}.emp-brand{margin:0;font-size:1.15rem;font-weight:800;letter-spacing:-.03em;color:#f8fafc}.emp-topbar-actions{display:flex;align-items:center;gap:.5rem;min-width:0}.emp-user{font-size:.78rem;color:#94a3b8;max-width:42vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.emp-btn-ghost{background:#ffffff14;color:#e2e8f0;border:1px solid rgba(255,255,255,.15);padding:.4rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600;cursor:pointer;transition:transform .18s ease,background .15s ease,box-shadow .18s ease}@media (hover: hover) and (pointer: fine){.emp-btn-ghost:hover{transform:scale(1.04);background:#ffffff1f;box-shadow:0 4px 16px #0003}}.emp-btn-ghost:active{transform:scale(.97)}.emp-page-transition{min-height:100%}.emp-main{padding:1rem 1rem 1.25rem;max-width:32rem;margin:0 auto;background-color:#f1f5f9;background-image:linear-gradient(180deg,#f8fafc,#f1f5f9 10%,#f1f5f9);border-radius:22px 22px 0 0;box-shadow:0 -6px 28px #0f172a2e;flex:1 1 auto;min-height:calc(100dvh - 5.25rem - var(--emp-tab-h));color:#1e293b;isolation:isolate}.emp-tabbar{position:fixed;left:0;right:0;bottom:0;z-index:50;display:flex;justify-content:space-around;align-items:stretch;gap:.25rem;padding:.35rem .5rem calc(.35rem + env(safe-area-inset-bottom,0px));background:#0f172aeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -8px 32px #0003}.emp-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;padding:.35rem .2rem;border-radius:12px;text-decoration:none;color:#94a3b8;font-size:.62rem;font-weight:600;letter-spacing:.02em;min-width:0;transition:transform .18s ease,color .15s ease,background .15s ease}@media (hover: hover) and (pointer: fine){.emp-tab:hover{transform:scale(1.05);color:#cbd5e1}.emp-tab:active{transform:scale(.96)}}.emp-tab svg{width:22px;height:22px;opacity:.85}.emp-tab.active{color:#da7756;background:#da77561f}.emp-tab.active svg{opacity:1}.emp-main .emp-page-title{font-size:1.35rem;font-weight:800;letter-spacing:-.03em;margin:0 0 .25rem;color:#0f172a}.emp-main .emp-page-sub{margin:0 0 1rem;font-size:.88rem;color:#475569;line-height:1.45}.emp-main .emp-page-sub strong{color:#0f172a;font-weight:700}.emp-main input:not([type=checkbox]):not([type=radio]),.emp-main select,.emp-main textarea{transition:border-color .2s ease,box-shadow .22s ease}.emp-main input:focus,.emp-main select:focus,.emp-main textarea:focus{outline:none;border-color:#da7756;box-shadow:0 0 0 3px #da775626}.emp-card{background:var(--emp-surface);border-radius:16px;padding:1rem 1.05rem;margin-bottom:.85rem;box-shadow:0 4px 24px #0f172a0f;border:1px solid rgba(148,163,184,.2)}.emp-card h3{margin:0 0 .35rem;font-size:.95rem;font-weight:700;color:var(--emp-text)}.emp-error{background:#fef2f2;color:#b91c1c;padding:.75rem .85rem;border-radius:12px;margin-bottom:.85rem;font-size:.88rem;border:1px solid #fecaca}.emp-banner{background:linear-gradient(135deg,#5c2e1a,#3d1d0e);color:#fde0cc;padding:.85rem 1rem;border-radius:14px;margin-bottom:.85rem;font-size:.86rem;border:1px solid rgba(218,119,86,.35)}.emp-banner strong{display:block;margin-bottom:.25rem;color:#fff}.emp-banner button{margin-top:.5rem;background:#ffffff26;border:none;color:#fff;padding:.35rem .75rem;border-radius:8px;font-size:.8rem;cursor:pointer}.emp-banner.emp-banner-urgent{background:linear-gradient(135deg,#7f1d1d,#450a0a);border-color:#f8717173}.emp-muted{color:var(--emp-muted);font-size:.85rem;margin:0}.emp-hint{color:var(--emp-muted);font-size:.82rem;margin:0 0 .65rem;line-height:1.4}.emp-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.65rem 1rem;border-radius:12px;font-size:.9rem;font-weight:600;border:none;cursor:pointer;width:100%;transition:transform .18s ease,box-shadow .2s ease,filter .15s ease,opacity .15s ease;will-change:transform}.emp-btn:disabled{opacity:.55;cursor:not-allowed}@media (hover: hover) and (pointer: fine){.emp-btn:hover:not(:disabled){transform:scale(1.02);box-shadow:0 8px 22px #0f172a24}.emp-btn:active:not(:disabled){transform:scale(.98)}}.emp-btn-primary{background:linear-gradient(135deg,#f0a878,#da7756);color:#fff;box-shadow:0 4px 14px #da775659}.emp-btn-danger{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff}.emp-btn-secondary{background:#f1f5f9;color:#334155}.emp-shift-hero{background:linear-gradient(145deg,#fff,#fef7f2);border-radius:20px;padding:1.1rem 1rem 1.25rem;margin-bottom:1rem;border:1px solid rgba(218,119,86,.25);box-shadow:0 8px 32px #0f172a14}.emp-shift-hero-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#da7756;margin:0 0 .35rem;text-align:center}.emp-shift-meta{text-align:center;font-size:.88rem;color:#475569;margin:0 0 .5rem;line-height:1.4}.shift-ring-wrap{margin:0 auto .75rem}.shift-ring-visual{position:relative;margin:0 auto}.shift-ring-svg{display:block;margin:0 auto;max-width:100%;height:auto}.shift-ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;padding:18%}.shift-ring-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#64748b}.shift-ring-time{font-size:clamp(1.5rem,7vw,2rem);font-weight:800;font-variant-numeric:tabular-nums;color:#0f172a;letter-spacing:-.02em;line-height:1.1}.shift-ring-sub{font-size:.75rem;color:#94a3b8;margin-top:.15rem}.emp-break-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:.65rem 1rem;margin:0 0 .75rem;font-size:.75rem;color:#475569}.emp-break-legend span{display:inline-flex;align-items:center;gap:.35rem}.emp-dot{width:8px;height:8px;border-radius:50%;border:1px solid #0f172a}.emp-dot.break{background:#a78bfa}.emp-dot.fifth-hour{background:#f97316}.emp-disclaimer{font-size:.68rem;color:#94a3b8;text-align:center;margin:0 0 .75rem;line-height:1.35}.emp-notify-row{display:flex;justify-content:center;margin-bottom:.5rem}.emp-notify-btn{background:transparent;border:1px dashed #94a3b8;color:#475569;padding:.4rem .75rem;border-radius:999px;font-size:.75rem;cursor:pointer}.emp-week-strip{display:flex;align-items:center;gap:.35rem;margin-bottom:1rem}.emp-week-strip button{flex-shrink:0;width:2.25rem;height:2.25rem;border-radius:10px;border:1px solid #cbd5e1;background:#fff;color:#334155;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.emp-week-label{flex:1;text-align:center;font-size:.8rem;font-weight:600;color:#334155;line-height:1.25}.emp-day-block{margin-bottom:1rem}.emp-day-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin:0 0 .45rem .15rem}.emp-shift-card{background:#fff;border-radius:14px;padding:.85rem 1rem;margin-bottom:.5rem;border:1px solid rgba(148,163,184,.25);box-shadow:0 2px 12px #0f172a0a}.emp-shift-time{font-weight:800;font-size:1rem;color:#0f172a;margin-bottom:.2rem}.emp-shift-role{font-size:.88rem;color:#475569}.emp-shift-loc{font-size:.78rem;color:#94a3b8;margin-top:.15rem}.emp-shift-actions{margin-top:.65rem}.emp-form-stack{display:flex;flex-direction:column;gap:.85rem}.emp-field label{display:flex;flex-direction:column;gap:.35rem;font-size:.82rem;font-weight:600;color:#475569}.emp-field input,.emp-field select{padding:.65rem .75rem;border-radius:10px;border:1px solid #e2e8f0;font-size:.95rem;width:100%;box-sizing:border-box}.emp-form-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.emp-pills{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.65rem}.emp-pill{display:inline-flex;align-items:center;gap:.35rem;background:#f1f5f9;padding:.4rem .55rem;border-radius:10px;font-size:.82rem}.emp-pill-btn{background:none;border:none;padding:0 .2rem;cursor:pointer;color:#64748b;font-size:.85rem}.emp-pill-btn.danger{color:#dc2626}.emp-inline-form{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.emp-inline-form>select,.emp-inline-form>input[type=text],.emp-inline-form>input[type=date]{padding:.5rem .65rem;border-radius:10px;border:1px solid #e2e8f0;font-size:.9rem}.emp-inline-form .emp-btn,.emp-inline-form .emp-btn-primary{width:auto}.emp-btn-narrow{width:auto;padding-left:1rem;padding-right:1rem}.emp-time-meridiem{display:inline-flex;gap:.35rem;align-items:center}.emp-time-meridiem select{min-width:4.25rem}.emp-time-meridiem input{width:6.25rem;box-sizing:border-box}.emp-request-list{list-style:none;margin:0;padding:0}.emp-request-item{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.65rem 0;border-bottom:1px solid #f1f5f9;font-size:.86rem}.emp-request-item:last-child{border-bottom:none}@keyframes empRequestPop{0%{opacity:1;transform:scale(1)}30%{transform:scale(1.04)}to{opacity:0;transform:scale(.85)}}.emp-pop-approve{animation:empRequestPop .4s ease-in forwards;box-shadow:0 0 0 3px #4ade8073;border-radius:8px}.emp-pop-deny{animation:empRequestPop .4s ease-in forwards;box-shadow:0 0 0 3px #f8717173;border-radius:8px}.emp-status{font-size:.72rem;padding:.2rem .45rem;border-radius:6px;text-transform:capitalize;font-weight:600}.emp-status-pending{background:#fef3c7;color:#92400e}.emp-status-approved{background:#d1fae5;color:#065f46}.emp-status-denied{background:#fee2e2;color:#991b1b}.emp-status-completed{background:#d1fae5;color:#065f46}.emp-cancel-btn{margin-left:auto;padding:.35rem .65rem;font-size:.8rem;font-weight:600;color:#dc2626;background:#fff;border:1px solid #fecaca;border-radius:8px;cursor:pointer}.emp-dates-strong{font-weight:600;color:#0f172a}.emp-swap-line{font-size:.84rem;color:#334155;line-height:1.4}.emp-request-item .emp-status.emp-swap-status{margin-left:auto}.emp-loading{text-align:center;color:#64748b;padding:2rem 1rem;font-size:.9rem}.emp-skeleton{border-radius:10px;background:linear-gradient(110deg,#e2e8f0,#f1f5f9 45%,#e8edf3 55%,#e2e8f0);background-size:200% 100%;animation:emp-skeleton-shimmer 1.15s ease-in-out infinite}.emp-skeleton-block{height:2.6rem;margin-bottom:.85rem}.emp-skeleton-row{height:2.85rem;max-width:100%}.emp-skeleton-row--short{height:2.5rem;max-width:12rem}@keyframes emp-skeleton-shimmer{0%{background-position:120% 0}to{background-position:-120% 0}}@media (min-width: 640px){.emp-shell{background:linear-gradient(165deg,#0f172a,#1e293b 35%,#f1f5f9 35%)}.emp-main{max-width:40rem;padding:1rem 1.25rem 1.25rem}.emp-user{max-width:200px}}@media (prefers-reduced-motion: reduce){.emp-btn,.emp-tab,.emp-btn-ghost{transition:opacity .15s ease,background .15s ease,color .15s ease}.emp-btn:hover:not(:disabled),.emp-btn:active:not(:disabled),.emp-tab:hover,.emp-tab:active,.emp-btn-ghost:hover,.emp-btn-ghost:active{transform:none}.emp-main input,.emp-main select,.emp-main textarea{transition:border-color .15s ease}.emp-skeleton{animation:none;background:#e2e8f0}}[data-theme=dark] .emp-shell{background:linear-gradient(165deg,#020617,#0f172a 42%,#1e293b 42%);color:#e2e8f0}[data-theme=dark] .emp-main{background-color:#1e293b;background-image:linear-gradient(180deg,#1e293b,#1a2332 10%,#1a2332);color:#e2e8f0;box-shadow:0 -6px 28px #0000004d}[data-theme=dark] .emp-main .emp-page-title{color:#f1f5f9}[data-theme=dark] .emp-main .emp-page-sub{color:#94a3b8}[data-theme=dark] .emp-main .emp-page-sub strong{color:#f1f5f9}[data-theme=dark] .emp-tabbar{background:#020617f2;border-top-color:#ffffff0f}[data-theme=dark] .emp-card{background:#0f172a;border-color:#47556966;box-shadow:0 4px 24px #00000026}[data-theme=dark] .emp-card h3{color:#f1f5f9}[data-theme=dark] .emp-error{background:#450a0a;color:#fca5a5;border-color:#7f1d1d}[data-theme=dark] .emp-shift-card{background:#0f172a;border-color:#47556959;box-shadow:0 2px 12px #00000026}[data-theme=dark] .emp-shift-time{color:#f1f5f9}[data-theme=dark] .emp-shift-role{color:#94a3b8}[data-theme=dark] .emp-shift-loc{color:#64748b}[data-theme=dark] .emp-day-label{color:#94a3b8}[data-theme=dark] .emp-shift-hero{background:linear-gradient(145deg,#0f172a,#3d1d0e);border-color:#da775640}[data-theme=dark] .emp-shift-hero-title{color:#f0a878}[data-theme=dark] .emp-shift-meta{color:#94a3b8}[data-theme=dark] .shift-ring-time{color:#f1f5f9}[data-theme=dark] .shift-ring-label{color:#94a3b8}[data-theme=dark] .shift-ring-sub{color:#64748b}[data-theme=dark] .emp-break-legend{color:#94a3b8}[data-theme=dark] .emp-disclaimer{color:#64748b}[data-theme=dark] .emp-week-strip button{background:#0f172a;border-color:#475569;color:#e2e8f0}[data-theme=dark] .emp-week-label{color:#e2e8f0}[data-theme=dark] .emp-muted,[data-theme=dark] .emp-hint{color:#94a3b8}[data-theme=dark] .emp-btn-secondary{background:#334155;color:#e2e8f0}[data-theme=dark] .emp-field label{color:#94a3b8}[data-theme=dark] .emp-field input,[data-theme=dark] .emp-field select{background:#0f172a;border-color:#475569;color:#e2e8f0}[data-theme=dark] .emp-pill{background:#334155;color:#e2e8f0}[data-theme=dark] .emp-pill-btn{color:#94a3b8}[data-theme=dark] .emp-inline-form>select,[data-theme=dark] .emp-inline-form>input[type=text],[data-theme=dark] .emp-inline-form>input[type=date]{background:#0f172a;border-color:#475569;color:#e2e8f0}[data-theme=dark] .emp-request-item{border-bottom-color:#334155}[data-theme=dark] .emp-status-pending{background:#451a03;color:#fbbf24}[data-theme=dark] .emp-status-approved,[data-theme=dark] .emp-status-completed{background:#052e16;color:#4ade80}[data-theme=dark] .emp-status-denied{background:#450a0a;color:#fca5a5}[data-theme=dark] .emp-cancel-btn{background:#1e293b;border-color:#7f1d1d;color:#f87171}[data-theme=dark] .emp-dates-strong{color:#f1f5f9}[data-theme=dark] .emp-swap-line{color:#e2e8f0}[data-theme=dark] .emp-loading{color:#94a3b8}[data-theme=dark] .emp-notify-btn{border-color:#475569;color:#94a3b8}[data-theme=dark] .emp-skeleton{background:linear-gradient(110deg,#334155,#1e293b 45%,#2d3a4d 55%,#334155);background-size:200% 100%}@media (min-width: 640px){[data-theme=dark] .emp-shell{background:linear-gradient(165deg,#020617,#0f172a 35%,#1e293b 35%)}}.emp-tab-bar{display:flex;gap:.35rem;padding:.25rem;background:#f1f5f9;border-radius:10px}.emp-tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem .75rem;border:none;border-radius:8px;background:transparent;color:#64748b;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .15s ease}.emp-tab-btn:hover{background:#da775614;color:#334155}.emp-tab-active{background:#fff;color:#1e293b;box-shadow:0 1px 3px #0000001a}.emp-badge-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#da7756;color:#fff;font-size:.68rem;font-weight:700;line-height:1}.emp-success{padding:.65rem .85rem;border-radius:8px;background:#dcfce7;color:#166534;font-size:.82rem;font-weight:500;margin-bottom:.75rem}[data-theme=dark] .emp-tab-bar{background:#1e293b}[data-theme=dark] .emp-tab-btn{color:#94a3b8}[data-theme=dark] .emp-tab-btn:hover{background:#da775626;color:#e2e8f0}[data-theme=dark] .emp-tab-active{background:#334155;color:#f1f5f9;box-shadow:0 1px 3px #0000004d}[data-theme=dark] .emp-success{background:#052e16;color:#86efac}*{box-sizing:border-box}:root{font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#1e293b;background-color:#f8fafc;font-size:15px}body{margin:0;min-height:100vh}#root{min-height:100vh}.app-shell{display:flex;min-height:100vh}.sidebar{width:260px;min-width:260px;background:#0f172a;color:#e2e8f0;display:flex;flex-direction:column;padding:.75rem 0 1.5rem;position:sticky;top:0;height:100vh;overflow-y:auto;transition:width .2s ease,min-width .2s ease;z-index:100}.sidebar-collapsed{width:56px;min-width:56px}.sidebar-top{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem .75rem;border-bottom:1px solid #1e293b;margin-bottom:.5rem}.sidebar-collapsed .sidebar-top{justify-content:center;padding:.5rem .5rem .75rem}.sidebar-toggle{background:none;border:1px solid #334155;border-radius:6px;color:#94a3b8;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;line-height:1;flex-shrink:0;transition:all .15s ease}.sidebar-toggle:hover{background:#1e293b;color:#e2e8f0;border-color:#475569}.sidebar-brand{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;color:#fff}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:0 .75rem;flex:1}.sidebar-footer{padding:.75rem .75rem 0;border-top:1px solid #1e293b;margin-top:auto}.sidebar-footer .sidebar-link.sidebar-logout{color:#94a3b8}.sidebar-footer .sidebar-link.sidebar-logout:hover{background:#7f1d1d;color:#fecaca}.sidebar-footer .sidebar-link svg{width:18px;height:18px}.sidebar-link{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;color:#94a3b8;transition:all .15s ease;border:none;background:none;text-align:left;width:100%}.sidebar-link:hover{background:#1e293b;color:#e2e8f0}.sidebar-link.active{background:#5c2e1a;color:#fde0cc}.sidebar-link svg{width:18px;height:18px;flex-shrink:0}.sidebar-collapsed .sidebar-link{justify-content:center;padding:.6rem}.sidebar-collapsed .sidebar-nav{padding:0 .35rem}.main-content{flex:1;min-width:0;padding:2rem 2.5rem;max-width:1400px}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;font-weight:700;margin:0 0 .25rem;color:#0f172a;letter-spacing:-.02em}.page-header p{margin:0;color:#64748b;font-size:.9rem}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1rem;box-shadow:0 1px 4px #0000000a}.card-title{font-size:1rem;font-weight:600;color:#0f172a;margin:0 0 .75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background-color .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap;line-height:1.4;will-change:transform}@media (hover: hover) and (pointer: fine){.btn:hover:not(:disabled){transform:scale(1.02);box-shadow:0 4px 14px #0f172a1f}.btn:active:not(:disabled){transform:scale(.98);box-shadow:0 2px 6px #0f172a14}}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#da7756;color:#fff;border-color:#da7756;box-shadow:0 2px 8px #da77564d}.btn-primary:hover:not(:disabled){background:#c4684a}.btn-success{background:#059669;color:#fff;border-color:#059669}.btn-success:hover:not(:disabled){background:#047857}.btn-secondary{background:#fff;color:#374151;border-color:#d1d5db}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-danger{background:#fff;color:#dc2626;border-color:#fecaca}.btn-danger:hover:not(:disabled){background:#fef2f2;border-color:#dc2626}.btn-ghost{background:transparent;color:#64748b;border-color:transparent;padding:.35rem .6rem;font-size:.8rem}.btn-ghost:hover:not(:disabled){background:#f1f5f9;color:#334155}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.input,select,textarea{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;color:#1e293b;background:#fff;transition:border-color .2s ease,box-shadow .22s ease;font-family:inherit}.input:focus,select:focus,textarea:focus{outline:none;border-color:#da7756;box-shadow:0 0 0 3px #da77562e}.input:focus-visible,select:focus-visible,textarea:focus-visible{border-color:#da7756}textarea{resize:vertical}.badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;line-height:1.4}.badge-blue{background:#dbeafe;color:#1e40af}.badge-green{background:#dcfce7;color:#166534}.badge-amber{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.alert{padding:.75rem 1rem;border-radius:8px;font-size:.875rem;margin-bottom:1rem}.alert-warning{background:#fffbeb;border:1px solid #f59e0b;color:#92400e}.alert-error{background:#fef2f2;border:1px solid #ef4444;color:#991b1b}.alert-success{background:#f0fdf4;border:1px solid #22c55e;color:#166534}.toggle-group{display:inline-flex;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;background:#fff;box-shadow:0 1px 2px #0000000a}.toggle-btn{padding:.5rem 1rem;border:none;background:transparent;color:#64748b;font-weight:600;font-size:.875rem;cursor:pointer;transition:transform .16s ease,background .15s ease,color .15s ease}@media (hover: hover) and (pointer: fine){.toggle-btn:active:not(.active){transform:scale(.97)}}.toggle-btn:not(:last-child){border-right:1px solid #e2e8f0}.toggle-btn.active{background:#da7756;color:#fff}.toggle-btn:hover:not(.active){background:#f8fafc;color:#334155}.schedule-scroll-breakout{margin-left:-1.5rem;margin-right:-1.5rem;width:calc(100% + 3rem)}.schedule-scroll{overflow-x:auto;overflow-y:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding-bottom:12px;margin-bottom:1rem;border-radius:0;border:none;background:transparent;box-shadow:none}.schedule-scroll::-webkit-scrollbar{height:8px}.schedule-scroll::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.schedule-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.schedule-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}.schedule-grid{display:block;width:100%;max-width:100%;border:1px solid #BFDBFE;border-radius:14px;overflow:hidden;background:#eff4fb;box-shadow:0 2px 8px #2563eb0f}.schedule-grid-week-fluid .schedule-grid-header,.schedule-grid-week-fluid .schedule-week-body{width:100%}.schedule-grid-week-fluid .schedule-day-header,.schedule-grid-week-fluid .schedule-day-column{flex:1 1 0%;min-width:0;width:auto;max-width:none}.schedule-week-body{display:flex;flex-wrap:nowrap;align-items:flex-start;justify-content:flex-start}.schedule-grid-header{display:flex;flex-wrap:nowrap;justify-content:flex-start;border-bottom:1px solid #BFDBFE;background:#dbeafe;transition:background .3s ease}.schedule-grid-header.published{background:#bbf7d0;border-bottom-color:#86efac}.schedule-grid-header.pending-review{background:#fef08a;border-bottom-color:#fde047}.schedule-day-header{text-align:center;padding:10px 8px;font-weight:600;color:#1e3a5f;cursor:pointer;border-left:1px solid #BFDBFE;transition:background .15s ease,border-color .3s ease}.schedule-grid-header.published .schedule-day-header{border-left-color:#86efac;color:#14532d}.schedule-grid-header.pending-review .schedule-day-header{border-left-color:#fde047;color:#713f12}.schedule-day-header:first-child{border-left:none}.schedule-day-header:hover{background:#c7d9f5;color:#0f172a}.schedule-grid-header.published .schedule-day-header:hover{background:#a7f3d0;color:#0f172a}.schedule-grid-header.pending-review .schedule-day-header:hover{background:#fef08a;color:#0f172a}.schedule-day-header-dayname{display:block;font-size:.7rem;font-weight:500;color:#4b6a9b;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.schedule-grid-header.published .schedule-day-header-dayname{color:#15803d}.schedule-grid-header.pending-review .schedule-day-header-dayname{color:#a16207}.schedule-day-header-date{font-size:1.1rem;color:#0f172a;line-height:1.2}.schedule-week-status-badge{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:999px;margin-left:.5rem;vertical-align:middle}.schedule-week-status-badge.published{background:#dcfce7;color:#15803d}.schedule-week-status-badge.pending-review{background:#fef9c3;color:#a16207}.schedule-day-column{position:relative;overflow:hidden;cursor:pointer;background:#eff4fb;border-left:1px solid #BFDBFE;transition:background .15s ease}.schedule-day-column:first-child{border-left:none}.schedule-day-column:hover{background:#dbeafe}.schedule-day-column-empty{display:flex;align-items:center;justify-content:center;height:100%;min-height:100px;color:#64748b;font-size:.8rem;font-weight:500;padding:1rem;text-align:center}.schedule-day-view-box{border:1px solid #BFDBFE;border-radius:14px;overflow:hidden;background:#eff4fb;box-shadow:0 2px 8px #2563eb0f}.schedule-day-view-content{background:#eff4fb;min-height:100px;position:relative;cursor:pointer;transition:background .15s ease}.schedule-day-view-content:hover{background:#dbeafe}.schedule-day-view-empty{display:flex;align-items:center;justify-content:center;min-height:140px;color:#64748b;font-size:.9rem;font-weight:500;padding:1.5rem;text-align:center}@keyframes requestPopOut{0%{opacity:1;transform:scale(1)}30%{transform:scale(1.04)}to{opacity:0;transform:scale(.85)}}.request-pop-approve{animation:requestPopOut .4s ease-in forwards;box-shadow:0 0 0 3px #22c55e73,0 4px 16px #22c55e33}.request-pop-deny{animation:requestPopOut .4s ease-in forwards;box-shadow:0 0 0 3px #ef444473,0 4px 16px #ef444433}@keyframes shiftBubbleIn{0%{opacity:0;transform:translateY(12px) scale(.92)}60%{opacity:1;transform:translateY(-2px) scale(1.02)}to{opacity:1;transform:translateY(0) scale(1)}}.shift-block.shift-block-animate{animation:shiftBubbleIn .4s ease-out both}.shift-block{position:absolute;border-radius:8px;padding:6px 10px;overflow:hidden;font-size:.75rem;transition:box-shadow .18s ease,border-color .18s ease,transform .18s ease,filter .18s ease;cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:44px}.shift-block:hover{transform:scale(1.03) translateY(-1px);box-shadow:0 6px 20px #00000026;filter:brightness(1.05);z-index:5!important}.shift-block-assigned{border:1px solid rgba(37,99,235,.18);box-shadow:0 1px 3px #2563eb1a}.shift-block-assigned:not(.shift-block-boh){color:#1e293b}.shift-block-boh.shift-block-assigned{border-color:#2563eb38;box-shadow:0 1px 3px #2563eb1a;color:#1e293b}.shift-block-boh.shift-block-assigned span{color:inherit}.shift-block-boh .shift-time{color:#1e3a5f!important}.shift-block-unassigned{border:1px dashed #94a3b8;box-shadow:0 1px 3px #0000000a;color:#64748b}.shift-block-unassigned:hover{transform:scale(1.03) translateY(-1px);box-shadow:0 4px 12px #0000001a;border-color:#64748b}.shift-block-boh.shift-block-unassigned{border-color:#94a3b8;color:#64748b}.shift-block-boh.shift-block-unassigned:hover{border-color:#64748b}.shift-block-pinned:after{content:"";position:absolute;top:3px;right:5px;width:12px;height:12px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23475569'%3E%3Cpath d='M16 12V4h1V2H7v2h1v8l-2 2v2h5.2v6h1.6v-6H18v-2l-2-2z'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;opacity:.75}.shift-block-changed{box-shadow:inset 0 0 0 2px #f59e0b}.shift-block-changed:before{content:"";position:absolute;top:2px;left:5px;width:7px;height:7px;border-radius:50%;background:#f59e0b}.emp-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem 0;border-bottom:1px solid #f1f5f9}.emp-row:last-child{border-bottom:none}.avail-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .6rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.82rem;color:#334155}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:#fff;padding:1.5rem 1.75rem;border-radius:16px;min-width:min(480px,92vw);max-width:90vw;box-shadow:0 12px 40px #0000001f,0 2px 8px #0000000f;border:1px solid #e2e8f0;box-sizing:border-box}.modal-card h3{margin:0 0 1rem;font-size:1.15rem;font-weight:700;color:#0f172a}.ai-panel{background:linear-gradient(135deg,#fef7f2,#fdfaf8);border:1px solid #f0c8b0;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.25rem}.ai-panel textarea{width:100%;border:1px solid #f0c8b0}.ai-panel textarea:focus{border-color:#da7756;box-shadow:0 0 0 3px #da77561f}.ai-response{margin-top:.75rem;padding:.75rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;white-space:pre-wrap;font-size:.875rem;color:#334155;line-height:1.6}.edit-table{width:100%;border-collapse:collapse;font-size:.875rem}.edit-table th{text-align:left;padding:.6rem .75rem;border-bottom:2px solid #e2e8f0;color:#64748b;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.edit-table td{padding:.5rem .75rem;border-bottom:1px solid #f1f5f9}.edit-table tr:hover{background:#f8fafc}.list-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.list-item:last-child{border-bottom:none}.notif-panel{position:fixed;bottom:80px;left:268px;width:340px;max-height:420px;overflow-y:auto;border-radius:12px;box-shadow:0 8px 32px #00000040;z-index:9999}.sidebar-collapsed~.notif-panel,.notif-panel.notif-panel-collapsed{left:64px}@media (max-width: 900px){.sidebar{width:56px!important;min-width:56px!important}.sidebar-brand{display:none}.sidebar-top{justify-content:center}.sidebar-link span{display:none}.sidebar-link{justify-content:center;padding:.6rem}.sidebar-nav{padding:0 .35rem}.main-content{padding:1.5rem 1rem}.notif-panel{left:64px!important}}@media (prefers-reduced-motion: reduce){.btn,.toggle-btn{transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}.btn:hover:not(:disabled),.btn:active:not(:disabled){transform:none}.input,select,textarea{transition:border-color .15s ease}}[data-theme=dark]{color:#e2e8f0;background-color:#0f172a}[data-theme=dark] .sidebar{background:#020617;border-right:1px solid #1e293b}[data-theme=dark] .sidebar-top{border-bottom-color:#334155}[data-theme=dark] .sidebar-footer{border-top-color:#334155}[data-theme=dark] .sidebar-link:hover{background:#1e293b}[data-theme=dark] .sidebar-link.active{background:#1e3a5f}[data-theme=dark] .main-content{background:#0f172a}[data-theme=dark] .page-header h1{color:#f1f5f9}[data-theme=dark] .page-header p{color:#94a3b8}[data-theme=dark] .card{background:#1e293b;border-color:#334155;box-shadow:0 1px 4px #0003}[data-theme=dark] .card-title{color:#f1f5f9}[data-theme=dark] .btn-secondary{background:#1e293b;color:#e2e8f0;border-color:#475569}[data-theme=dark] .btn-secondary:hover:not(:disabled){background:#334155;border-color:#64748b}[data-theme=dark] .btn-danger{background:#1e293b;color:#f87171;border-color:#7f1d1d}[data-theme=dark] .btn-danger:hover:not(:disabled){background:#371717;border-color:#dc2626}[data-theme=dark] .btn-ghost{color:#94a3b8}[data-theme=dark] .btn-ghost:hover:not(:disabled){background:#1e293b;color:#e2e8f0}[data-theme=dark] .input,[data-theme=dark] select,[data-theme=dark] textarea{background:#1e293b;border-color:#475569;color:#e2e8f0}[data-theme=dark] .input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{border-color:#da7756;box-shadow:0 0 0 3px #da775640}[data-theme=dark] .badge-blue{background:#1e3a5f;color:#93c5fd}[data-theme=dark] .badge-green{background:#14532d;color:#86efac}[data-theme=dark] .badge-amber{background:#451a03;color:#fbbf24}[data-theme=dark] .badge-red{background:#450a0a;color:#fca5a5}[data-theme=dark] .alert-warning{background:#451a03;border-color:#b45309;color:#fbbf24}[data-theme=dark] .alert-error{background:#450a0a;border-color:#b91c1c;color:#fca5a5}[data-theme=dark] .alert-success{background:#052e16;border-color:#15803d;color:#86efac}[data-theme=dark] .toggle-group{background:#1e293b;border-color:#475569}[data-theme=dark] .toggle-btn{color:#94a3b8}[data-theme=dark] .toggle-btn:not(:last-child){border-right-color:#475569}[data-theme=dark] .toggle-btn:hover:not(.active){background:#334155;color:#e2e8f0}[data-theme=dark] .schedule-grid{background:#1e293b;border-color:#334155;box-shadow:0 2px 8px #0003}[data-theme=dark] .schedule-grid-header{background:#172554;border-bottom-color:#1e3a5f}[data-theme=dark] .schedule-grid-header.published{background:#052e16;border-bottom-color:#15803d}[data-theme=dark] .schedule-grid-header.pending-review{background:#422006;border-bottom-color:#a16207}[data-theme=dark] .schedule-day-header{color:#93c5fd;border-left-color:#1e3a5f}[data-theme=dark] .schedule-day-header:hover{background:#1e3a5f;color:#e0f2fe}[data-theme=dark] .schedule-grid-header.published .schedule-day-header{color:#86efac;border-left-color:#15803d}[data-theme=dark] .schedule-grid-header.published .schedule-day-header:hover{background:#14532d;color:#bbf7d0}[data-theme=dark] .schedule-grid-header.pending-review .schedule-day-header{color:#fbbf24;border-left-color:#a16207}[data-theme=dark] .schedule-grid-header.pending-review .schedule-day-header:hover{background:#451a03;color:#fde68a}[data-theme=dark] .schedule-day-header-dayname{color:#60a5fa}[data-theme=dark] .schedule-grid-header.published .schedule-day-header-dayname{color:#4ade80}[data-theme=dark] .schedule-grid-header.pending-review .schedule-day-header-dayname{color:#f59e0b}[data-theme=dark] .schedule-day-header-date{color:#f1f5f9}[data-theme=dark] .schedule-day-column{background:#1e293b;border-left-color:#334155}[data-theme=dark] .schedule-day-column:hover{background:#172554}[data-theme=dark] .schedule-day-column-empty{color:#94a3b8}[data-theme=dark] .schedule-day-view-box{background:#1e293b;border-color:#334155}[data-theme=dark] .schedule-day-view-content{background:#1e293b}[data-theme=dark] .schedule-day-view-content:hover{background:#172554}[data-theme=dark] .schedule-day-view-empty{color:#94a3b8}[data-theme=dark] .shift-block-assigned{border-color:#3b82f64d;box-shadow:0 1px 3px #0000004d}[data-theme=dark] .shift-block-assigned:not(.shift-block-boh){color:#1e293b}[data-theme=dark] .shift-block-boh.shift-block-assigned{color:#1e293b}[data-theme=dark] .shift-block-unassigned{border-color:#475569;color:#94a3b8;background:#1e293b99}[data-theme=dark] .shift-block-unassigned:hover{border-color:#64748b;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .shift-block:hover{box-shadow:0 6px 20px #0000004d}[data-theme=dark] .schedule-week-status-badge.published{background:#052e16;color:#4ade80}[data-theme=dark] .schedule-week-status-badge.pending-review{background:#422006;color:#fbbf24}[data-theme=dark] .emp-row{border-bottom-color:#334155}[data-theme=dark] .avail-pill{background:#334155;border-color:#475569;color:#e2e8f0}[data-theme=dark] .modal-overlay{background:#0009}[data-theme=dark] .modal-card{background:#1e293b;border-color:#475569;box-shadow:0 12px 40px #0006,0 2px 8px #0003}[data-theme=dark] .modal-card h3{color:#f1f5f9}[data-theme=dark] .ai-panel{background:linear-gradient(135deg,#1e293b,#0f172a);border-color:#475569}[data-theme=dark] .ai-panel textarea{border-color:#475569;background:#0f172a;color:#e2e8f0}[data-theme=dark] .ai-response{background:#0f172a;border-color:#334155;color:#e2e8f0}[data-theme=dark] .edit-table th{border-bottom-color:#475569;color:#94a3b8}[data-theme=dark] .edit-table td{border-bottom-color:#334155;color:#e2e8f0}[data-theme=dark] .edit-table tr:hover{background:#334155}[data-theme=dark] .list-item{border-bottom-color:#334155}[data-theme=dark] .schedule-scroll::-webkit-scrollbar-track{background:#1e293b}[data-theme=dark] .schedule-scroll::-webkit-scrollbar-thumb{background:#475569}[data-theme=dark] .schedule-scroll::-webkit-scrollbar-thumb:hover{background:#64748b}.login-page .login-card-wrap{width:100%;max-width:360px}.login-page .login-card input{transition:border-color .2s ease,box-shadow .22s ease}.login-page .login-card input:focus{outline:none;border-color:#da7756;box-shadow:0 0 0 3px #da775633}.login-page .login-card .motion-btn{width:100%;padding:.6rem 1rem;margin-top:.5rem;background:#da7756;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;box-shadow:0 4px 14px #da775659}.login-page .login-card .motion-btn:hover:not(:disabled){background:#c4684a}.login-page .login-card .motion-btn:disabled{opacity:.7;cursor:not-allowed;box-shadow:none}@media (prefers-reduced-motion: reduce){.login-page .login-card input{transition:border-color .15s ease}}[data-theme=dark] .login-page{background:linear-gradient(135deg,#020617,#0f172a)}[data-theme=dark] .login-card{background:#1e293b;box-shadow:0 20px 40px #0006}[data-theme=dark] .login-subtitle{color:#94a3b8}[data-theme=dark] .login-card label{color:#cbd5e1}[data-theme=dark] .login-card input{background:#0f172a;border-color:#475569;color:#e2e8f0}[data-theme=dark] .login-card input:focus{border-color:#da7756;box-shadow:0 0 0 3px #da775640}[data-theme=dark] .forgot-link{color:#f0a878}[data-theme=dark] .form-error{background:#450a0a;color:#fca5a5}
