:root{--amber:#F59E0B;--coral:#FB7185;--charcoal:#78350F;--amber-hover:#D97706;--amber-light:#FEF3C7;--amber-secondary:#FBBF24;--coral-hover:#F43F5E;--coral-light:#FDA4AF;--inactive:#78716C;--success:#22C55E;--warning:#EAB308;--error:#EF4444;--white:#FFFFFF;--black:#1C1917;--gray-50:#FAFAF9;--gray-100:#F5F5F4;--gray-200:#E7E5E4;--gray-300:#D6D3D1;--gray-400:#A8A29E;--gray-500:#78716C;--gray-600:#57534E;--gray-700:#44403C;--gray-800:#292524;--gray-900:#1C1917;--teal:#F59E0B;--teal-500:#F59E0B;--teal-400:#FBBF24;--teal-300:#FCD34D;--teal-200:#FDE68A;--teal-700:#B45309;--mint:#FBBF24;--primary:#F59E0B;--primary-hover:#D97706;--primary-dark:#B45309;--primary-light:#FEF3C7;--primary-muted:#FDE68A;--coral-400:#FB7185;--coral-300:#FDA4AF;--slate-50:#FAFAF9;--slate-100:#F5F5F4;--slate-200:#E7E5E4;--slate-300:#D6D3D1;--slate-400:#A8A29E;--slate-500:#78716C;--slate-600:#57534E;--slate-700:#44403C;--slate-800:#292524;--slate-900:#1C1917;--cream:#FFFBEB;--gray:#78716C;--gray-light:#E7E5E4;--gray-lighter:#F5F5F4;--gray-dark:#44403C;--accent-1:#fdf4f0;--accent-1-dark:#e8c4b8;--accent-2:#f0f7f4;--accent-2-dark:#93c5b4;--accent-3:#fef9ed;--accent-3-dark:#e8d59c;--accent-4:#f0f4f8;--accent-4-dark:#94b8d4;--accent-5:#faf0f5;--accent-5-dark:#d4a0b8;--accent-6:#f5f0fa;--accent-6-dark:#b8a0d4;--success-light:#DCFCE7;--success-dark:#166534;--success-muted:#86EFAC;--warning-light:#FEF3C7;--warning-dark:#92400E;--warning-muted:#FDE68A;--error-light:#FEE2E2;--error-dark:#991B1B;--error-muted:#FECACA;--info:#F59E0B;--info-light:#FEF3C7;--shadow-xs:0 1px 2px rgba(245, 158, 11, 0.05);--shadow-sm:0 2px 4px rgba(245, 158, 11, 0.06),0 1px 2px rgba(245, 158, 11, 0.04);--shadow-md:0 4px 8px rgba(245, 158, 11, 0.08),0 2px 4px rgba(245, 158, 11, 0.05);--shadow-lg:0 12px 20px rgba(245, 158, 11, 0.12),0 4px 8px rgba(245, 158, 11, 0.06);--shadow-xl:0 24px 32px rgba(245, 158, 11, 0.14),0 8px 16px rgba(245, 158, 11, 0.08);--shadow-2xl:0 32px 48px rgba(245, 158, 11, 0.18),0 12px 24px rgba(245, 158, 11, 0.10);--shadow-elevated:0 16px 32px rgba(245, 158, 11, 0.15),0 0 1px rgba(0, 0, 0, 0.1);--shadow-coral:0 4px 12px rgba(251, 113, 133, 0.30);--shadow-coral-lg:0 8px 20px rgba(251, 113, 133, 0.35);--shadow-focus:0 0 0 3px #FDE68A,0 0 0 1px #F59E0B;--shadow-focus-amber:0 0 0 3px #FDE68A,0 0 0 1px #F59E0B;--shadow-focus-error:0 0 0 3px var(--error-muted);--border:1px solid var(--slate-200);--border-dark:1px solid var(--slate-400);--border-subtle:1px solid var(--slate-100);--border-primary:1px solid var(--teal-300);--border-focus:2px solid var(--teal-500);--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:10px;--radius-2xl:12px;--radius-full:9999px;--transition-fast:0.15s ease;--transition-base:0.2s ease;--transition-slow:0.3s ease}*{box-sizing:border-box}body{margin:0;font-family:Manrope,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--cream);color:var(--black);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;width:100%;line-height:1.6;font-size:15px}.container{width:100%;max-width:100%;margin:0 auto;padding:16px;overflow-x:hidden}@media (max-width:768px){.container{padding:8px;padding-bottom:90px}}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px;padding:12px 18px;background:linear-gradient(180deg,var(--white) 0,var(--slate-50) 100%);border:1px solid var(--slate-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);position:sticky;top:8px;z-index:100;backdrop-filter:blur(8px)}@media (max-width:768px){.toolbar{padding:10px 14px;gap:8px;border-radius:var(--radius-lg)}}.toolbar h1{font-size:24px;font-weight:700;margin:0;margin-right:auto;color:var(--black);display:none;letter-spacing:-.02em}button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:2px solid #e5e7eb;background:#fff;border-radius:8px;cursor:pointer;font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;font-weight:600;transition:all .15s ease;color:#1a1a1a;position:relative;overflow:hidden}@media (max-width:768px){button{padding:8px 14px;font-size:12px;min-height:44px;min-width:44px}}button:hover{background:#fafaf9;border-color:#f59e0b;color:#f59e0b}button:active{transform:scale(.98)}button.primary{background:#f59e0b;color:#fff;border-color:#f59e0b}button.primary:hover{background:#d97706;border-color:#d97706}button.primary:active{background:#f59e0b}button.coral,button.cta{background:#fb7185;color:#fff;border-color:#fb7185}button.coral:hover,button.cta:hover{background:#f43f5e;border-color:#f43f5e}button.coral:active,button.cta:active{background:#fb7185}button.secondary{background:0 0;color:#f59e0b;border-color:#f59e0b}button.secondary:hover{background:#f59e0b;color:#fff}button.ghost{background:0 0;border-color:transparent;color:#f59e0b}button.ghost:hover{background:#fef3c7;border-color:#fef3c7}button.destructive{background:#ef4444;color:#fff;border-color:#ef4444}button.destructive:hover{background:#dc2626;border-color:#dc2626}button:disabled{background:#f5f5f4;color:#a8a29e;border-color:#e7e5e4;cursor:not-allowed;transform:none!important}button:disabled:hover{background:#f5f5f4;color:#a8a29e;border-color:#e5e7eb}.tabs{display:flex;gap:2px;flex-wrap:wrap;background:linear-gradient(180deg,var(--slate-100) 0,var(--slate-50) 100%);padding:6px;border:1px solid var(--slate-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm),inset 0 1px 2px rgba(0,0,0,.04)}@media (max-width:768px){.tabs{flex-wrap:nowrap;overflow-x:auto;border-radius:var(--radius-lg);padding:5px;-webkit-overflow-scrolling:touch}.tabs-desktop-only{display:none!important}.btn-desktop-only{display:none!important}.mobile-hide{display:none!important}}.tab{padding:12px 22px;border:none;background:0 0;cursor:pointer;font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.4, 0, .2, 1);color:var(--slate-500);position:relative;box-shadow:none;border-radius:var(--radius-lg);margin:2px}.tab:last-child{border-right:none}@media (max-width:768px){.tab{padding:10px 16px;font-size:12px;white-space:nowrap;flex-shrink:0}}.tab:hover{background:var(--white);color:var(--slate-700);transform:none;box-shadow:0 1px 2px rgba(0,0,0,.05)}.tab.active{background:var(--white);color:#b45309;box-shadow:var(--shadow-sm);font-weight:700}.tab.active::after{content:'';position:absolute;bottom:6px;left:50%;transform:translateX(-50%);width:24px;height:3px;background:#f59e0b;border-radius:var(--radius-full)}.card{background:var(--white);border:1px solid var(--slate-200);border-radius:var(--radius-xl);margin:16px 0;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease;overflow:hidden}.card .content{padding:0;overflow:visible;-webkit-overflow-scrolling:touch;border-radius:var(--radius-xl)}.card:has([data-wrap]) .content{overflow:auto;max-height:80vh}.card:has(.people-table) .content{overflow-x:hidden;overflow-y:visible;padding:12px}@media (max-width:768px){.card:has(.people-table) .content{overflow-x:auto;-webkit-overflow-scrolling:touch}}.people-table{margin:0}.card .content>div{overflow:visible;max-width:100%}@media (max-width:768px){.card{border-radius:var(--radius-lg)}.card .content{padding:0}.card:has(.people-table) .content{padding:6px}.people-table{margin:0}}.card:first-child .content>div:first-child{padding:20px 24px;padding-bottom:16px;background:var(--primary-light);border-radius:var(--radius-xl) var(--radius-xl) 0 0}@media (max-width:768px){.card:first-child .content>div:first-child{padding:12px 16px;padding-bottom:12px}}.card:first-child .content>div:first-child>div:last-child{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}@media (max-width:768px){.card:first-child .content>div:first-child>div:last-child{gap:6px;margin-top:8px}}.grid-wrap[data-chart]{width:100%;overflow:visible!important;max-height:none!important;height:auto!important;padding-right:9px}.grid-wrap[data-chart] *{overflow:visible!important}.grid-wrap[data-wrap]{overflow:auto;max-height:65vh;width:100%}.grid{display:grid;width:100%}.td,.th{border:1px solid var(--gray-light);padding:8px;text-align:center;font-size:13px}.th.sticky{position:sticky;left:0;background:var(--white);z-index:5}.td.sticky{position:sticky;left:0;z-index:5}.td.sticky-left,.th.sticky-left{position:sticky;left:0;background:var(--white);z-index:11}.th{position:sticky;top:0;background:var(--primary-light);color:var(--black);z-index:9;font-weight:600;border-bottom:2px solid var(--primary-muted);font-size:12px}.th.sticky-header{top:80px;z-index:7}.th.sticky{z-index:12}.th.sticky-left.sticky-header{z-index:11}.time-header{writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;height:72px;display:flex;align-items:center;justify-content:center;font-weight:600}.cell{user-select:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;position:relative;border:1px solid var(--gray-light)}.cell:hover:not(.unavail){filter:brightness(.95);transform:scale(1.02);z-index:2}.on-mgr{background:var(--accent-1);border-color:var(--accent-1-dark);color:var(--black);font-weight:600}.on-dep{background:var(--accent-6);border-color:var(--accent-6-dark);color:var(--black);font-weight:600}.on-am{background:var(--accent-3);border-color:var(--accent-3-dark);color:var(--black);font-weight:600}.on-sup{background:var(--accent-4);border-color:var(--accent-4-dark);color:var(--black);font-weight:600}.on-team{background:var(--accent-2);border-color:var(--accent-2-dark);color:var(--black);font-weight:600}.on-kitchen{background:var(--accent-5);border-color:var(--accent-5-dark);color:var(--black);font-weight:600}.unavail{background:repeating-linear-gradient(45deg,var(--gray-lighter),var(--gray-lighter) 8px,var(--gray-light) 8px,var(--gray-light) 16px)!important;color:var(--gray);opacity:.6;cursor:not-allowed!important;pointer-events:none!important}.cell.preview-fill{background:var(--accent-4)!important;border:2px dashed var(--accent-4-dark)!important;animation:pulse-preview .8s ease-in-out infinite}.cell.preview-clear{background:var(--error-light)!important;border:2px dashed var(--error)!important;animation:pulse-preview-clear .8s ease-in-out infinite}@keyframes pulse-preview{0%,100%{opacity:1}50%{opacity:.6}}@keyframes pulse-preview-clear{0%,100%{opacity:1}50%{opacity:.5}}.chip{display:inline-flex;align-items:center;padding:6px 14px;border-radius:var(--radius-full);font-size:12px;font-weight:600;border:none}@media (max-width:768px){.chip{padding:4px 10px;font-size:10px}}.chip.mgr{background:var(--accent-1);color:var(--black)}.chip.dep{background:var(--accent-6);color:var(--black)}.chip.am{background:var(--accent-3);color:var(--black)}.chip.sup{background:var(--accent-4);color:var(--black)}.chip.team{background:var(--accent-2);color:var(--black)}.chip.kitchen{background:var(--accent-5);color:var(--black)}.pill{display:inline-flex;align-items:center;gap:6px;background:var(--white);color:var(--black);border:var(--border);border-radius:var(--radius-full);padding:8px 16px;font-size:13px;font-weight:600;box-shadow:var(--shadow-xs)}@media (max-width:768px){.pill{padding:6px 12px;font-size:11px}}.card:first-child .pill{padding:10px 18px;background:var(--white)}@media (max-width:768px){.card:first-child .pill{padding:6px 12px;font-size:10px}}.week-controls{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;margin-bottom:12px;background:var(--white);border:var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.week-controls-group{display:flex;align-items:center;gap:8px}.week-controls-group.actions{gap:10px}.week-controls-divider{width:1px;height:24px;background:var(--gray-light);margin:0 4px}.week-control-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:600;border-radius:var(--radius-md);border:var(--border);background:var(--white);color:var(--black);cursor:pointer;transition:all .15s ease;white-space:nowrap}.week-control-btn:hover{background:var(--gray-lighter);border-color:var(--gray)}.week-control-btn.primary{background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);color:var(--white);border-color:var(--primary);box-shadow:0 2px 4px rgba(245,158,11,.2)}.week-control-btn.primary:hover{box-shadow:0 4px 8px rgba(245,158,11,.3);transform:translateY(-1px)}.week-control-btn.success{background:var(--success-light);color:var(--success);border-color:var(--success)}.week-control-toggle{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:600;border-radius:var(--radius-md);border:var(--border);background:var(--gray-lighter);color:var(--gray);cursor:pointer;transition:all .15s ease}.week-control-toggle:hover{background:var(--gray-light)}.week-control-toggle.active{background:var(--primary-light);color:var(--primary);border-color:var(--primary-muted)}.week-control-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary);cursor:pointer}@media (max-width:768px){.week-controls{display:none}}.week-stats{display:flex;gap:20px;padding:0 8px}.week-stat{display:flex;flex-direction:column;gap:2px}.week-stat-label{font-size:10px;font-weight:500;color:var(--gray);text-transform:uppercase;letter-spacing:.5px}.week-stat-value{font-size:14px;font-weight:700;color:var(--black)}.week-stat-value.success{color:var(--success)}.week-stat-value.warning{color:var(--warning)}.week-stat-value.error{color:var(--error)}.people-table{width:100%;border-collapse:collapse;table-layout:fixed;margin:0;border:1px solid var(--slate-200);border-radius:var(--radius-lg);overflow:hidden}@media (max-width:768px){.people-table{table-layout:auto;min-width:600px}}.people-table thead th{background:var(--primary-light);color:var(--black);padding:12px 8px;font-weight:600;font-size:12px;border-bottom:1px solid var(--teal-300);border-right:1px solid var(--teal-200);text-align:center;height:52px}.people-table thead th:last-child{border-right:none}@media (max-width:768px){.people-table thead th{padding:10px 6px;font-size:10px;height:46px}}.people-table thead tr:first-child th{top:0}.people-table thead tr:nth-child(2) th{top:52px}@media (max-width:768px){.people-table thead tr:nth-child(2) th{top:46px}}.people-table thead tr:nth-child(3) th{top:104px}@media (max-width:768px){.people-table thead tr:nth-child(3) th{top:92px}}.people-table thead th:first-child{background:var(--primary-light)!important;width:15%;min-width:100px;text-align:left;border-right:1px solid var(--teal-300)}@media (max-width:768px){.people-table thead th:first-child{width:25%;min-width:80px}}.people-table thead th:not(:first-child){width:auto}.people-table tbody td{padding:10px 8px;border-bottom:1px solid var(--slate-200);border-right:1px solid var(--slate-100);font-size:13px;text-align:center;vertical-align:top;overflow:hidden;position:relative;transition:background-color var(--transition-fast)}.people-table tbody td:last-child{border-right:none}.people-table tbody td.name.has-role::after{content:'\A' attr(data-role);white-space:pre-wrap;font-size:9px;color:var(--slate-400);font-weight:400}.people-table tbody tr:last-child td{border-bottom:none}.people-table tbody td:hover{background-color:rgba(245,158,11,.04)}@media (max-width:768px){.people-table tbody td{padding:8px 6px;font-size:11px}}.shift-time{display:inline-block;padding:4px 8px;background:var(--white);border:1px solid var(--gray-light);border-radius:var(--radius-sm);font-weight:600;font-size:12px;color:var(--black);margin:2px 0;box-shadow:var(--shadow-xs)}.shift-time.kitchen{border-color:var(--success);background:var(--success-light);color:var(--success)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-sm);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.status-badge.holiday{background:var(--warning-light);color:var(--warning-dark);border:1px solid var(--warning-muted)}.status-badge.approved-holiday{background:var(--success-light);color:var(--success-dark);border:1px solid var(--success-muted)}.status-badge.pending{background:var(--warning-light);color:var(--warning-dark);border:1px solid var(--warning-muted)}.status-badge.sick{background:var(--error-light);color:var(--error);border:1px solid var(--error-muted)}.status-badge.off{background:var(--slate-100);color:var(--slate-500);border:1px solid var(--slate-200)}.status-badge.exclusion{background:var(--error-muted);color:var(--error-dark);border:1px solid var(--error)}.hours-display{font-size:10px;color:var(--gray);font-weight:500;margin-top:4px}.clock-record{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:3px 6px;border-radius:var(--radius-sm);font-size:10px;font-weight:500}.clock-record.complete{background:var(--success-light);color:var(--success-dark)}.clock-record.in-progress{background:var(--warning-light);color:var(--warning-dark)}.people-table td.today-column,.people-table th.today-column{background:linear-gradient(180deg,rgba(245,158,11,.08) 0,rgba(245,158,11,.04) 100%)!important}.people-table tbody tr.role-group-start td{border-top:2px solid var(--primary-muted)!important}.role-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.role-dot.manager{background:#f59e0b}.role-dot.supervisor{background:#d97706}.role-dot.kitchen{background:#9d174d}.role-dot.team{background:var(--success-dark)}.people-table tbody td:first-child{font-weight:600;text-align:left;padding-left:14px;border-right:1px solid var(--slate-200);overflow:hidden}@media (max-width:768px){.people-table tbody td:first-child{padding-left:10px}}.people-table tbody tr:nth-child(odd){background:var(--white)}.people-table tbody tr:nth-child(2n){background:var(--gray-lighter)}.people-table td .ranges{white-space:pre-wrap;line-height:1.5;font-weight:600}@media (max-width:768px){.people-table td .ranges{font-size:10px;line-height:1.3}}.people-table td[draggable=true]{cursor:grab;-webkit-user-select:none;user-select:none}@media (max-width:768px){.people-table td[draggable=true]{cursor:pointer}}.people-table td.drop-target{outline:2px solid var(--accent-4-dark);outline-offset:-2px;background:var(--accent-4)!important}.holiday-shaded{background:var(--accent-3)!important;opacity:.8;cursor:not-allowed!important;pointer-events:none!important}.users-container{max-width:1400px;margin:0 auto}.users-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding:20px 24px;background:var(--white);border:var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.users-header h2{margin:0;font-size:24px;font-weight:700;color:var(--black)}.users-header-actions{display:flex;gap:12px}.user-card{background:var(--white);border:var(--border);border-radius:var(--radius-xl);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-sm);transition:all .2s ease;display:flex;flex-direction:column}.user-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.user-card-header{order:1;display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--gray-light)}.user-card-title{display:flex;align-items:center;gap:14px}.user-avatar{width:52px;height:52px;border-radius:50%;background:var(--primary-light);border:2px solid var(--primary-muted);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:20px;font-weight:700;box-shadow:var(--shadow-xs)}.user-info{flex:1}.user-name{font-size:18px;font-weight:700;color:var(--black);margin:0 0 6px 0}.user-role-badge{display:inline-block;padding:4px 12px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:var(--primary-light);color:var(--primary)}.user-card-body{order:2;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}.user-card-body-force-grid{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:16px!important}.user-field{display:flex;flex-direction:column;gap:8px}.user-field-label{font-size:12px;font-weight:700;color:var(--gray)}.user-field input,.user-field select{width:100%;padding:12px 14px;border:var(--border);border-radius:var(--radius-md);font-size:14px;font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;transition:var(--transition-base);background:var(--white)}.user-field input:hover,.user-field select:hover{border-color:var(--primary-muted)}.user-field input:focus,.user-field select:focus{outline:0;border-color:var(--teal-500);box-shadow:var(--shadow-focus);background:var(--white)}.availability-section{margin-top:16px;border-top:1px solid var(--gray-light);padding-top:16px}.availability-toggle{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--primary-light);border:var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;user-select:none}.availability-toggle:hover{background:var(--teal-200);border-color:var(--teal-300)}.availability-toggle-left{display:flex;align-items:center;gap:10px}.availability-toggle-icon{font-size:22px}.availability-toggle-text{font-size:15px;font-weight:700;color:var(--black)}.availability-toggle-arrow{font-size:20px;transition:transform .2s ease;color:var(--black)}.availability-toggle-arrow.expanded{transform:rotate(180deg)}.availability-content{max-height:0;overflow:hidden;transition:max-height .3s ease}.availability-content.expanded{max-height:400px;padding-top:16px}.availability-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.availability-day{background:var(--white);border:var(--border);border-radius:var(--radius-lg);padding:14px;text-align:center;transition:all .2s ease}.availability-day:hover{border-color:var(--primary-muted);box-shadow:var(--shadow-sm)}.availability-day-name{font-size:12px;font-weight:700;color:var(--black);margin-bottom:10px}.availability-checkboxes{display:flex;flex-direction:column;gap:8px}.availability-checkbox{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:500;color:var(--black)}.availability-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.users-empty{text-align:center;padding:60px 20px;color:var(--gray)}.users-empty-icon{font-size:72px;margin-bottom:20px}.users-empty-text{font-size:18px;font-weight:600;margin-bottom:24px}.finance-table,.forecast-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--white);border:var(--border);border-radius:var(--radius-xl);overflow:hidden}.finance-table thead th,.forecast-table thead th{background:var(--primary-light);color:var(--black);padding:14px 16px;font-weight:600;font-size:13px;text-align:left;border-bottom:2px solid var(--primary-muted);position:sticky;top:0;z-index:10}.finance-table tbody td,.forecast-table tbody td{padding:14px 16px;border-bottom:1px solid var(--gray-light);font-size:14px;color:var(--black)}.finance-table tbody tr:nth-child(2n),.forecast-table tbody tr:nth-child(2n){background:var(--gray-lighter)}.finance-table tbody tr:hover,.forecast-table tbody tr:hover{background:var(--primary-light)}.finance-table tfoot td,.forecast-table tfoot td{padding:18px 16px;font-weight:700;font-size:15px;background:var(--success-light);border-top:2px solid var(--success)}.finance-table tbody input[type=number],.forecast-table tbody input[type=number]{max-width:120px}.forecast-table tbody textarea{width:100%;min-width:220px;resize:vertical}input[type=date],input[type=email],input[type=number],input[type=password],input[type=tel],input[type=text],select,textarea{border:var(--border);border-radius:var(--radius-md);padding:12px 14px;font-size:14px;font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;transition:var(--transition-base);background:var(--white)}input:hover,select:hover,textarea:hover{border-color:var(--primary-muted)}input:focus,select:focus,textarea:focus{outline:0;border-color:var(--teal-500);box-shadow:var(--shadow-focus);background:var(--white)}.time-select{font-size:12px;padding:6px 8px;border:var(--border);border-radius:var(--radius-sm);font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;min-width:0;flex:1;max-width:65px}.time-select-wrap{display:flex;align-items:center;gap:4px;margin-top:8px;justify-content:center;flex-wrap:nowrap;overflow:hidden;max-width:100%}.time-select-wrap.hidden{display:none}@media (max-width:1024px){.time-select{font-size:11px;padding:4px 6px;max-width:55px}.time-select-wrap{gap:3px}.time-select-wrap span{font-size:11px}}@media (max-width:768px){.time-select-wrap{display:none!important}}.availability-marker{display:inline;color:var(--coral);font-weight:700}.hide-availability-markers .availability-marker{display:none}.ics-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:var(--border);border-radius:var(--radius-full);background:var(--white);font-size:13px;font-weight:600;cursor:pointer;color:var(--black);transition:all .2s ease;box-shadow:none}.ics-btn:hover{background:var(--primary-light);box-shadow:var(--shadow-sm)}.delete-shift-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;margin-left:6px;border:none;border-radius:50%;background:var(--error);color:#fff;font-size:12px;font-weight:700;cursor:pointer;box-shadow:var(--shadow-xs);transition:all .2s ease}.delete-shift-btn:hover{background:var(--error-dark);transform:scale(1.1)}.delete-shift-btn.hidden{display:none}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--cream);padding:20px;position:relative}.login-box{position:relative;z-index:1;background:var(--white);padding:48px;border:var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:420px}@media (max-width:768px){.login-box{padding:32px 24px;border-radius:var(--radius-lg)}}.login-icon{font-size:56px;text-align:center;margin-bottom:20px}.login-title{margin:0 0 8px 0;font-size:28px;font-weight:700;text-align:center;color:var(--black)}.login-subtitle{margin:0 0 32px 0;font-size:15px;font-weight:500;text-align:center;color:var(--gray)}.login-form-group{margin-bottom:20px}.login-label{display:block;margin-bottom:8px;font-size:13px;font-weight:700;color:var(--black)}.login-input{width:100%;padding:14px 16px;border:var(--border);border-radius:var(--radius-md);font-size:15px;font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;transition:var(--transition-base);background:var(--white);color:var(--black)}.login-input:hover{border-color:var(--primary-muted)}.login-input:focus{outline:0;border-color:var(--teal-500);box-shadow:var(--shadow-focus);background:var(--white)}.login-input::placeholder{color:var(--gray);opacity:.6}.login-submit{width:100%;padding:16px;background:var(--primary);color:var(--white);border:none;border-radius:var(--radius-full);font-size:15px;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.login-submit:hover{background:var(--primary-dark);box-shadow:var(--shadow-md)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.oauth-button{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 16px;background:var(--white);color:var(--text-primary);border:2px solid var(--neutral-200);border-radius:var(--radius-full);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.oauth-button:hover{border-color:var(--neutral-300);box-shadow:var(--shadow-md);background:var(--neutral-50)}.oauth-button:disabled{opacity:.6;cursor:not-allowed}.oauth-icon{flex-shrink:0}.oauth-google:hover{border-color:#4285f4}.oauth-divider{display:flex;align-items:center;gap:16px;margin:20px 0;color:var(--neutral-400);font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.oauth-divider::after,.oauth-divider::before{content:'';flex:1;height:1px;background:var(--neutral-200)}.login-error{padding:14px;margin-bottom:20px;background:var(--error-light);color:var(--error);border:1px solid var(--error);border-radius:var(--radius-md);font-size:14px;font-weight:600;text-align:center}.login-success{padding:16px;margin-bottom:20px;background:var(--success-light);color:var(--primary-dark);border:1px solid var(--success);border-radius:var(--radius-md);font-size:14px;font-weight:600;text-align:center;white-space:pre-line;line-height:1.6}.login-forgot-link{display:block;width:100%;margin-top:16px;padding:10px;background:0 0;border:none;color:var(--primary);font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;text-align:center;transition:color .2s}.login-forgot-link:hover{color:var(--primary-dark);text-decoration:underline}.login-version{margin-top:24px;padding-top:16px;border-top:1px solid var(--gray-light);text-align:center;font-size:13px;font-weight:500;color:var(--gray)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(45,52,54,.5);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-in-out;backdrop-filter:blur(4px)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.modal-dialog{background:var(--white);border:var(--border);border-radius:var(--radius-xl);padding:28px;max-width:500px;width:90%;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out}@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width:768px){.modal-dialog{width:95%;padding:24px;border-radius:var(--radius-lg)}}.modal-title{font-size:22px;font-weight:700;margin:0 0 24px 0;color:var(--black);text-align:center}.modal-options{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.modal-option-btn{display:flex;align-items:flex-start;padding:18px;border:var(--border);border-radius:var(--radius-lg);background:var(--white);cursor:pointer;transition:var(--transition-base);text-align:left;font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;box-shadow:none}.modal-option-btn:hover{background:var(--primary-light);border-color:var(--primary-muted)}.modal-option-icon{font-size:36px;margin-right:16px;flex-shrink:0}@media (max-width:768px){.modal-option-icon{font-size:28px;margin-right:12px}}.modal-option-content{flex:1}.modal-option-title{font-size:17px;font-weight:700;margin:0 0 8px 0;color:var(--black)}.modal-option-desc{font-size:14px;margin:0;color:var(--gray);line-height:1.6}.modal-option-desc li{margin:4px 0}.modal-cancel{width:100%;padding:12px;background:0 0;border:var(--border);border-radius:var(--radius-full);font-size:14px;font-weight:700;color:var(--black);cursor:pointer;transition:all .2s ease;box-shadow:none}.modal-cancel:hover{background:var(--gray-lighter)}.birthday-emoji{display:inline-block!important;animation:bounce 1.5s ease-in-out infinite;transform-origin:center center}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:var(--border);padding:8px 12px;z-index:1000;box-shadow:0 -4px 16px rgba(0,0,0,.08)}@media (max-width:768px){.mobile-nav{display:flex;justify-content:space-around;align-items:center}}.mobile-nav-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:0 0;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;color:var(--gray);box-shadow:none;min-width:60px}.mobile-nav-btn:hover{background:var(--gray-lighter)}.mobile-nav-btn.active{background:var(--primary-light);color:var(--primary)}.mobile-nav-icon{font-size:22px}.mobile-nav-label{font-size:11px;font-weight:700}.messages-container{max-width:800px;margin:0 auto}.message-card{background:var(--white);border:var(--border);border-radius:var(--radius-xl);padding:20px;margin-bottom:12px;box-shadow:var(--shadow-sm);transition:all .2s ease}.message-card:hover{box-shadow:var(--shadow-md)}.message-card.unread{border-left:4px solid var(--primary);background:var(--primary-light)}.message-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.message-from{font-weight:700;font-size:16px;color:var(--black)}.message-date{font-size:13px;color:var(--gray);font-weight:500}.message-content{font-size:15px;color:var(--black);line-height:1.7}.toast{position:fixed;top:20px;right:20px;background:var(--black);color:var(--white);padding:16px 24px;border-radius:var(--radius-xl);border:none;box-shadow:var(--shadow-lg);z-index:10001;animation:slideIn .3s ease-out;font-weight:600}.toast.success{background:var(--success);color:var(--white)}.toast.error{background:var(--error);color:var(--white)}@keyframes slideIn{from{transform:translateX(100px);opacity:0}to{transform:translateX(0);opacity:1}}.settings-section{background:var(--white);border:var(--border);border-radius:var(--radius-xl);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.settings-section-title{font-size:18px;font-weight:700;color:var(--black);margin:0 0 20px 0;padding-bottom:12px;border-bottom:1px solid var(--gray-light)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--gray-light)}.settings-row:last-child{border-bottom:none}.settings-label{font-weight:600;color:var(--black)}.settings-desc{font-size:14px;color:var(--gray);margin-top:4px}.toggle-switch{position:relative;width:52px;height:28px;background:var(--gray-light);border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .2s ease}.toggle-switch.active{background:var(--success)}.toggle-switch::after{content:'';position:absolute;top:3px;left:3px;width:22px;height:22px;background:var(--white);border:none;border-radius:50%;transition:all .2s ease;box-shadow:var(--shadow-sm)}.toggle-switch.active::after{left:27px}.loading{display:flex;align-items:center;justify-content:center;padding:60px}.loading-spinner{width:48px;height:48px;border:3px solid var(--gray-light);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:80px 40px;color:var(--gray)}.empty-state-icon{font-size:80px;margin-bottom:24px}.empty-state-title{font-size:24px;font-weight:700;color:var(--black);margin-bottom:12px}.empty-state-desc{font-size:16px;color:var(--gray);max-width:400px;margin:0 auto 32px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:700}.text-sm{font-size:13px}.text-lg{font-size:18px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.p-4{padding:16px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-lighter);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--primary-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--primary)}@media print{body{background:var(--white)!important}.mobile-nav,.tabs,.toolbar,button{display:none!important}.card{box-shadow:none!important;border:1px solid var(--slate-300)!important;break-inside:avoid}}