:root{--font: "Inter", system-ui, -apple-system, sans-serif;--primary: #7C3AED;--primary-light: rgba(124,58,237,.1);--primary-hover: #6D28D9;--primary-glow: rgba(124,58,237,.35);--accent-blue: #0EA5E9;--accent-teal: #0D9488;--accent-green: #10B981;--accent-amber: #F59E0B;--accent-rose: #F43F5E;--bg: #F1F5F9;--surface: #FFFFFF;--surface-raised: #FFFFFF;--border: #E2E8F0;--border-strong: #CBD5E1;--text-primary: #0F172A;--text-secondary: #475569;--text-tertiary: #94A3B8;--text-muted: #94A3B8;--tabbar-bg: #0E1028;--tabbar-height: 52px;--tabbar-border: rgba(255,255,255,.06);--sidebar-width: 240px;--sidebar-collapsed: 64px;--sidebar-bg: #0A0C1E;--sidebar-border: rgba(255,255,255,.06);--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 8px 24px rgba(0,0,0,.14), 0 4px 8px rgba(0,0,0,.08);--shadow-xl: 0 16px 40px rgba(0,0,0,.18), 0 8px 16px rgba(0,0,0,.1);--radius: 10px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--transition: .18s cubic-bezier(.4, 0, .2, 1)}html.dark{color-scheme:dark;--primary-light: rgba(124,58,237,.18);--primary-glow: rgba(124,58,237,.4);--bg: #080B18;--surface: #10152A;--surface-raised: #181E36;--border: #1E2640;--border-strong: #2D3A58;--text-primary: #F1F5F9;--text-secondary: #8B9DC3;--text-tertiary: #4E6088;--text-muted: #4E6088;--tabbar-bg: #060814;--tabbar-border: rgba(255,255,255,.05);--sidebar-bg: #04060F;--sidebar-border: rgba(255,255,255,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.55), 0 2px 4px rgba(0,0,0,.35);--shadow-lg: 0 8px 24px rgba(0,0,0,.65), 0 4px 8px rgba(0,0,0,.4);--shadow-xl: 0 16px 40px rgba(0,0,0,.75), 0 8px 16px rgba(0,0,0,.5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;font-size:14px}body{height:100%;font-family:var(--font);background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;overflow:hidden}#root{height:100%;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;height:100%;overflow:hidden}.app-body{display:flex;flex:1;overflow:hidden}.main-content{flex:1;overflow-y:auto;background:var(--bg)}.app-right{display:flex;flex-direction:column;flex:1;overflow:hidden}.tabbar{display:flex;flex-direction:column;width:var(--sidebar-width);height:100%;background:var(--tabbar-bg);border-right:1px solid var(--tabbar-border);flex-shrink:0;transition:width .22s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:2px 0 24px #00000073,0 0 0 1px #ffffff08;-webkit-user-select:none;user-select:none;--text-primary: rgba(255,255,255,.92);--text-secondary: rgba(255,255,255,.5);--text-tertiary: rgba(255,255,255,.3);--bg: rgba(255,255,255,.05);--border: rgba(255,255,255,.08);--surface: rgba(255,255,255,.04)}.tabbar--collapsed{width:var(--sidebar-collapsed)}.tabbar-tabs{display:flex;flex-direction:column;gap:2px;padding:4px 8px;flex-shrink:0}.tabbar-brand{display:flex;align-items:center;gap:10px;padding:16px 14px 12px;flex-shrink:0}.tabbar-brand-icon{flex-shrink:0;display:flex}.tabbar-brand-name{font-size:13px;font-weight:800;letter-spacing:-.3px;background:linear-gradient(135deg,#fffffff2,#c4b5fdd9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.tabbar-brand-sep{height:1px;background:#ffffff12;margin:2px 12px;flex-shrink:0}.tabbar-spacer{flex:1}.tabbar-collapse-btn{display:flex;align-items:center;gap:8px;padding:9px 14px;border:none;background:transparent;cursor:pointer;color:#ffffff4d;font-family:var(--font);font-size:12px;transition:all var(--transition);width:100%;text-align:left;flex-shrink:0}.tabbar-collapse-btn:hover{color:#ffffffbf;background:#ffffff0d}.tab{position:relative;display:flex;align-items:center;gap:10px;padding:10px 12px 10px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);color:#ffffff73;font-size:13px;font-weight:500;letter-spacing:.01em;width:100%;overflow:hidden}.tab:hover{background:#ffffff12;color:#ffffffc7}.tab--active{background:#ffffff17;color:#fffffff2;font-weight:600}.tab-icon{display:flex;align-items:center;flex-shrink:0;opacity:.6;transition:opacity var(--transition)}.tab--active .tab-icon{opacity:1}.tab:hover .tab-icon{opacity:.85}.tab-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tab-close{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;border:none;background:transparent;cursor:pointer;color:#fff6;opacity:0;transition:all var(--transition);flex-shrink:0}.tab:hover .tab-close,.tab--active .tab-close{opacity:1}.tab-close:hover{background:#ffffff1a;color:#ffffffe6}.tab-indicator{position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:0 2px 2px 0;box-shadow:2px 0 12px var(--tab-color, #7C3AED);filter:brightness(1.2)}.tab-pending-badge{font-size:10px;font-weight:700;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;padding:1px 5px;border-radius:999px;min-width:18px;text-align:center;flex-shrink:0;box-shadow:0 2px 8px #f9731680}.tab-add-container{position:relative;width:100%}.tab-add-btn{display:flex;align-items:center;gap:8px;padding:9px 12px 9px 14px;width:100%;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;color:#ffffff4d;transition:all var(--transition);font-family:var(--font);font-size:12px}.tab-add-btn:hover{background:#ffffff0f;color:#ffffffb3}.tab-add-menu{z-index:500;background:#14192e;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);box-shadow:0 16px 48px #0009,0 0 0 1px #7c3aed26;padding:8px;min-width:190px;animation:slideDown .15s ease}.tab-add-menu-title{font-size:10px;font-weight:700;color:#ffffff4d;text-transform:uppercase;letter-spacing:.08em;padding:4px 8px 8px}.tab-add-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border:none;background:transparent;cursor:pointer;border-radius:var(--radius-sm);font-size:13px;color:#ffffffbf;font-family:var(--font);transition:all var(--transition);text-align:left}.tab-add-menu-item:hover{background:#7c3aed26;color:#fffffff2}.sidebar{display:flex;flex-direction:row;align-items:center;height:56px;background:var(--sidebar-bg);border-bottom:1px solid var(--sidebar-border);flex-shrink:0;padding:0 8px 0 16px;gap:0;overflow:visible;box-shadow:0 2px 20px #0000004d;--text-primary: rgba(255,255,255,.92);--text-secondary: rgba(255,255,255,.55);--text-tertiary: rgba(255,255,255,.3);--text-muted: rgba(255,255,255,.25);--bg: rgba(255,255,255,.04);--border: rgba(255,255,255,.07);--surface: #141A38;--surface-raised: #1C2245;--primary-light: rgba(124,58,237,.2)}.sidebar-page-title{display:flex;align-items:center;flex-shrink:0;margin-right:4px}.sidebar-page-title-text{font-size:14px;font-weight:700;color:#ffffffd9;white-space:nowrap;letter-spacing:-.2px}.sidebar-header-sep{width:1px;height:22px;background:#ffffff17;margin:0 10px;flex-shrink:0}.sidebar-nav{display:flex;flex-direction:row;align-items:center;gap:3px;padding:0;flex-shrink:0}.sidebar-nav-item{display:flex;align-items:center;gap:6px;padding:6px 12px;border:none;background:transparent;cursor:pointer;color:#ffffff73;font-family:var(--font);font-size:12.5px;font-weight:500;transition:all var(--transition);border-radius:var(--radius-full);white-space:nowrap}.sidebar-nav-item:hover{background:#ffffff14;color:#ffffffe0}.sidebar-nav-item--active{background:linear-gradient(135deg,#7c3aed59,#6366f138);color:#c4b5fd;font-weight:600;box-shadow:0 0 16px #7c3aed40,inset 0 1px #ffffff1a;border:1px solid rgba(124,58,237,.4)}.sidebar-nav-icon{font-size:14px;flex-shrink:0;line-height:1}.sidebar-nav-label{white-space:nowrap}.sidebar-spacer{flex:1}.sidebar-user{display:flex;align-items:center;gap:8px;flex-shrink:0;padding:0}.sidebar-user-info{display:flex;flex-direction:column;gap:1px;overflow:hidden;min-width:0}.sidebar-user-name{font-size:12px;font-weight:600;color:#ffffffe0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-signout{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;color:#ffffff4d;transition:all var(--transition);flex-shrink:0}.sidebar-signout:hover{color:#f87171;background:#ef44441f}.header-role-preview-btn{display:flex!important;align-items:center!important;gap:6px!important;padding:5px 10px!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:var(--radius-sm)!important;background:#ffffff0d!important;width:auto!important;font-family:var(--font)!important;text-align:left!important}.header-role-preview-btn:hover{background:#ffffff1a!important;border-color:#fff3!important}.header-role-preview-btn.role-preview-btn--active{background:color-mix(in srgb,var(--preview-color, #6C63FF) 15%,transparent)!important;border-color:color-mix(in srgb,var(--preview-color, #6C63FF) 40%,transparent)!important;color:var(--preview-color, #6C63FF)!important}.header-store-switcher{position:relative;flex-shrink:0}.header-store-btn{display:flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);background:#ffffff0d;cursor:pointer;color:#ffffffa6;font-family:var(--font);transition:all var(--transition);font-size:12px}.header-store-btn:hover{background:#ffffff1a;color:#ffffffe6;border-color:#fff3}.header-store-dropdown{z-index:500;background:#14192e;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);box-shadow:0 16px 48px #0009,0 0 0 1px #7c3aed1f;padding:6px;min-width:200px;animation:slideDown .15s ease}.page{padding:24px 28px;min-height:100%;animation:pageFadeIn .2s ease}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-title{font-size:24px;font-weight:800;color:var(--text-primary);letter-spacing:-.6px}.page-subtitle{font-size:13px;color:var(--text-tertiary);margin-top:2px}.page-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;height:34px;border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all var(--transition);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;border-color:transparent;box-shadow:0 2px 10px #7c3aed66}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,#6d28d9,#4338ca);box-shadow:0 4px 18px #7c3aed80;transform:translateY(-1px)}.btn--primary:active:not(:disabled){transform:translateY(0)}.btn--ghost{background:transparent;color:var(--text-secondary);border-color:var(--border)}.btn--ghost:hover:not(:disabled){background:var(--bg);color:var(--text-primary);border-color:var(--border-strong)}.btn--danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:transparent;box-shadow:0 2px 8px #ef44444d}.btn--danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 14px #ef444466;transform:translateY(-1px)}.btn--sm{height:28px;padding:0 10px;font-size:12px}.btn--full{width:100%}.btn--icon{width:32px;height:32px;padding:0}.btn--google{background:#ffffff0f;color:#ffffffd9;border-color:#ffffff1f;font-weight:500}.btn--google:hover:not(:disabled){background:#ffffff1a;border-color:#fff3}.form-group{display:flex;flex-direction:column;gap:5px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-label{font-size:12.5px;font-weight:600;color:var(--text-secondary)}.form-input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;color:var(--text-primary);background:var(--surface);transition:all var(--transition);outline:none;width:100%}.form-input:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed2e}.form-input::placeholder{color:var(--text-tertiary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal,.modal-box{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:480px;max-width:calc(100vw - 32px);animation:slideUp .18s ease;max-height:90vh;display:flex;flex-direction:column}.modal--sm{width:380px}.modal-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;cursor:pointer;color:var(--text-tertiary);font-size:14px;transition:all var(--transition);flex-shrink:0}.modal-close:hover{background:#ef44441a;color:#f87171;border-color:#ef444440}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:none;opacity:1}}@keyframes slideDown{0%{transform:translateY(-8px);opacity:0}to{transform:none;opacity:1}}@keyframes slideRight{0%{transform:translate(-8px);opacity:0}to{transform:none;opacity:1}}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:16px;font-weight:700;letter-spacing:-.2px}.modal-date{font-size:12px;color:var(--text-tertiary)}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:transparent}.login-bg{min-height:100vh;background:#060914;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden}.login-card{background:#101430d9;backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-xl);box-shadow:0 32px 80px #000000b3,0 0 0 1px #7c3aed1f,inset 0 1px #ffffff0f;padding:40px;width:100%;max-width:440px;position:relative;z-index:1;animation:slideUp .35s cubic-bezier(.4,0,.2,1);--text-primary: rgba(255,255,255,.94);--text-secondary: rgba(255,255,255,.6);--text-tertiary: rgba(255,255,255,.35);--border: rgba(255,255,255,.1);--surface: rgba(255,255,255,.05);--bg: rgba(255,255,255,.03);--primary-light: rgba(124,58,237,.18)}.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:32px}.login-logo{flex-shrink:0}.login-title{font-size:22px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,#fff 40%,#c4b5fde6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{font-size:12px;color:#ffffff59;margin-top:2px}.login-heading{font-size:20px;font-weight:700;letter-spacing:-.3px;color:#fffffff0}.login-desc{font-size:13px;color:#ffffff80;margin-top:4px;margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:14px}.login-error{background:#ef44441a;color:#fca5a5;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-sm);padding:10px 12px;font-size:13px}.login-success{background:#10b9811a;color:#6ee7b7;border:1px solid rgba(16,185,129,.25);border-radius:var(--radius-sm);padding:10px 12px;font-size:13px;margin-bottom:12px}.login-forgot{background:none;border:none;color:#a78bfa;cursor:pointer;font-size:12px;font-family:var(--font);text-align:right;padding:0;margin-top:-6px;transition:color var(--transition)}.login-forgot:hover{color:#c4b5fd;text-decoration:underline}.login-back{background:none;border:none;color:#fff6;cursor:pointer;font-size:13px;font-family:var(--font);margin-top:16px;padding:0;display:block;transition:color var(--transition)}.login-back:hover{color:#ffffffbf}.login-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:#ffffff40;font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#ffffff14}.login-blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.login-blob--1{width:500px;height:500px;top:-150px;left:-120px;background:radial-gradient(circle,rgba(124,58,237,.6),transparent 70%);opacity:.7;animation:blobFloat1 8s ease-in-out infinite}.login-blob--2{width:380px;height:380px;bottom:-100px;right:-80px;background:radial-gradient(circle,rgba(79,70,229,.5),transparent 70%);opacity:.6;animation:blobFloat2 10s ease-in-out infinite}.login-blob--3{width:280px;height:280px;top:35%;right:8%;background:radial-gradient(circle,rgba(14,165,233,.4),transparent 70%);opacity:.5;animation:blobFloat3 7s ease-in-out infinite}@keyframes blobFloat1{0%,to{transform:translate(0) scale(1)}50%{transform:translate(20px,30px) scale(1.05)}}@keyframes blobFloat2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-25px,-20px) scale(1.08)}}@keyframes blobFloat3{0%,to{transform:translate(0) scale(1)}50%{transform:translate(15px,-25px) scale(.95)}}.schedule-page{padding:20px 24px}.week-nav{display:flex;gap:2px}.schedule-grid-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);position:relative}.schedule-grid{display:grid;grid-template-columns:180px repeat(7,1fr);overflow-x:auto;min-width:0}.schedule-col-header{padding:10px 8px;text-align:center;border-bottom:2px solid var(--border);background:var(--bg);border-right:1px solid var(--border);position:sticky;top:0;z-index:5}.schedule-col-header:last-child{border-right:none}.schedule-col-header--today{background:linear-gradient(180deg,#7c3aed12,#7c3aed05);border-bottom-color:#7c3aed4d!important}.schedule-name-col{text-align:left}.schedule-day-name{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em}.schedule-day-num{font-size:18px;font-weight:700;color:var(--text-primary);margin-top:2px}.schedule-day-num--today{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:14px;margin:2px auto 0;box-shadow:0 2px 8px #7c3aed73}.schedule-name-cell{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border);border-right:2px solid var(--border);background:var(--surface);position:sticky;left:0;z-index:2}.emp-avatar-sm{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.emp-name{font-size:12.5px;font-weight:600;color:var(--text-primary)}.emp-jobcode{font-size:10.5px;color:var(--text-tertiary)}.emp-name-info{min-width:0;overflow:hidden}.schedule-cell{padding:6px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);min-height:52px;display:flex;flex-direction:column;gap:3px;cursor:pointer;transition:background var(--transition)}.schedule-cell:hover{background:var(--bg)}.schedule-cell:last-child{border-right:none}.schedule-cell--today{background:#7c3aed0a}.schedule-cell-add{display:flex;align-items:center;justify-content:center;height:100%;opacity:0;transition:opacity var(--transition);color:var(--text-tertiary);flex:1;min-height:30px}.schedule-cell:hover .schedule-cell-add{opacity:1}.shift-chip{padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600;border:1px solid;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.01em}.schedule-empty{padding:48px 24px}.schedule-legend{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}.legend-item{display:flex;align-items:center}.legend-dot{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;border:1px solid}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 20px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:all var(--transition)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#7c3aed,#0ea5e9)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-value{font-size:30px;font-weight:800;letter-spacing:-.8px;background:linear-gradient(135deg,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:12px;color:var(--text-tertiary);margin-top:4px;font-weight:500}.search-box{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 10px;color:var(--text-tertiary)}.search-input{border:none;background:transparent;outline:none;font-family:var(--font);font-size:13px;color:var(--text-primary);padding:7px 0;width:200px}.search-input::placeholder{color:var(--text-tertiary)}.emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.emp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:0;box-shadow:var(--shadow-sm);transition:all .22s cubic-bezier(.4,0,.2,1);position:relative}.emp-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:linear-gradient(90deg,#7c3aed,#0ea5e9);opacity:0;transition:opacity var(--transition);pointer-events:none}.emp-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--border-strong)}.emp-card:hover:after{opacity:1}.emp-card-header{display:flex;align-items:flex-start;gap:10px;padding:16px 14px 12px}.emp-card-info{flex:1;min-width:0}.emp-card-name{font-size:14px;font-weight:700;color:var(--text-primary)}.emp-card-email{font-size:11.5px;color:var(--text-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.emp-card-menu-container{position:relative}.emp-card-menu{position:absolute;right:0;top:100%;z-index:500;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000004d;padding:4px;min-width:140px}.emp-card-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;background:transparent;cursor:pointer;color:var(--text-primary);font-family:var(--font);font-size:13px;border-radius:var(--radius-sm);transition:background var(--transition);text-align:left}.emp-card-menu-item:hover{background:var(--bg)}.emp-card-menu-item--danger{color:#ef4444}.emp-card-menu-item--danger:hover{background:#ef44441a}.emp-card-body{padding:12px 14px 14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.emp-card-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:11.5px;font-weight:700;border:1px solid;letter-spacing:.04em;width:fit-content}.emp-card-vac-label{display:flex;justify-content:space-between;font-size:11.5px;color:var(--text-secondary);margin-bottom:5px}.emp-card-vac-bar{height:5px;background:var(--bg);border-radius:3px;overflow:hidden;border:1px solid var(--border)}.emp-card-vac-fill{height:100%;border-radius:3px;transition:width .4s ease}.settings-content{display:flex;flex-direction:column;gap:24px;max-width:720px}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition)}.settings-section:hover{box-shadow:var(--shadow-md)}.settings-section-header{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--bg)}.settings-section-title{font-size:14px;font-weight:700;color:var(--text-primary)}.settings-section-desc{font-size:12px;color:var(--text-tertiary);margin-top:2px}.settings-section-body{padding:4px 0}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-row-info{flex:1;min-width:0}.settings-row-label{font-size:13.5px;font-weight:500;color:var(--text-primary)}.settings-row-desc{font-size:12px;color:var(--text-tertiary);margin-top:2px}.settings-row-control{flex-shrink:0}.settings-value{font-size:13px;color:var(--text-secondary)}.settings-avatar-row{display:flex;align-items:center;gap:10px}.toggle{width:44px;height:24px;border-radius:var(--radius-full);background:var(--border);border:none;cursor:pointer;position:relative;transition:all .2s;flex-shrink:0}.toggle--on{background:linear-gradient(135deg,#7c3aed,#4f46e5);box-shadow:0 2px 8px #7c3aed66}.toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s cubic-bezier(.4,0,.2,1)}.toggle--on .toggle-thumb{transform:translate(20px)}.segmented-control{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;gap:2px}.seg-btn{padding:5px 14px;border:none;border-radius:5px;cursor:pointer;font-family:var(--font);font-size:12.5px;font-weight:500;color:var(--text-secondary);background:transparent;transition:all var(--transition)}.seg-btn--active{background:var(--surface);color:var(--text-primary);font-weight:600;box-shadow:var(--shadow-sm)}html.dark .seg-btn--active{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;box-shadow:0 2px 8px #7c3aed66}.placeholder-page{display:flex;align-items:center;justify-content:center;min-height:80vh}.placeholder-content{text-align:center;max-width:440px}.placeholder-icon{width:100px;height:100px;border-radius:var(--radius-xl);border:2px solid;display:flex;align-items:center;justify-content:center;margin:0 auto 24px}.placeholder-title{font-size:24px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px}.placeholder-desc{font-size:14px;color:var(--text-secondary);margin-top:10px;line-height:1.6}.placeholder-features{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-top:24px;text-align:left}.placeholder-features-title{font-size:12px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}.placeholder-feature-list{display:flex;flex-direction:column;gap:8px}.placeholder-feature{font-size:13.5px;color:var(--text-secondary);display:flex;gap:8px}.placeholder-badge{display:inline-flex;align-items:center;gap:8px;margin-top:24px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-full);padding:6px 14px;font-size:12.5px;color:var(--text-secondary)}.placeholder-dot{width:8px;height:8px;border-radius:50%}.sidebar-view-mode{display:flex;align-items:center;gap:3px;padding:5px 8px 3px}.sidebar-view-mode-btn{width:24px;height:24px;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;cursor:pointer;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff6;transition:all var(--transition);flex-shrink:0}.sidebar-view-mode-btn:hover{background:#7c3aed33;color:#c4b5fd;border-color:#7c3aed66}.sidebar-view-mode-btn--active{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;border-color:transparent;box-shadow:0 2px 8px #7c3aed66}.sidebar-view-mode-label{flex:1;font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding-left:4px}.sidebar-store-dropdown-patch-header{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:6px 10px 3px;opacity:.7}.sidebar-store-single{display:flex;align-items:center;gap:8px;padding:7px 14px;overflow:hidden}.sidebar-store-switcher{position:relative;padding:4px 8px}.sidebar-store-btn{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border:none;background:#ffffff0a;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font);color:#ffffff8c;transition:all var(--transition);border:1px solid rgba(255,255,255,.08)}.sidebar-store-btn:hover{background:#7c3aed26;color:#c4b5fd;border-color:#7c3aed59}.sidebar-store-dropdown{position:absolute;top:calc(100% + 4px);left:8px;right:8px;z-index:200;background:#141a38;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);box-shadow:0 16px 48px #000000b3,0 0 0 1px #7c3aed1f;padding:6px;animation:slideUp .15s ease}.sidebar-store-dropdown-label{font-size:10px;font-weight:700;color:#ffffff4d;text-transform:uppercase;letter-spacing:.07em;padding:4px 8px 6px}.sidebar-store-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;background:transparent;cursor:pointer;border-radius:var(--radius-sm);font-family:var(--font);transition:all var(--transition);color:#ffffffa6}.sidebar-store-option:hover{background:#ffffff0f;color:#ffffffe6}.sidebar-store-option--active{background:#7c3aed33;color:#c4b5fd}.tabbar-admin-btn{display:flex;align-items:center;gap:8px;padding:9px 14px;width:100%;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;color:#ffffff59;font-family:var(--font);font-size:12px;font-weight:500;transition:all var(--transition);flex-shrink:0;position:relative;text-align:left}.tabbar-admin-btn:hover{background:#ef44441f;color:#fca5a5}.tabbar-admin-label{white-space:nowrap;flex:1}.tabbar-admin-badge{width:7px;height:7px;border-radius:50%;background:#ef4444;box-shadow:0 0 6px #ef4444b3;flex-shrink:0}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:500;animation:fadeIn .2s ease}.admin-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:501;display:flex;flex-direction:column;background:#080c18;animation:slideInPanel .25s cubic-bezier(.4,0,.2,1);--text-primary: #F1F5F9;--text-secondary: #8B9DC3;--text-tertiary: #4E6088;--text-muted: #4E6088;--bg: #0C1020;--surface: #121828;--surface-raised: #1A2238;--border: #1E2A42;--border-strong: #2D3E5C;--primary-light: rgba(124,58,237,.18)}@keyframes slideInPanel{0%{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}.admin-panel-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:60px;flex-shrink:0;background:linear-gradient(135deg,#0e1628,#080c18);border-bottom:1px solid rgba(255,255,255,.06);box-shadow:0 1px 20px #0006}.admin-panel-brand{display:flex;align-items:center;gap:12px}.admin-panel-logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#ef4444,#f59e0b);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #ef444473}.admin-panel-title{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.3px}.admin-panel-sub{font-size:11px;color:#fff6;font-weight:500}.admin-panel-header-right{display:flex;align-items:center;gap:16px}.admin-panel-user{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.admin-panel-close{width:32px;height:32px;border-radius:var(--radius-sm);background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#ffffffb3;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.admin-panel-close:hover{background:#ffffff26;color:#fff}.admin-panel-body{display:flex;flex:1;overflow:hidden}.admin-panel-nav{width:200px;flex-shrink:0;background:#0a0e1c;border-right:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;padding:16px 8px}.admin-nav-item{position:relative;display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:none;background:transparent;cursor:pointer;color:#ffffff73;font-family:var(--font);font-size:13px;font-weight:500;text-align:left;transition:all var(--transition);border-radius:var(--radius-sm)}.admin-nav-item:hover{color:#ffffffd9;background:#ffffff0f}.admin-nav-item--active{color:#fca5a5;background:linear-gradient(135deg,#ef44442e,#f59e0b14)}.admin-nav-icon{display:flex;align-items:center;flex-shrink:0}.admin-nav-label{flex:1}.admin-nav-indicator{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:70%;background:linear-gradient(180deg,#ef4444,#f59e0b);border-radius:0 3px 3px 0;box-shadow:0 0 8px #ef444480}.admin-panel-version{display:flex;align-items:center;gap:6px;padding:16px 20px 8px;font-size:10px;color:#fff3}.admin-panel-content{flex:1;overflow-y:auto;background:var(--bg);padding:0}.admin-panel-content::-webkit-scrollbar{width:6px}.admin-panel-content::-webkit-scrollbar-track{background:transparent}.admin-panel-content::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}.admin-section{padding:28px 32px}.admin-section-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.admin-section-title{font-size:20px;font-weight:800;color:var(--text-primary);letter-spacing:-.4px}.admin-section-subtitle{font-size:13px;color:var(--text-tertiary);margin-top:3px}.admin-search-bar{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:0 12px;margin-bottom:20px;height:40px;box-shadow:var(--shadow-sm);transition:border-color var(--transition)}.admin-search-bar:focus-within{border-color:#ef444466;box-shadow:0 0 0 3px #ef44441a}.admin-search-input{flex:1;border:none;background:transparent;outline:none;font-family:var(--font);font-size:13px;color:var(--text-primary)}.admin-search-input::placeholder{color:var(--text-tertiary)}.admin-filters{display:flex;align-items:center;gap:10px;margin-bottom:20px}.admin-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 16px;height:36px;border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all var(--transition);white-space:nowrap}.admin-btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.admin-btn--primary{background:linear-gradient(135deg,#ef4444,#f59e0b);color:#fff;border-color:transparent;box-shadow:0 2px 8px #ef44444d}.admin-btn--primary:hover:not(:disabled){box-shadow:0 4px 16px #ef444466;transform:translateY(-1px)}.admin-btn--ghost{background:transparent;color:var(--text-secondary);border-color:var(--border)}.admin-btn--ghost:hover:not(:disabled){background:var(--bg);color:var(--text-primary)}.admin-btn--danger{background:#ef4444;color:#fff}.admin-btn--danger:hover:not(:disabled){background:#dc2626}.admin-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-secondary);transition:all var(--transition)}.admin-icon-btn:hover{background:var(--surface-raised);color:var(--text-primary);border-color:var(--border-strong)}.admin-icon-btn--danger:hover{background:#ef44441f;color:#f87171;border-color:#ef44444d}.admin-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 24px;text-align:center;color:var(--text-tertiary);font-size:14px}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.admin-store-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px;transition:all var(--transition);position:relative;overflow:hidden}.admin-store-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#ef4444,#f59e0b);opacity:0;transition:opacity var(--transition)}.admin-store-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--border-strong)}.admin-store-card:hover:before{opacity:1}.admin-store-card-header{display:flex;align-items:flex-start;gap:12px}.admin-store-name{font-size:15px;font-weight:700;color:var(--text-primary)}.admin-store-address{font-size:12px;color:var(--text-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-store-meta{display:flex;flex-wrap:wrap;gap:8px}.admin-meta-item{display:flex;align-items:center;gap:4px;font-size:11.5px;color:var(--text-secondary)}.admin-store-managers{display:flex;align-items:center;gap:8px}.admin-manager-label{font-size:11px;color:var(--text-tertiary);white-space:nowrap}.admin-store-actions{display:flex;gap:6px;padding-top:10px;border-top:1px solid var(--border)}.admin-action-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-family:var(--font);font-size:11.5px;font-weight:500;color:var(--text-secondary);transition:all var(--transition)}.admin-action-btn:hover{background:var(--surface-raised);color:var(--text-primary);border-color:var(--border-strong)}.admin-action-btn--danger:hover{background:#ef44441f;color:#f87171;border-color:#ef44444d}.admin-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.admin-status-badge--active{background:#10b9811f;color:#6ee7b7;border:1px solid rgba(16,185,129,.25)}.admin-status-badge--inactive{background:#f59e0b1f;color:#fcd34d;border:1px solid rgba(245,158,11,.25)}.admin-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);position:relative}.admin-table{width:100%;border-collapse:collapse;border-radius:var(--radius-lg)}.admin-table th{text-align:left;padding:11px 16px;font-size:11px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;background:var(--bg);border-bottom:1px solid var(--border)}.admin-table th:first-child{border-radius:var(--radius-lg) 0 0 0}.admin-table th:last-child{border-radius:0 var(--radius-lg) 0 0}.admin-table td{padding:12px 16px;border-bottom:1px solid var(--border)}.admin-table-row:last-child td{border-bottom:none}.admin-table-row:last-child td:first-child{border-radius:0 0 0 var(--radius-lg)}.admin-table-row:last-child td:last-child{border-radius:0 0 var(--radius-lg) 0}.admin-table-row{transition:background var(--transition)}.admin-table-row:hover td{background:var(--bg)}.admin-store-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;background:var(--primary-light);color:var(--primary);border:1px solid rgba(108,99,255,.2);white-space:nowrap}.admin-store-tag--more{background:var(--bg);color:var(--text-secondary);border-color:var(--border)}.admin-form{display:flex;flex-direction:column;gap:16px}.admin-form-group{display:flex;flex-direction:column;gap:5px}.admin-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.admin-label{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.admin-input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;color:var(--text-primary);background:var(--surface);outline:none;width:100%;transition:all var(--transition)}.admin-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6c63ff1f}.admin-input::placeholder{color:var(--text-tertiary)}.admin-select{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;color:var(--text-primary);background:var(--surface);outline:none;width:100%;cursor:pointer;transition:border-color var(--transition)}.admin-select:focus{border-color:var(--primary)}.admin-select--sm{width:auto;height:40px;padding:0 10px}.admin-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:600;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .15s ease}.admin-modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:0 24px 64px #0003;max-width:calc(100vw - 32px);max-height:calc(100vh - 64px);display:flex;flex-direction:column;animation:slideUp .2s ease}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.admin-modal-title{font-size:16px;font-weight:800;color:var(--text-primary);letter-spacing:-.2px}.admin-modal-close{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.admin-modal-close:hover{background:#ef44441f;color:#ef4444;border-color:#ef44444d}.admin-modal-body{padding:20px 24px;overflow-y:auto}.admin-role-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.admin-role-option{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;text-align:left;transition:all var(--transition);font-family:var(--font)}.admin-role-option:hover{border-color:var(--role-color, var(--primary));background:var(--bg)}.admin-role-option--active{border-color:var(--role-color, var(--primary));background:color-mix(in srgb,var(--role-color, var(--primary)) 12%,transparent)}.admin-role-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:3px}.admin-multi-select{display:flex;flex-direction:column;gap:4px;border:1px solid var(--border);border-radius:var(--radius-md);padding:8px;max-height:180px;overflow-y:auto;background:var(--bg)}.admin-check-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);font-size:13px}.admin-check-row:hover{background:var(--surface-raised)}.admin-check-row input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:var(--primary)}.admin-status-pill{padding:6px 14px;border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--surface);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;color:var(--text-secondary);transition:all var(--transition)}.admin-status-pill--active{border-color:#22c55e80;color:#6ee7b7;background:#10b98124}.admin-status-pill--inactive{border-color:#f59e0b80;color:#fcd34d;background:#f59e0b24}.admin-roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:20px}.admin-role-card{background:var(--surface);border:1.5px solid color-mix(in srgb,var(--role-color) 30%,transparent);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.admin-role-card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.admin-role-perms{display:flex;flex-direction:column;gap:6px}.admin-role-perm{display:flex;align-items:flex-start;gap:8px;font-size:12.5px;color:var(--text-secondary)}.admin-roles-note{display:flex;align-items:flex-start;gap:8px;background:var(--primary-light);border:1px solid rgba(108,99,255,.2);border-radius:var(--radius-md);padding:12px 16px;font-size:12.5px;color:var(--primary);line-height:1.5}.admin-patch-card{background:var(--surface);border:1.5px solid;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px;transition:all var(--transition)}.admin-patch-card:hover{box-shadow:var(--shadow-md)}.admin-patch-card-header{display:flex;align-items:center;gap:12px}.admin-patch-icon{width:40px;height:40px;border-radius:10px;border:1.5px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-patch-stores{display:flex;flex-wrap:wrap;gap:8px}.admin-patch-store-chip{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--radius-sm);border:1px solid;font-size:12px}.admin-patch-staff{padding-top:12px;border-top:1px solid var(--border)}.admin-access-type-toggle{display:flex;gap:6px;margin-bottom:4px}.admin-access-type-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 14px;border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;font-family:var(--font);font-size:12.5px;font-weight:600;color:var(--text-secondary);transition:all var(--transition)}.admin-access-type-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.admin-access-type-btn--active{border-color:var(--primary);color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 2px #6c63ff1f}.admin-access-type-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;width:fit-content}.admin-access-type-badge--stores{background:#6366f126;color:#a5b4fc;border:1px solid rgba(99,102,241,.3)}.admin-access-type-badge--patches{background:#f59e0b26;color:#fcd34d;border:1px solid rgba(245,158,11,.3)}.admin-info-callout{display:flex;align-items:flex-start;gap:8px;background:#6366f11a;border:1px solid rgba(99,102,241,.25);border-radius:var(--radius-md);padding:12px 16px;font-size:12.5px;color:#a5b4fc;line-height:1.5;margin-bottom:20px}.admin-color-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.admin-color-swatch{width:28px;height:28px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0}.admin-color-swatch:hover{transform:scale(1.15)}.admin-color-swatch--active{border-color:#fff;box-shadow:0 0 0 2px #00000040;transform:scale(1.1)}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffc;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:10;font-size:13px;color:var(--text-secondary);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading-center{display:flex;align-items:center;justify-content:center;gap:12px;padding:60px;font-size:13px;color:var(--text-secondary)}.spinner{width:24px;height:24px;border-radius:50%;border:2.5px solid var(--border);border-top-color:var(--primary);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 24px;text-align:center;color:var(--text-tertiary);font-size:13.5px}.schedule-apply-tmpl-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;cursor:pointer;color:var(--text-tertiary);flex-shrink:0;transition:all var(--transition);opacity:0}.schedule-name-cell:hover .schedule-apply-tmpl-btn{opacity:1}.schedule-apply-tmpl-btn:hover{background:#6366f124;color:var(--primary);border-color:#6366f166}.schedule-apply-tmpl-btn:disabled{opacity:.5;cursor:wait}.sched-view-toggle{display:flex;align-items:center;background:var(--bg, #F8FAFC);border:1px solid var(--border, #E2E8F0);border-radius:8px;padding:2px;gap:2px}.sched-toggle-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:6px;border:none;background:none;cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600;color:var(--text-secondary, #64748B);transition:background .15s,color .15s}.sched-toggle-btn--active{background:var(--surface-raised);color:var(--primary, #6366F1);box-shadow:0 1px 4px #0003}.sched-toggle-btn:hover:not(.sched-toggle-btn--active){background:var(--surface-raised, #F1F5F9)}.sched-layout-btn{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600}.month-week-stack{display:flex;flex-direction:column;gap:0}.month-week-block{border-bottom:2px solid var(--border, #E2E8F0)}.month-week-block:last-child{border-bottom:none}.month-week-label{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--surface, #F8FAFC);border-bottom:1px solid var(--border, #E2E8F0)}.month-week-badge{display:inline-flex;align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:20px}.month-week-range{font-size:12px;color:var(--text-tertiary, #94A3B8);font-weight:500}.schedule-cell--locked{cursor:default!important;pointer-events:none;opacity:.85}.schedule-cell--runner{border-left:3px solid var(--runner-color, #FF9800)!important;background-color:color-mix(in srgb,var(--runner-color, #FF9800) 10%,transparent)!important;position:relative}.schedule-cell--runner:after{content:"";position:absolute;top:4px;right:4px;width:6px;height:6px;border-radius:50%;background:var(--runner-color, #FF9800);opacity:.75;pointer-events:none}.schedule-week-row-header{display:flex;align-items:center;gap:10px;padding:7px 14px;background:var(--surface, #F8FAFC);border-top:2px solid var(--border, #E2E8F0);border-bottom:1px solid var(--border, #E2E8F0)}.schedule-week-row-header:first-child{border-top:none}.schedule-cell--compact{min-height:42px;padding:3px}.schedule-cell--compact .schedule-cell-add{opacity:0}.schedule-cell--compact:hover .schedule-cell-add{opacity:1}.schedule-cell--compact .shift-chip{font-size:9px;padding:1px 4px}.schedule-emp-col-header{flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:4px;padding:8px 6px}.schedule-emp-col-header .emp-avatar-sm{margin:0}.schedule-emp-col-header .emp-name{text-align:center}.schedule-day-label-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;background:var(--surface, #F8FAFC);border-right:1px solid var(--border, #E2E8F0);border-bottom:1px solid var(--border, #E2E8F0);min-height:52px}.schedule-day-label-cell--today{background:#6366f11f}.schedule-day-label-cell--today .schedule-day-name{color:var(--primary, #6366F1)}.apply-toast{display:flex;align-items:center;gap:8px;background:#10b9811f;color:#6ee7b7;border:1px solid rgba(16,185,129,.3);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-bottom:12px;font-weight:500;animation:fadeIn .2s ease}.shift-ctx-menu{background:var(--surface-raised, #fff);border:1px solid var(--border, #E2E8F0);border-radius:10px;box-shadow:0 8px 32px #00000024,0 2px 8px #00000014;min-width:210px;overflow:hidden;animation:fadeIn .12s ease;-webkit-user-select:none;user-select:none}.shift-ctx-header{display:flex;align-items:center;gap:7px;padding:9px 14px 7px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary, #94A3B8);border-bottom:1px solid var(--border, #E2E8F0)}.shift-ctx-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;cursor:pointer;font-family:var(--font);font-size:13px;color:var(--text-primary, #0F172A);text-align:left;transition:background .12s}.shift-ctx-item:hover{background:#ef44441a}.shift-ctx-item:hover .shift-ctx-item-label{color:#fca5a5}.shift-ctx-item+.shift-ctx-item{border-top:1px solid var(--border, #E2E8F0)}.shift-ctx-item-badge{flex-shrink:0;padding:2px 7px;border-radius:4px;border:1px solid;font-size:10px;font-weight:700;letter-spacing:.02em;white-space:nowrap}.shift-ctx-item-label{flex:1;font-weight:500;color:var(--text-secondary, #475569);transition:color .12s}.shift-ctx-divider{height:1px;background:var(--border, #E2E8F0);margin:2px 0}.shift-ctx-item--off:hover{background:var(--surface-raised)}.shift-ctx-item--off:hover .shift-ctx-item-label{color:var(--text-secondary)}.preset-chips{display:flex;gap:6px;flex-wrap:wrap}.preset-chip{display:inline-flex;flex-direction:column;align-items:center;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600;color:var(--text-primary);transition:all var(--transition);gap:2px}.preset-chip:hover{background:#6366f124;border-color:#6366f166;color:var(--primary)}.preset-chip-time{font-size:10px;color:var(--text-tertiary);font-weight:400}.templates-page{padding-bottom:48px}.tmpl-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:2px solid var(--border);padding-bottom:0}.tmpl-tab{display:flex;align-items:center;gap:7px;padding:9px 14px;border:none;background:transparent;cursor:pointer;font-family:var(--font);font-size:13.5px;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;position:relative;bottom:-2px;border-bottom:2px solid transparent;transition:all var(--transition)}.tmpl-tab:hover{color:var(--text-primary);background:var(--bg)}.tmpl-tab--active{color:var(--primary);font-weight:600;border-bottom:2px solid var(--primary)}.tmpl-tab-count{background:var(--border);color:var(--text-secondary);border-radius:10px;padding:1px 6px;font-size:11px;font-weight:600}.tmpl-tab--active .tmpl-tab-count{background:var(--primary-light);color:var(--primary)}.tmpl-section-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;gap:12px}.tmpl-section-title{font-size:15px;font-weight:700;color:var(--text-primary)}.tmpl-section-desc{font-size:12.5px;color:var(--text-tertiary);margin-top:3px}.wt-grid-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.wt-grid{width:100%;border-collapse:collapse;table-layout:auto}.wt-th{padding:10px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);background:var(--bg);border-bottom:2px solid var(--border);text-align:center;white-space:nowrap}.wt-name-th{text-align:left;min-width:160px}.wt-actions-th{width:40px}.wt-row{cursor:pointer;transition:background var(--transition)}.wt-row:hover{background:var(--bg)}.wt-row:not(:last-child) td{border-bottom:1px solid var(--border)}.wt-row--empty{opacity:.7}.wt-td{padding:10px 12px;vertical-align:middle}.wt-day-td,.wt-edit-td{text-align:center}.wt-emp{display:flex;align-items:center;gap:9px}.wt-emp-name{font-size:13px;font-weight:600;color:var(--text-primary)}.wt-emp-code{font-size:11px;color:var(--text-tertiary);margin-top:1px}.wt-edit-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-tertiary);transition:all var(--transition);opacity:0}.wt-row:hover .wt-edit-btn{opacity:1}.wt-edit-btn:hover{background:#6366f124;color:var(--primary)}.day-chip{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10.5px;font-weight:600;white-space:nowrap}.day-chip--off{background:#ef444426;color:#fca5a5}.day-chip--shift{background:#6366f126;color:#a5b4fc;font-size:10px}.day-chip--blank{background:transparent;color:var(--text-tertiary);font-weight:400}.wt-editor-modal{width:620px;max-height:88vh}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-tertiary);transition:all var(--transition)}.modal-close-btn:hover{background:var(--bg);color:var(--text-primary)}.wt-editor-info{display:flex;align-items:flex-start;gap:8px;background:#3b82f61a;border-bottom:1px solid rgba(59,130,246,.2);padding:10px 20px;font-size:12.5px;color:#93c5fd}.wt-editor-body{gap:8px}.wt-day-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);flex-wrap:wrap}.wt-day-label{width:90px;font-size:13px;font-weight:600;color:var(--text-primary);flex-shrink:0}.wt-day-state{min-width:120px}.wt-day-times{display:flex;align-items:center;gap:6px;flex:1}.wt-day-to{font-size:12px;color:var(--text-tertiary)}.wt-day-actions{display:flex;align-items:center;gap:4px;margin-left:auto}.time-picker{display:flex;align-items:center;gap:2px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 4px;background:var(--surface);height:32px}.time-picker-sel{border:none;background:transparent;outline:none;font-family:var(--font);font-size:12.5px;color:var(--text-primary);cursor:pointer;padding:0 2px}.time-picker-sep{color:var(--text-tertiary);font-size:13px}.wt-preset-btn{font-size:11.5px;padding:0 8px;height:26px}.wt-preset-menu{position:absolute;right:0;top:100%;z-index:50;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:6px;min-width:200px}.wt-preset-menu-title{font-size:10.5px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;padding:4px 8px 6px}.wt-preset-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:7px 10px;border:none;background:transparent;cursor:pointer;color:var(--text-primary);font-family:var(--font);font-size:13px;border-radius:var(--radius-sm);transition:background var(--transition);gap:8px}.wt-preset-item:hover{background:var(--bg)}.wt-preset-name{font-weight:500}.wt-preset-time{font-size:11.5px;color:var(--text-tertiary)}.st-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.st-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition);display:flex;flex-direction:column}.st-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.st-card-accent{height:4px;background:var(--st-color, var(--primary))}.st-card-body{padding:14px 14px 10px;flex:1}.st-card-name{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.st-card-time{font-size:12.5px;color:var(--text-secondary)}.st-card-duration{font-size:11.5px;color:var(--text-tertiary);margin-top:4px}.st-card-menu-wrap{position:relative;padding:8px;display:flex;justify-content:flex-end}.st-add-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:2px dashed var(--border);border-radius:var(--radius-lg);background:transparent;cursor:pointer;font-family:var(--font);font-size:13px;color:var(--text-tertiary);min-height:120px;transition:all var(--transition)}.st-add-card:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.st-duration{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);background:var(--bg);border-radius:var(--radius-sm);padding:7px 10px;border:1px solid var(--border)}.sidebar-store-single{display:flex;align-items:center;gap:8px;padding:7px 14px;font-size:11.5px;color:var(--text-secondary)}.sidebar-store-switcher{position:relative}.sidebar-store-btn{display:flex;align-items:center;gap:8px;width:100%;padding:7px 14px;border:none;background:transparent;cursor:pointer;font-family:var(--font);font-size:11.5px;color:var(--text-secondary);transition:all var(--transition)}.sidebar-store-btn:hover{background:var(--bg);color:var(--text-primary)}.sidebar-store-dropdown{position:absolute;left:8px;right:8px;top:100%;z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:6px}.sidebar-store-dropdown-label{font-size:10.5px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;padding:4px 8px 6px}.sidebar-store-option{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;background:transparent;cursor:pointer;border-radius:var(--radius-sm);font-family:var(--font);transition:background var(--transition)}.sidebar-store-option:hover{background:var(--bg)}.sidebar-store-option--active{background:var(--primary-light)}.pto-page{display:flex;flex-direction:column;gap:20px;padding:24px;min-height:100%}.pto-stats-bar{display:flex;gap:12px;flex-wrap:wrap}.pto-stat-card{flex:1;min-width:120px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;border-top:3px solid var(--accent, #6C63FF)}.pto-stat-value{font-size:22px;font-weight:700;color:var(--text-primary)}.pto-stat-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.pto-inner-tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:4px}.pto-inner-tab{padding:8px 16px;font-size:13px;font-weight:600;color:var(--text-muted);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition);border-radius:4px 4px 0 0;display:flex;align-items:center;gap:6px}.pto-inner-tab:hover{color:var(--primary);background:var(--primary-light)}.pto-inner-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.pto-section-body{display:flex;flex-direction:column;gap:16px}.pto-section-header{display:flex;align-items:baseline;gap:10px}.pto-section-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0}.pto-section-sub{font-size:12px;color:var(--text-muted)}.pto-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}.pto-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--surface)}.pto-table th{padding:10px 12px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border)}.pto-th-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:700;letter-spacing:.05em}.pto-subhead th{padding:6px 12px;font-size:10px;color:var(--text-muted);background:var(--bg);border-bottom:2px solid var(--border)}.pto-row td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}.pto-row:last-child td{border-bottom:none}.pto-row:hover td{background:var(--bg)}.pto-emp-cell{display:flex;align-items:center;gap:10px}.pto-emp-cell.sm{gap:8px}.pto-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.pto-avatar.sm{width:28px;height:28px;font-size:11px}.pto-emp-name{font-weight:600;font-size:13px;color:var(--text-primary)}.pto-emp-name.sm{font-size:13px}.pto-emp-code{font-size:11px;color:var(--text-muted)}.pto-used-chip{display:inline-block;padding:2px 8px;border-radius:8px;font-size:12px;font-weight:600;background:var(--bg);color:var(--text-muted)}.pto-used-chip.has-hours{background:#f59e0b29;color:#fcd34d}.pto-rem-chip{display:inline-block;padding:2px 8px;border-radius:8px;font-size:12px;font-weight:600;background:#10b98129;color:#6ee7b7}.pto-rem-chip.low{background:#ef444429;color:#fca5a5}.pto-total-row td{padding:10px 12px;background:var(--bg);font-size:13px;border-top:2px solid var(--border)}.pto-empty{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}.pto-trim-wrap{display:flex;flex-direction:column;gap:16px}.pto-trim-year-row{display:flex;align-items:center;gap:12px}.pto-year-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:16px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.pto-year-btn:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.pto-year-label{font-size:15px;font-weight:700;color:var(--text-primary);min-width:40px;text-align:center}.pto-trim-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}.pto-trim-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:12px}.pto-trim-emp{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-primary)}.pto-trim-rows{display:flex;flex-direction:column;gap:8px}.pto-trim-row{display:flex;align-items:center;gap:10px}.pto-trim-label{font-size:11px;font-weight:700;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:2px 6px;min-width:24px;text-align:center}.pto-trim-bars{display:flex;flex-direction:column;gap:4px;flex:1}.pto-bar-row{display:flex;align-items:center;gap:6px}.pto-bar-tag{font-size:10px;font-weight:700;padding:1px 5px;border-radius:4px;min-width:28px;text-align:center}.pto-bar-tag.pto{background:#f59e0b2e;color:#fcd34d}.pto-bar-tag.vac{background:#3b82f62e;color:#93c5fd}.pto-bar-track{flex:1;height:6px;border-radius:3px;background:var(--border);overflow:hidden}.pto-bar-fill{height:100%;border-radius:3px;transition:width .3s}.pto-bar-fill.pto{background:#f59e0b}.pto-bar-fill.vac{background:#4f8ef7}.pto-bar-text{font-size:11px;color:var(--text-muted);min-width:80px;text-align:right}.vac-weeks-wrap{display:flex;flex-direction:column;gap:10px}.vac-week-row{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px}.vac-bar-wrap{flex:1;display:flex;align-items:center;gap:10px}.vac-bar-track{flex:1;height:8px;border-radius:4px;background:var(--border);overflow:hidden}.vac-bar-fill{height:100%;border-radius:4px;transition:width .3s,background .3s}.vac-bar-label{font-size:12px;font-weight:600;color:var(--text-secondary);white-space:nowrap;display:flex;align-items:center;gap:6px}.vac-full-badge{background:#ef444429;color:#fca5a5;font-size:10px;font-weight:700;padding:1px 6px;border-radius:8px}.toff-page{display:flex;flex-direction:column;gap:20px;padding:24px;min-height:100%}.toff-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px}.toff-title{font-size:22px;font-weight:800;color:var(--text-primary);margin:0}.toff-subtitle{font-size:13px;color:var(--text-muted);margin:2px 0 0}.toff-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.toff-filter-btn{padding:6px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:6px}.toff-filter-btn:hover{background:var(--bg);color:var(--primary);border-color:var(--primary)}.toff-filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.toff-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center}.toff-entries{display:flex;flex-direction:column;gap:8px}.toff-empty{text-align:center;padding:48px;color:var(--text-muted);font-size:14px}.toff-list-wrap{display:flex;flex-direction:column;gap:12px}.toff-entry-card{display:flex;justify-content:space-between;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;gap:12px;flex-wrap:wrap;transition:box-shadow var(--transition)}.toff-entry-card:hover{box-shadow:var(--shadow)}.toff-entry-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.toff-entry-right{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap}.toff-entry-name{font-weight:600;font-size:14px;color:var(--text-primary)}.toff-entry-date{font-size:12px;color:var(--text-muted);margin-top:2px}.toff-entry-notes{font-size:12px;color:var(--text-secondary);margin-top:2px;font-style:italic}.toff-type-chip{padding:3px 10px;border-radius:10px;font-size:11px;font-weight:700;letter-spacing:.03em}.toff-status-chip{padding:3px 10px;border-radius:10px;font-size:11px;font-weight:700}.toff-actions{display:flex;gap:4px}.toff-action-btn{padding:5px 12px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:12px;font-weight:600;transition:all var(--transition)}.toff-action-btn.approve{background:#10b98129;color:#6ee7b7}.toff-action-btn.approve:hover{background:#22c55e;color:#fff}.toff-action-btn.deny{background:#ef444429;color:#fca5a5}.toff-action-btn.deny:hover{background:#ef4444;color:#fff}.toff-delete-btn{background:none;border:none;cursor:pointer;padding:4px 6px;font-size:15px;opacity:.5;transition:opacity var(--transition);border-radius:4px}.toff-delete-btn:hover{opacity:1;background:#ef444429}.toff-cal-wrap{display:flex;flex-direction:column;gap:12px}.toff-cal-nav{display:flex;align-items:center;gap:12px}.toff-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--border)}.toff-cal-head{background:var(--bg);padding:8px 4px;text-align:center;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase}.toff-cal-cell{background:var(--surface);padding:8px;min-height:90px;display:flex;flex-direction:column;gap:2px;overflow:hidden}.toff-cal-cell.empty{background:var(--bg)}.toff-cal-cell.today{background:var(--primary-light)}.toff-cal-day{font-size:12px;font-weight:700;color:var(--text-secondary);margin-bottom:2px}.toff-cal-cell.today .toff-cal-day{color:var(--primary);background:var(--primary);color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px}.toff-cal-chip{font-size:10px;font-weight:600;padding:2px 5px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toff-cal-more{font-size:10px;color:var(--text-muted);margin-top:1px}.toff-header{flex-wrap:wrap;gap:14px}.toff-role-indicator{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid;white-space:nowrap}.toff-pending-banner{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#f59e0b1f,#fbbf2414);border:1px solid rgba(245,158,11,.35);border-radius:var(--radius);padding:12px 18px;font-size:14px;cursor:pointer;transition:all var(--transition)}.toff-pending-banner:hover{background:linear-gradient(135deg,#f59e0b33,#fbbf2424)}.toff-pending-dot{width:8px;height:8px;border-radius:50%;background:#f59e0b;flex-shrink:0;animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.toff-pending-cta{margin-left:auto;font-weight:700;color:#f59e0b;font-size:13px}.toff-tabs{display:flex;gap:4px;background:var(--bg);border-radius:var(--radius);padding:4px;border:1px solid var(--border)}.toff-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:calc(var(--radius) - 2px);border:none;background:transparent;font-size:13px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap}.toff-tab:hover{background:var(--surface);color:var(--text-primary)}.toff-tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.toff-entry-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;transition:box-shadow var(--transition),border-color var(--transition);position:relative;overflow:hidden}.toff-entry-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.toff-entry-card--pending:before{background:#f59e0b}.toff-entry-card--approved:before{background:#22c55e}.toff-entry-card--denied:before{background:#ef4444}.toff-entry-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}.toff-entry-info{flex:1;min-width:0}.toff-entry-name{font-weight:700;font-size:14px;color:var(--text-primary);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.toff-entry-date{font-size:12px;color:var(--text-muted);margin-top:3px}.toff-entry-notes{font-size:12px;color:var(--text-secondary);margin-top:3px}.toff-deny-reason{font-size:12px;color:#ef4444;margin-top:3px}.toff-entry-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.toff-role-badge{padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border:1px solid}.toff-self-emp-banner{display:flex;align-items:center;gap:12px;background:var(--primary-light);border:1px solid var(--primary);border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:14px}.toff-type-selector{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}.toff-type-option{padding:8px 16px;border-radius:20px;border:2px solid transparent;font-size:13px;font-weight:600;cursor:pointer;background:var(--type-bg, #F1F5F9);color:var(--type-text, #475569);transition:all var(--transition)}.toff-type-option.active{border-color:currentColor;box-shadow:0 0 0 3px var(--type-bg, #F1F5F9)}.toff-type-option:hover{opacity:.85}.toff-myreq-wrap{display:flex;flex-direction:column;gap:16px}.toff-myreq-stats{display:flex;gap:12px;flex-wrap:wrap;align-items:stretch}.toff-stat-card{flex:1;min-width:100px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;text-align:center;border-top:3px solid var(--stat-color, var(--primary));transition:box-shadow var(--transition)}.toff-stat-card:hover{box-shadow:var(--shadow-md)}.toff-stat-val{font-size:28px;font-weight:800;color:var(--stat-color, var(--primary));line-height:1}.toff-stat-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:6px}.toff-new-req-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:120px;padding:16px 20px;border-radius:var(--radius);background:linear-gradient(135deg,#7c3aed,#4f8ef7);color:#fff;border:none;cursor:pointer;font-weight:700;font-size:14px;transition:all var(--transition);box-shadow:0 4px 14px #7c3aed4d}.toff-new-req-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #7c3aed66}.toff-new-req-btn span:first-child{font-size:22px;line-height:1}.toff-myreq-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:box-shadow var(--transition);position:relative;overflow:hidden}.toff-myreq-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.toff-myreq-card--pending:before{background:#f59e0b}.toff-myreq-card--approved:before{background:#22c55e}.toff-myreq-card--denied:before{background:#ef4444}.toff-myreq-card:hover{box-shadow:var(--shadow-md)}.toff-myreq-type{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:700;white-space:nowrap;flex-shrink:0}.toff-myreq-body{flex:1;min-width:0}.toff-myreq-date{font-size:13px;font-weight:600;color:var(--text-primary)}.toff-myreq-notes{font-size:12px;color:var(--text-secondary);margin-top:2px}.toff-myreq-status{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:700;white-space:nowrap;flex-shrink:0}.toff-blackout-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:20px;font-size:13px;font-weight:600}.toff-empty{text-align:center;padding:56px 24px;color:var(--text-muted);font-size:14px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius)}.analytics-page{display:flex;flex-direction:column;gap:20px;padding:24px;min-height:100%}.analytics-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px}.analytics-title{font-size:22px;font-weight:800;color:var(--text-primary);margin:0}.analytics-subtitle{font-size:13px;color:var(--text-muted);margin:2px 0 0}.analytics-nav{display:flex;align-items:center;gap:10px}.analytics-month-label{font-size:15px;font-weight:700;color:var(--text-primary);min-width:140px;text-align:center}.analytics-stats-bar{display:flex;gap:12px;flex-wrap:wrap}.analytics-stat{flex:1;min-width:100px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;text-align:center}.analytics-stat-val{font-size:20px;font-weight:700}.analytics-stat-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-top:2px}.analytics-filters{display:flex;gap:10px;flex-wrap:wrap}.analytics-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}.analytics-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--surface)}.analytics-table th{padding:10px 12px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap}.analytics-row td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}.analytics-row:last-child td{border-bottom:none}.analytics-row:hover td{background:var(--bg)}.analytics-total-row td{padding:10px 12px;background:var(--bg);border-top:2px solid var(--border);font-size:13px}.analytics-num{font-size:13px;font-weight:600;color:var(--text-primary);text-align:center}.analytics-zero{color:var(--text-muted)}.analytics-empty{text-align:center;padding:48px;color:var(--text-muted)}.analytics-code-badge{display:inline-block;padding:2px 8px;border-radius:8px;background:var(--primary-light);color:var(--primary);font-size:11px;font-weight:700}.pnl-page{display:flex;flex-direction:column;gap:20px;padding:24px;min-height:100%}.pnl-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px}.pnl-title{font-size:22px;font-weight:800;color:var(--text-primary);margin:0}.pnl-subtitle{font-size:13px;color:var(--text-muted);margin:2px 0 0}.pnl-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}.pnl-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--surface)}.pnl-th-label{width:50%;padding:10px 16px;text-align:left}.pnl-th-dollar,.pnl-th-pct{width:25%;padding:10px 12px;text-align:right}.pnl-table thead th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg);border-bottom:2px solid var(--border)}.pnl-row td{border-bottom:1px solid var(--border);transition:background var(--transition)}.pnl-row:last-child td{border-bottom:none}.pnl-row:hover td{background:var(--bg)}.pnl-td-label{padding:10px 16px}.pnl-td-dollar,.pnl-td-pct{padding:8px 12px;text-align:right}.pnl-row-label{font-size:13px;font-weight:500;color:var(--text-primary)}.pnl-row-label.bold{font-weight:700;font-size:13px}.pnl-indent{display:inline-block;width:20px}.pnl-yellow td{background:#eab3081a!important}.pnl-yellow:hover td{background:#eab30829!important}.pnl-yellow .pnl-row-label{color:#fcd34d}.pnl-cyan td{background:#06b6d41a!important}.pnl-cyan:hover td{background:#06b6d429!important}.pnl-cyan .pnl-row-label{color:#67e8f9}.pnl-computed td{background:var(--bg)}.pnl-item .pnl-row-label{color:var(--text-secondary)}.pnl-dollar-input{width:100%;text-align:right;border:1px solid transparent;border-radius:4px;padding:4px 8px;font-size:13px;font-weight:500;font-family:var(--font);background:transparent;color:var(--text-primary);transition:all var(--transition)}.pnl-dollar-input:focus{outline:none;border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 2px var(--primary-light)}.pnl-dollar-input::placeholder{color:var(--text-muted)}.pnl-pct-input{width:60px;text-align:right;border:1px solid transparent;border-radius:4px;padding:4px 6px;font-size:13px;font-weight:500;font-family:var(--font);background:transparent;color:var(--text-primary);transition:all var(--transition)}.pnl-pct-input:focus{outline:none;border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 2px var(--primary-light)}.pnl-readonly-val{font-size:13px;font-weight:600;color:var(--text-primary)}.pnl-readonly-val.negative{color:#ef4444}.pnl-pct-val{font-size:13px;color:var(--text-secondary)}.pnl-pct-val.high{color:#ef4444;font-weight:600}.pnl-add-row-btn{padding:6px 16px;border:1px dashed var(--border);border-radius:6px;background:none;cursor:pointer;font-size:12px;font-weight:600;color:var(--text-muted);transition:all var(--transition);width:100%;text-align:left}.pnl-add-row-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.pnl-legend{display:flex;gap:16px;align-items:center}.pnl-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--text-muted)}.pnl-legend-item:before{content:"";display:inline-block;width:12px;height:12px;border-radius:3px}.pnl-legend-item.yellow:before{background:#eab30833;border:1px solid rgba(234,179,8,.5)}.pnl-legend-item.cyan:before{background:#06b6d433;border:1px solid rgba(6,182,212,.5)}.settings-page{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.settings-page-header{padding:20px 28px 0;flex-shrink:0}.settings-page-title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 16px;letter-spacing:-.3px}.settings-content{flex:1;overflow-y:auto;padding:0 28px 28px}.settings-section{display:flex;flex-direction:column;gap:16px}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px}.settings-card-title{font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 16px;display:flex;align-items:center;gap:8px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none;padding-bottom:0}.settings-row:first-of-type{padding-top:0}.settings-row-label{font-size:13px;font-weight:600;color:var(--text-primary)}.settings-row-hint{font-size:12px;color:var(--text-muted);margin-top:2px}.settings-save-bar{display:flex;justify-content:flex-end;align-items:center;padding:12px 0;gap:12px}.settings-saved-msg{font-size:13px;font-weight:600;color:#22c55e}.color-swatch-btn{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;transition:all var(--transition)}.color-swatch-btn:hover{border-color:var(--primary)}.color-picker-popover{position:fixed;z-index:9999;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:0 12px 40px #0006;min-width:200px}.color-palette-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.palette-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s}.palette-swatch:hover{transform:scale(1.15)}.palette-swatch.selected{border-color:#fff;box-shadow:0 0 0 2px var(--primary)}.jc-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);cursor:grab}.jc-row:last-child{border-bottom:none}.jc-row:active{cursor:grabbing}.jc-drag-handle{font-size:18px;color:var(--text-muted);cursor:grab}.jc-code{font-size:13px;font-weight:700;color:var(--text-primary);font-family:monospace}.jc-pto-badge{font-size:10px;font-weight:700;padding:1px 6px;border-radius:8px;background:#3b82f62e;color:#93c5fd}.icon-btn{background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:4px;font-size:14px;opacity:.65;transition:all var(--transition)}.icon-btn:hover{opacity:1;background:var(--bg)}.shift-type-preview{padding:4px 14px;border-radius:12px;font-size:12px;font-weight:600;color:#000000b3}.store-hours-grid{display:grid;grid-template-columns:120px 1fr 1fr;gap:8px;align-items:center}.store-hours-head{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.04em}.store-hours-day{font-size:13px;font-weight:600;color:var(--text-primary)}.tracked-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-secondary);transition:all var(--transition)}.tracked-chip:hover{border-color:var(--primary);color:var(--primary)}.tracked-chip.active{border-color:var(--chip-color, var(--primary));background:color-mix(in srgb,var(--chip-color, var(--primary)) 15%,transparent);color:var(--text-primary)}.tracked-emp-list{display:flex;flex-direction:column;gap:4px;max-height:240px;overflow-y:auto}.tracked-emp-row{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text-secondary);transition:background var(--transition)}.tracked-emp-row:hover{background:var(--bg)}.tracked-emp-row input{cursor:pointer}.avail-page{display:flex;height:100%;min-height:0}.avail-emp-list{width:220px;flex-shrink:0;border-right:1px solid var(--border);background:var(--surface);overflow-y:auto;display:flex;flex-direction:column}.avail-emp-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 0;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.avail-emp-count{background:var(--primary-light);color:var(--primary);font-size:11px;font-weight:700;padding:1px 7px;border-radius:10px}.avail-emp-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border:none;background:none;cursor:pointer;text-align:left;width:100%;transition:background var(--transition);border-left:3px solid transparent}.avail-emp-row:hover{background:var(--bg)}.avail-emp-row.active{background:var(--primary-light);border-left-color:var(--primary)}.avail-emp-name{font-size:13px;font-weight:600;color:var(--text-primary)}.avail-emp-code{font-size:11px;color:var(--text-muted)}.avail-has-dot{width:7px;height:7px;border-radius:50%;background:var(--primary);flex-shrink:0}.avail-editor{flex:1;overflow-y:auto;display:flex;flex-direction:column}.avail-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:8px;padding:40px}.avail-empty h3{font-size:16px;color:var(--text-secondary);margin:0}.avail-empty p{font-size:13px;text-align:center;max-width:260px}.avail-editor-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.avail-editor-name{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.avail-pattern-tabs{display:flex;gap:4px;padding:12px 24px 0;border-bottom:2px solid var(--border);flex-shrink:0}.avail-editor-body{padding:20px 24px;flex:1;overflow-y:auto}.avail-week-header{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--primary);background:var(--primary-light);border-radius:6px;padding:4px 12px;margin:12px 0 4px;display:inline-block}.avail-day-row{display:flex;align-items:flex-start;gap:16px;padding:10px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.avail-day-row:last-child{border-bottom:none}.avail-day-label{min-width:90px;font-size:13px;font-weight:600;color:var(--text-primary);padding-top:7px}.avail-day-controls{display:flex;flex-direction:column;gap:8px}.avail-time-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.avail-monthly{display:flex;flex-direction:column;gap:12px}.avail-monthly-nav{display:flex;align-items:center;gap:12px}.avail-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.avail-cal-head{text-align:center;font-size:11px;font-weight:700;color:var(--text-muted);padding:4px}.avail-cal-day{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:13px;font-weight:500;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all var(--transition);color:var(--text-primary)}.avail-cal-day:hover{border-color:var(--primary);background:var(--primary-light)}.avail-cal-day.unavail{background:#ef444429;border-color:#ef444459;color:#fca5a5}.avail-cal-x{position:absolute;top:2px;right:4px;font-size:9px}.avail-badge{display:inline-block;padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600}.avail-badge.none{color:var(--text-muted)}.avail-badge.unavail{background:#ef444429;color:#fca5a5}.avail-badge.all{background:#10b98129;color:#6ee7b7}.avail-badge.partial{background:#3b82f629;color:#93c5fd}.csv-drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px 24px;text-align:center;cursor:pointer;transition:all var(--transition);display:flex;flex-direction:column;align-items:center;gap:8px;outline:none}.csv-drop-zone:hover,.csv-drop-zone:focus{border-color:var(--primary);background:var(--primary-light)}.csv-drop-zone.dragging{border-color:var(--primary);background:var(--primary-light)}.csv-drop-zone h4{font-size:15px;font-weight:700;margin:0;color:var(--text-primary)}.csv-drop-zone p{font-size:13px;color:var(--text-muted);margin:0}.csv-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-muted);font-size:12px}.csv-divider:before,.csv-divider:after{content:"";flex:1;height:1px;background:var(--border)}.csv-textarea{font-family:monospace;font-size:13px;resize:vertical}.csv-format-hint{margin-top:12px;padding:12px 16px;background:var(--bg);border-radius:var(--radius-sm);font-size:12px;color:var(--text-muted)}.csv-format-hint ul{margin:4px 0 0 16px;padding:0;display:flex;flex-direction:column;gap:2px}.csv-format-hint code{font-family:monospace;background:var(--border);padding:1px 5px;border-radius:3px}.csv-review-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:12px;font-size:14px}.csv-table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border);max-height:340px;overflow-y:auto}.csv-table{width:100%;border-collapse:collapse;font-size:13px}.csv-table th{padding:8px 10px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0}.csv-table tr:not(:last-child) td{border-bottom:1px solid var(--border)}.csv-table td{padding:6px 8px}.csv-table tr:hover td{background:var(--bg)}.csv-cell-input{width:100%!important;min-width:90px;padding:4px 8px!important;font-size:12px!important}.admin-card{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;padding:18px 20px}.admin-card-title{font-size:13px;font-weight:700;color:var(--text-primary);letter-spacing:.01em}.admin-jc-row{display:flex;align-items:center;gap:10px;padding:9px 8px;border-radius:8px;transition:background .12s;cursor:default;min-height:42px}.admin-jc-row:not(:last-child){border-bottom:1px solid var(--border)}.admin-jc-row:hover{background:var(--bg)}.admin-pto-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--border)}.admin-pto-row:last-child{border-bottom:none}html.dark .login-bg{background:linear-gradient(135deg,#1a1744,#0f2036,#0f1f1a)}html.dark .login-card{background:var(--surface)}html.dark .btn--google{background:var(--surface);color:var(--text-primary)}html.dark .btn--google:hover:not(:disabled){background:var(--surface-raised)}html.dark .seg-btn--active{background:var(--surface-raised);color:var(--text-primary)}html.dark .sidebar-view-mode-btn{background:var(--surface)}html.dark .sidebar-view-mode-btn:hover{background:var(--primary-light)}html.dark .sidebar-store-btn,html.dark .sidebar-store-option{background:transparent}html.dark .admin-search-bar,html.dark .admin-icon-btn,html.dark .admin-action-btn,html.dark .admin-access-type-btn{background:var(--surface)}html.dark .admin-icon-btn:hover,html.dark .admin-action-btn:hover{background:var(--surface-raised)}html.dark .admin-store-card,html.dark .admin-table-wrap,html.dark .admin-role-card,html.dark .admin-patch-card,html.dark .admin-modal,html.dark .admin-role-option{background:var(--surface)}html.dark .admin-role-option:hover{background:var(--surface-raised)}html.dark .admin-role-option--active{background:color-mix(in srgb,var(--role-color, var(--primary)) 15%,var(--surface))}html.dark .admin-check-row:hover{background:var(--surface-raised)}html.dark .admin-status-pill{background:var(--surface)}html.dark .color-swatch-btn{background:var(--surface);border-color:var(--border)}html.dark .schedule-cell--empty:hover{background:var(--surface-raised)}html.dark ::-webkit-scrollbar-track{background:var(--bg)}html.dark ::-webkit-scrollbar-thumb{background:var(--border-strong)}html.dark ::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.approvals-page{display:flex;flex-direction:column;min-height:100%;background:var(--bg)}.approvals-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding:24px 28px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;position:sticky;top:0;z-index:10}.approvals-title{font-size:26px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px;margin:0}.approvals-subtitle{font-size:13px;color:var(--text-muted);margin:4px 0 0}.approvals-summary-pills{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.approvals-pill{display:flex;align-items:center;gap:7px;padding:8px 14px;border-radius:10px;font-size:13px;font-weight:600;border:1.5px solid;white-space:nowrap}.approvals-pill-count{font-size:18px;font-weight:800;line-height:1}.approvals-pill--timeoff{background:linear-gradient(135deg,#fef3c7,#fde68a20);color:#92400e;border-color:#fde68a}.approvals-pill--schedule{background:linear-gradient(135deg,#dbeafe,#bfdbfe20);color:#1e40af;border-color:#bfdbfe}.approvals-pill--pnl{background:linear-gradient(135deg,#ccfbf1,#99f6e420);color:#0f766e;border-color:#99f6e4}html.dark .approvals-pill--timeoff{background:#fef3c714;color:#fcd34d;border-color:#fde68a40}html.dark .approvals-pill--schedule{background:#dbeafe14;color:#93c5fd;border-color:#bfdbfe40}html.dark .approvals-pill--pnl{background:#ccfbf114;color:#5eead4;border-color:#99f6e440}.approvals-cattabs{display:flex;gap:4px;padding:12px 28px;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;position:sticky;top:0;z-index:9}.approvals-cattab{display:flex;align-items:center;gap:7px;padding:7px 16px;border-radius:8px;border:1.5px solid transparent;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap;position:relative}.approvals-cattab:hover{background:var(--bg);color:var(--text-primary)}.approvals-cattab--active{background:linear-gradient(135deg,#7c3aed1f,#4f8ef71f);color:var(--primary);border-color:#7c3aed40}.approvals-cattab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:99px;background:#f97316;color:#fff;font-size:10px;font-weight:800;line-height:1}.approvals-content{padding:20px 28px 40px;display:flex;flex-direction:column;gap:28px}.approvals-section{background:var(--surface);border-radius:14px;border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm)}.approvals-section-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:12px}.approvals-section-title{font-size:15px;font-weight:700;color:var(--text-primary)}.approvals-store-filter{display:flex;gap:6px;flex-wrap:wrap}.approvals-store-filter-btn{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:7px;border:1.5px solid var(--border);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}.approvals-store-filter-btn:hover,.approvals-store-filter-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.approvals-store-filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:99px;background:#f97316;color:#fff;font-size:10px;font-weight:700}.approvals-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;padding:16px 20px 20px}.approval-card{display:flex;border-radius:12px;border:1px solid var(--border);background:var(--bg);overflow:hidden;transition:box-shadow .18s ease,transform .18s ease}.approval-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.approval-card-stripe{width:5px;flex-shrink:0}.approval-card-body{flex:1;padding:14px 16px}.approval-deny-btn,.approval-approve-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:none;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s ease;flex:1;justify-content:center}.approval-deny-btn{background:#ef44441a;color:#ef4444;border:1.5px solid rgba(239,68,68,.2)}.approval-deny-btn:hover{background:#ef4444;color:#fff;border-color:#ef4444}.approval-approve-btn{background:#22c55e1a;color:#16a34a;border:1.5px solid rgba(34,197,94,.2)}.approval-approve-btn:hover{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border-color:#22c55e}.approvals-empty{padding:48px 20px;text-align:center;background:var(--bg)}.approvals-soon-section{padding:20px}.approvals-soon-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:10px;background:var(--bg);border:1.5px solid var(--border);margin-bottom:8px;transition:border-color .15s ease}.approvals-soon-item:hover{border-color:var(--soon-color, var(--primary))}.approvals-soon-badge{padding:3px 10px;border-radius:99px;font-size:10px;font-weight:700;letter-spacing:.05em;background:#7c3aed1a;color:var(--primary);border:1px solid rgba(124,58,237,.2);white-space:nowrap;flex-shrink:0}.tab-pending-badge{display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;padding:0 5px;border-radius:99px;background:#f97316;color:#fff;font-size:9px;font-weight:800;line-height:1;margin-left:2px;animation:pulse-badge 2s ease-in-out infinite}@keyframes pulse-badge{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(.95)}}html.dark .approvals-header,html.dark .approvals-section{background:var(--surface);border-color:var(--border)}html.dark .approvals-section-header{border-color:var(--border)}html.dark .approval-card{background:var(--surface-raised);border-color:var(--border)}html.dark .approvals-empty{background:var(--surface-raised)}html.dark .approvals-cattabs{background:var(--surface);border-color:var(--border)}html.dark .approvals-soon-item{background:var(--surface-raised);border-color:var(--border)}html.dark .approval-deny-btn{background:#ef44441f;border-color:#ef444440}html.dark .approval-approve-btn{background:#22c55e1f;border-color:#22c55e40}.sched-approval-bar{margin:0 0 12px;padding:10px 18px;border-radius:12px;border:1.5px solid;display:flex;flex-wrap:wrap;align-items:center;gap:10px;transition:background .2s,border-color .2s;position:relative}.sched-approval-bar-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0;flex-wrap:wrap}.sched-approval-bar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.sched-approval-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;animation:pulse-sched-dot 2s ease-in-out infinite}@keyframes pulse-sched-dot{0%,to{opacity:1}50%{opacity:.55}}.sched-approval-status-label{font-size:12px;font-weight:700;letter-spacing:.01em;white-space:nowrap}.sched-approval-month{font-size:13px;font-weight:600;color:var(--text-primary)}.sched-approval-meta{font-size:11px;color:var(--text-muted)}.sched-approval-comments-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:7px;border:1.5px solid var(--border);background:var(--bg-surface, var(--surface));color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.sched-approval-comments-btn:hover{border-color:var(--primary);color:var(--primary)}.sched-approval-submit-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;color:#fff!important;border:none!important;font-weight:700!important;display:flex;align-items:center;gap:6px;padding:7px 14px!important;white-space:nowrap}.sched-approval-submit-btn:hover:not(:disabled){opacity:.88}.sched-approval-pending-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:99px;background:#3b82f629;color:#93c5fd;white-space:nowrap}.sched-approval-approved-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:99px;background:#10b98129;color:#6ee7b7;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.sched-approval-comments-drawer{width:100%;border-top:1px solid var(--border);margin-top:6px;padding-top:10px;display:flex;flex-direction:column;gap:10px}.sched-approval-comment{display:flex;gap:10px;align-items:flex-start}.sched-approval-comment-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}.sched-approval-comment-body{flex:1;min-width:0}.sched-approval-comment-header{display:flex;align-items:center;gap:8px;margin-bottom:3px;flex-wrap:wrap}.sched-approval-comment-author{font-size:12px;font-weight:700;color:var(--text-primary)}.sched-approval-comment-time{font-size:11px;color:var(--text-muted)}.sched-approval-comment-type{font-size:10px;font-weight:700;padding:1px 7px;border-radius:99px}.sched-approval-comment-type--approval{background:#10b98129;color:#6ee7b7}.sched-approval-comment-type--changes_requested{background:#f59e0b29;color:#fcd34d}.sched-approval-comment-text{font-size:12px;color:var(--text-secondary);font-style:italic;line-height:1.4}.sched-approval-card{border:1.5px solid rgba(59,130,246,.25);background:#3b82f60f;position:relative;overflow:hidden}.sched-approval-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(59,130,246,.04),transparent);pointer-events:none}.admin-approval-settings-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:20px;margin-bottom:24px;position:relative;overflow:hidden}.admin-approval-settings-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f59e0b,#fbbf24,#fcd34d);border-radius:14px 14px 0 0}html.dark .sched-approval-bar{background:var(--surface)!important}html.dark .sched-approval-comments-btn{background:var(--surface-raised)}html.dark .sched-approval-comment-avatar{background:linear-gradient(135deg,#4f46e5,#7c3aed)}html.dark .sched-approval-card{background:var(--surface);border-color:#3b82f640}html.dark .admin-approval-settings-card{background:var(--surface);border-color:var(--border)}.sched-validation-modal{max-width:560px;width:95vw;background:var(--surface);border:1px solid var(--border);border-top:3px solid #F59E0B}.sched-val-group{border-radius:10px;overflow:hidden;border:1px solid rgba(245,158,11,.2);background:#f59e0b0a}.sched-val-group-header{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:12px;font-weight:700}.sched-val-group-header--blank{background:#f59e0b24;color:#fcd34d;border-bottom:1px solid rgba(245,158,11,.15)}.sched-val-group-header--blank svg{stroke:#fbbf24}.sched-val-group-header--clopen{background:#f9731624;color:#fb923c;border-bottom:1px solid rgba(249,115,22,.18)}.sched-val-group-header--clopen svg{stroke:#fb923c}.sched-val-items{display:flex;flex-direction:column;gap:0}.sched-val-item{display:flex;align-items:flex-start;gap:10px;padding:9px 14px;border-bottom:1px solid rgba(245,158,11,.1);background:transparent;transition:background .12s}.sched-val-item:last-child{border-bottom:none}.sched-val-item:hover{background:#f59e0b12}.sched-val-item-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#d97706,#f59e0b);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;margin-top:1px;box-shadow:0 2px 8px #f59e0b59}.sched-val-item-avatar--clopen{background:linear-gradient(135deg,#ea580c,#f97316);box-shadow:0 2px 8px #f9731659}.sched-val-item-body{flex:1;min-width:0}.sched-val-item-msg{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.35}.sched-val-item-detail{font-size:11px;color:var(--text-secondary);margin-top:3px;line-height:1.4}.sched-submitted-toast{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;color:#fff!important;padding:14px 18px!important;border-radius:12px!important;box-shadow:0 8px 24px #6366f159!important;animation:slide-in-toast .3s cubic-bezier(.34,1.56,.64,1) both}@keyframes slide-in-toast{0%{opacity:0;transform:translateY(-10px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.sched-submit-error-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;margin-bottom:8px;border-radius:10px;background:#ef44441f;border:1.5px solid rgba(239,68,68,.25);color:#fca5a5;font-size:13px;font-weight:500;animation:fade-in-banner .2s ease both}@keyframes fade-in-banner{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}html.dark .sched-submit-error-banner{background:#ef44441f;border-color:#ef444440;color:#fca5a5}.sched-review-modal{background:var(--surface);border-radius:18px;width:92vw;max-width:1100px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xl);border:1px solid var(--border)}.sched-review-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 24px;border-bottom:1.5px solid;flex-shrink:0;background:var(--surface)}.sched-review-warnings{padding:10px 24px;background:linear-gradient(135deg,#f59e0b12,#fbbf240a);border-bottom:1px solid rgba(245,158,11,.18);flex-shrink:0}.sched-review-warnings-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:#b45309;margin-bottom:6px}.sched-review-warnings-list{display:flex;flex-direction:column;gap:3px}.sched-review-warning-item{display:flex;align-items:baseline;gap:8px;font-size:12px;color:#92400e}.sched-review-warning-dot{width:5px;height:5px;border-radius:50%;background:#f59e0b;flex-shrink:0;margin-top:5px}.sched-review-body{flex:1;overflow:auto;padding:16px 20px;background:var(--bg)}.sched-review-grid-wrap{display:flex;flex-direction:column;gap:20px}.sched-review-week{border-radius:12px;border:1px solid var(--border);overflow:hidden;background:var(--surface)}.sched-review-week-header{display:grid;grid-template-columns:160px repeat(auto-fill,minmax(80px,1fr));background:linear-gradient(135deg,#7c3aed14,#4f8ef70f);border-bottom:1px solid var(--border)}.sched-review-week-label-cell{padding:8px 12px;font-size:11px;font-weight:800;color:var(--primary);letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;border-right:1px solid var(--border)}.sched-review-day-header{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;border-right:1px solid var(--border-strong);gap:1px}.sched-review-day-header:last-child{border-right:none}.sched-review-day-name{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.sched-review-day-num{font-size:14px;font-weight:800;color:var(--text-primary)}.sched-review-emp-row{display:grid;grid-template-columns:160px repeat(auto-fill,minmax(80px,1fr));border-bottom:1px solid var(--border);min-height:52px}.sched-review-emp-row:last-child{border-bottom:none}.sched-review-emp-name-cell{display:flex;align-items:center;gap:8px;padding:8px 12px;border-right:1px solid var(--border);background:var(--surface)}.sched-review-emp-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;flex-shrink:0}.sched-review-emp-name{font-size:12px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sched-review-day-cell{padding:4px;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:2px;align-items:stretch;justify-content:center;background:var(--bg)}.sched-review-day-cell:last-child{border-right:none}.sched-review-shift-chip{border-radius:5px;padding:3px 5px;display:flex;flex-direction:column;gap:1px}.sched-review-shift-label{font-size:10px;font-weight:700;color:#1e293b;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sched-review-shift-job{font-size:9px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.04em}.sched-review-comments{padding:14px 24px;border-top:1px solid var(--border);flex-shrink:0;background:var(--surface);max-height:180px;overflow-y:auto}.sched-review-comments-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px}.sched-review-comment-item{display:flex;gap:10px;margin-bottom:10px}.sched-review-comment-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;flex-shrink:0}.sched-review-comment-body{flex:1}.sched-review-comment-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-primary);margin-bottom:3px;flex-wrap:wrap}.sched-review-comment-text{font-size:13px;color:var(--text-secondary);line-height:1.5}.sched-review-actions{padding:14px 24px;border-top:1.5px solid var(--border);flex-shrink:0;background:var(--surface)}.sched-review-action-expanded{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:14px 16px}.sched-review-comment-input{width:100%;box-sizing:border-box;padding:10px 12px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-primary);font-size:13px;font-family:var(--font);resize:vertical;min-height:72px;transition:border-color .15s ease}.sched-review-comment-input:focus{outline:none;border-color:var(--primary)}.sched-review-changes-btn,.sched-review-approve-btn{display:flex;align-items:center;gap:7px;padding:10px 20px;border-radius:9px;border:none;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s ease;flex:1;justify-content:center}.sched-review-changes-btn{background:#f59e0b1a;color:#d97706;border:1.5px solid rgba(245,158,11,.25)}.sched-review-changes-btn:hover{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-color:#f59e0b}.sched-review-approve-btn{background:#22c55e1a;color:#16a34a;border:1.5px solid rgba(34,197,94,.25)}.sched-review-approve-btn:hover{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border-color:#22c55e}html.dark .sched-review-modal{background:var(--surface);border-color:var(--border)}html.dark .sched-review-header{background:var(--surface)}html.dark .sched-review-body{background:var(--bg)}html.dark .sched-review-week{background:var(--surface);border-color:var(--border)}html.dark .sched-review-week-header{background:#7c3aed1a}html.dark .sched-review-emp-name-cell{background:var(--surface)}html.dark .sched-review-day-cell{background:var(--surface-raised)}html.dark .sched-review-shift-label{color:var(--text-primary)}html.dark .sched-review-shift-job{color:var(--text-secondary)}html.dark .sched-review-comments,html.dark .sched-review-actions{background:var(--surface)}html.dark .sched-review-action-expanded{background:var(--surface-raised)}html.dark .sched-review-comment-input{background:var(--surface-raised);border-color:var(--border)}html.dark .sched-review-changes-btn{background:#f59e0b1f;border-color:#f59e0b40}.sched-review-action-row{display:flex;gap:10px;margin-bottom:10px}.sched-review-approve-btn{display:flex;align-items:center;justify-content:center;gap:7px;flex:1;padding:10px 18px;border-radius:9px;border:1.5px solid rgba(34,197,94,.25);background:#22c55e1a;color:#16a34a;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s ease}.sched-review-approve-btn:hover:not(:disabled){background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border-color:#22c55e;box-shadow:0 4px 12px #22c55e59}.sched-review-approve-btn:disabled{opacity:.55;cursor:not-allowed}.sched-review-sendback-btn{display:flex;align-items:center;justify-content:center;gap:7px;flex:1;padding:10px 18px;border-radius:9px;border:1.5px solid rgba(245,158,11,.25);background:#f59e0b1a;color:#d97706;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s ease}.sched-review-sendback-btn:hover{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-color:#f59e0b;box-shadow:0 4px 12px #f59e0b59}.sched-review-goto-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:9px 18px;border-radius:9px;border:1.5px solid var(--border);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease}.sched-review-goto-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.sched-review-content-row{display:flex;flex:1;overflow:hidden;min-height:0}.sched-review-content-row .sched-review-body{flex:1;overflow-y:auto;min-width:0}.sched-review-sendback-btn--active{background:#f59e0b2e!important;color:#d97706!important;border-color:#f59e0b73!important}.sched-sendback-sidebar{width:320px;flex-shrink:0;border-left:1.5px solid var(--border);background:var(--surface);display:flex;flex-direction:column;animation:slideInSidebar .22s cubic-bezier(.34,1.2,.64,1);overflow:hidden}@keyframes slideInSidebar{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.sched-sendback-sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 16px 14px;border-bottom:1.5px solid var(--border);background:linear-gradient(135deg,#f59e0b0f,#fbbf2408);flex-shrink:0}.sched-sendback-sidebar-close{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:16px;line-height:1;padding:4px 6px;border-radius:6px;transition:background .15s,color .15s}.sched-sendback-sidebar-close:hover{background:var(--bg);color:var(--text-primary)}.sched-sendback-sidebar-body{flex:1;padding:16px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}.sched-sendback-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);margin-bottom:2px}.sched-sendback-textarea{flex:1;min-height:180px;resize:vertical;padding:12px;border-radius:10px;border:1.5px solid var(--border);background:var(--bg);color:var(--text-primary);font-size:13.5px;line-height:1.55;font-family:inherit;transition:border-color .15s,box-shadow .15s;outline:none}.sched-sendback-textarea:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b26}.sched-sendback-sidebar-footer{display:flex;gap:8px;padding:14px 16px;border-top:1.5px solid var(--border);background:var(--surface);flex-shrink:0}.sched-sendback-sidebar-footer .btn--ghost{flex:1;justify-content:center}.sched-sendback-confirm-btn{flex:2;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 16px;border-radius:8px;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s ease,box-shadow .15s;box-shadow:0 2px 10px #f59e0b59}.sched-sendback-confirm-btn:hover:not(:disabled){box-shadow:0 4px 16px #f59e0b73}.sched-sendback-confirm-btn:disabled{opacity:.45;cursor:not-allowed}html.dark .sched-review-approve-btn{background:#22c55e1f;border-color:#22c55e40}html.dark .sched-review-sendback-btn{background:#f59e0b1f;border-color:#f59e0b40}html.dark .sched-sendback-sidebar{background:var(--surface);border-color:var(--border)}html.dark .sched-sendback-textarea{background:var(--surface-raised);border-color:var(--border)}.sched-reviewer-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:linear-gradient(90deg,#6366f114,#8b5cf60f);border-bottom:1px solid rgba(99,102,241,.2);flex-shrink:0}.sched-reviewer-bar-left{display:flex;align-items:center;gap:10px}.sched-reviewer-bar-icon{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#6366f133,#8b5cf626);border:1px solid rgba(99,102,241,.3);display:flex;align-items:center;justify-content:center;color:#a5b4fc;flex-shrink:0}.sched-reviewer-bar-title{font-size:12px;font-weight:700;color:#c4b5fd;letter-spacing:.01em}.sched-reviewer-bar-sub{font-size:10px;color:var(--text-tertiary);margin-top:1px}.sched-reviewer-bar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.sched-reviewer-approve-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:7px;border:1px solid rgba(34,197,94,.35);background:linear-gradient(135deg,#22c55e26,#10b9811a);color:#6ee7b7;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s}.sched-reviewer-approve-btn:hover:not(:disabled){background:linear-gradient(135deg,#22c55e40,#10b9812e);border-color:#22c55e8c;transform:translateY(-1px);box-shadow:0 3px 10px #22c55e33}.sched-reviewer-approve-btn:disabled{opacity:.5;cursor:not-allowed}.sched-reviewer-sendback-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:7px;border:1px solid rgba(245,158,11,.35);background:#f59e0b14;color:#fcd34d;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s}.sched-reviewer-sendback-btn:hover:not(:disabled){background:#f59e0b26;border-color:#f59e0b80}.sched-reviewer-sendback-btn--active{background:#f59e0b2e!important;border-color:#f59e0b80!important;color:#fbbf24!important}.sched-reviewer-sendback-btn:disabled{opacity:.5;cursor:not-allowed}.sched-reviewer-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.25);border-top-color:currentColor;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes slideDownIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sched-page-sendback-panel{display:flex;flex-direction:column;background:var(--surface);border-bottom:1px solid rgba(245,158,11,.25);animation:slideDownIn .18s ease;flex-shrink:0}.sched-page-sendback-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px 8px;font-size:12px;font-weight:700;color:#fcd34d;border-bottom:1px solid rgba(245,158,11,.12)}.sched-page-sendback-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;display:flex;align-items:center;border-radius:4px;transition:color .15s,background .15s}.sched-page-sendback-close:hover{color:var(--text-primary);background:var(--surface-raised)}.sched-page-sendback-body{padding:10px 16px;display:flex;align-items:flex-start;gap:12px}.sched-page-sendback-hint{font-size:11px;color:var(--text-tertiary);margin:0;flex-shrink:0;width:200px;line-height:1.5;padding-top:2px}.sched-page-sendback-textarea{flex:1;min-height:70px;padding:8px 10px;border-radius:7px;border:1px solid rgba(245,158,11,.3);background:#f59e0b0d;color:var(--text-primary);font-size:12px;line-height:1.5;resize:vertical;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.sched-page-sendback-textarea:focus{border-color:#f59e0b99;box-shadow:0 0 0 3px #f59e0b1f}.sched-page-sendback-textarea::placeholder{color:var(--text-tertiary)}.sched-page-sendback-footer{padding:8px 16px 10px;display:flex;justify-content:flex-end;border-top:1px solid rgba(245,158,11,.08)}.sched-page-sendback-confirm-btn{display:flex;align-items:center;gap:6px;padding:7px 18px;border-radius:7px;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #f59e0b40}.sched-page-sendback-confirm-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #f59e0b59}.sched-page-sendback-confirm-btn:disabled{opacity:.45;cursor:not-allowed}.role-preview-container{position:relative;display:flex;align-items:stretch;flex-direction:column;width:100%}.role-preview-btn{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;border-radius:var(--radius-sm);border:none;background:transparent;color:#ffffff59;font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all .15s;white-space:nowrap;text-align:left}.role-preview-btn:hover{background:#ffffff12;color:#ffffffbf}.role-preview-btn--active{background:color-mix(in srgb,var(--preview-color, #6C63FF) 12%,transparent);color:var(--preview-color, #6C63FF)}.role-preview-btn--active:hover{background:color-mix(in srgb,var(--preview-color, #6C63FF) 20%,transparent)}.role-preview-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-preview-menu{position:fixed;min-width:185px;background:#1a1c2e;border:1px solid rgba(255,255,255,.1);border-radius:10px;box-shadow:0 8px 40px #000000b3,0 2px 10px #00000080,0 0 0 1px #ffffff0a;padding:6px;z-index:9999;animation:fadeInDown .12s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.role-preview-menu-title{display:flex;align-items:center;gap:6px;padding:4px 8px 6px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#ffffff59}.role-preview-option{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;border-radius:7px;background:transparent;color:#ffffffe0;font-size:12px;font-weight:500;cursor:pointer;transition:background .1s;text-align:left}.role-preview-option:hover{background:#ffffff14}.role-preview-option--active{background:color-mix(in srgb,var(--opt-color, #6C63FF) 15%,transparent)!important}.role-preview-option-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.role-preview-option-icon{font-size:13px;line-height:1}.role-preview-option-label{flex:1;font-weight:600}.role-preview-exit-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:7px 10px;border:1px dashed rgba(239,68,68,.35);border-radius:7px;background:#ef44440f;color:#f87171;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.role-preview-exit-btn:hover{background:#ef444421;border-color:#ef44448c}.preview-banner{position:relative;display:flex;align-items:center;gap:8px;padding:7px 16px;background:linear-gradient(90deg,color-mix(in srgb,var(--banner-color, #6C63FF) 10%,#0A0C1E),color-mix(in srgb,var(--banner-color, #6C63FF) 6%,#0A0C1E));border-bottom:1px solid color-mix(in srgb,var(--banner-color, #6C63FF) 35%,transparent);overflow:hidden;z-index:50;animation:bannerSlideIn .25s ease}@keyframes bannerSlideIn{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.preview-banner-pulse{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,color-mix(in srgb,var(--banner-color, #6C63FF) 8%,transparent) 50%,transparent 100%);animation:shimmer 2.8s ease-in-out infinite;pointer-events:none}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}.preview-banner-text{font-size:12px;color:var(--text-secondary);font-weight:500}.preview-banner-sep{color:var(--text-tertiary);font-size:11px}.preview-banner-note{font-size:11px;color:var(--text-tertiary);font-style:italic}.preview-banner-exit{display:flex;align-items:center;gap:5px;margin-left:auto;padding:4px 11px;border-radius:6px;border:1px solid rgba(239,68,68,.35);background:#ef44441a;color:#f87171;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.preview-banner-exit:hover{background:#ef444433;border-color:#ef44448c;box-shadow:0 0 10px #ef444433}.shift-runner-page{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg)}.shift-runner-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.shift-runner-header-icon{font-size:28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#7c3aed1f,#4f8ef71f);border-radius:12px;border:1px solid rgba(124,58,237,.18)}.shift-runner-title{font-size:20px;font-weight:800;margin:0 0 2px;color:var(--text-primary)}.shift-runner-subtitle{font-size:13px;color:var(--text-muted);margin:0}.shift-runner-nav{display:flex;align-items:center;gap:6px;flex-shrink:0}.sr-nav-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.sr-nav-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.sr-today-btn{height:34px;padding:0 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition)}.sr-today-btn:hover,.sr-today-btn--active{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.shift-runner-table-wrap{flex:1;overflow:auto;padding:20px 24px}.shift-runner-table{width:100%;border-collapse:collapse;border-spacing:0;min-width:640px}.sr-th{padding:10px 8px;text-align:center;font-size:12px;color:var(--text-secondary);border-bottom:2px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:2}.sr-th--label{text-align:left;min-width:150px;padding-left:12px}.sr-th--today{color:var(--primary)}.sr-th-day{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.sr-th-date{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;margin:0 auto}.sr-th-date--today{background:var(--primary);color:#fff}.sr-row{border-bottom:1px solid var(--border)}.sr-row:hover{background:var(--bg)}.sr-td-label{padding:10px 8px 10px 12px;vertical-align:middle}.sr-shift-badge{display:flex;align-items:center;gap:8px}.sr-shift-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px var(--badge-color, #ccc)}.sr-shift-name{font-size:13px;font-weight:700;color:var(--text-primary);line-height:1.2}.sr-shift-range{font-size:11px;color:var(--text-muted);margin-top:1px}.runner-cell{padding:6px 4px;vertical-align:middle;text-align:center;position:relative}.runner-cell-inner{display:flex;align-items:center;justify-content:center;gap:5px;min-height:40px;border-radius:8px;border:1.5px dashed var(--border);padding:4px 8px;cursor:pointer;transition:all var(--transition);background:transparent}.runner-cell-inner:hover{border-style:solid;border-color:var(--primary);background:var(--primary-light)}.runner-cell-inner--filled{border-style:solid;border-color:color-mix(in srgb,var(--cell-color) 40%,transparent);background:color-mix(in srgb,var(--cell-color) 10%,transparent)}.runner-cell-inner--filled:hover{background:color-mix(in srgb,var(--cell-color) 18%,transparent);border-color:var(--cell-color)}.runner-cell-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:72px}.runner-cell-empty{font-size:16px;color:var(--text-tertiary);line-height:1}.runner-picker-anchor{position:absolute;top:100%;left:50%;transform:translate(-50%);z-index:100}.runner-picker{min-width:220px;background:var(--surface-raised);border:1px solid var(--border-strong);border-radius:12px;box-shadow:var(--shadow-xl);overflow:hidden;display:flex;flex-direction:column;margin-top:6px}.runner-picker-search{display:flex;align-items:center;gap:8px;padding:10px 12px 8px;border-bottom:1px solid var(--border);color:var(--text-muted)}.runner-picker-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:13px}.runner-picker-list{max-height:220px;overflow-y:auto;padding:4px 0}.runner-picker-option{display:flex;align-items:center;gap:10px;width:100%;padding:8px 14px;text-align:left;background:none;border:none;cursor:pointer;font-size:13px;color:var(--text-primary);transition:background var(--transition)}.runner-picker-option:hover{background:var(--bg)}.runner-picker-option--active{font-weight:700;color:var(--opt-color, var(--primary))}.runner-picker-clear{display:flex;align-items:center;gap:6px;width:100%;padding:8px 14px;border:none;border-top:1px solid var(--border);background:none;color:#ef4444;font-size:12px;cursor:pointer;transition:background var(--transition)}.runner-picker-clear:hover{background:#ef444414}.shift-runner-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-muted);text-align:center;padding:48px}.shift-runner-empty h3{margin:0;color:var(--text-secondary)}.shift-runner-empty p{margin:0;font-size:14px;max-width:360px}.shift-runner-legend{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 24px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;flex-wrap:wrap}.sr-legend-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-secondary);font-weight:500}.runner-type-row{display:flex;align-items:center;gap:14px;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:var(--surface);transition:box-shadow var(--transition),border-color var(--transition)}.runner-type-row:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.runner-type-swatch{width:52px;height:52px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #00000026}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:500;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-box{background:var(--surface-raised);border-radius:16px;border:1px solid var(--border-strong);box-shadow:var(--shadow-xl);width:100%;overflow:hidden;animation:modal-in .18s ease}@keyframes modal-in{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-close{width:28px;height:28px;border-radius:6px;border:none;background:var(--bg);color:var(--text-muted);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.modal-close:hover{background:#ef44441f;color:#ef4444}.inline-runner-section{border-top:1.5px dashed var(--border);background:var(--bg)}.inline-runner-header{display:flex;align-items:center;gap:7px;padding:7px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--surface);border-bottom:1px solid transparent;transition:background .15s}.inline-runner-header:hover{background:color-mix(in srgb,var(--accent) 6%,var(--surface))}.inline-runner-chevron{flex-shrink:0;transition:transform .2s ease;color:var(--text-secondary)}.inline-runner-chevron--open{transform:rotate(90deg)}.inline-runner-title{font-size:11.5px;font-weight:600;color:var(--text-secondary);letter-spacing:.02em;display:flex;align-items:center}.inline-runner-count{font-size:10px;color:var(--text-tertiary, var(--text-secondary));background:var(--border);border-radius:20px;padding:1px 7px;margin-left:2px;opacity:.8}.inline-runner-grid{display:grid;border-top:1px solid var(--border)}.inline-runner-label-cell{display:flex;align-items:center;gap:7px;padding:6px 12px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);min-height:38px;background:var(--surface)}.inline-runner-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.inline-runner-label-text{font-size:11.5px;font-weight:600;color:var(--text-primary);white-space:nowrap}.inline-runner-range{font-size:9.5px;color:var(--text-secondary);white-space:nowrap;margin-left:auto;opacity:.75}.inline-runner-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);min-height:38px;display:flex;align-items:center;justify-content:center;padding:4px;position:relative;transition:background .12s}.inline-runner-cell:last-child{border-right:none}.inline-runner-cell--dragover{background:color-mix(in srgb,var(--accent) 12%,var(--bg));outline:2px dashed var(--accent);outline-offset:-2px}.inline-runner-cell--filled{background:color-mix(in srgb,var(--runner-color, var(--accent)) 8%,var(--bg))}.inline-runner-badge{display:flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:2px 6px 2px 3px;max-width:100%;min-width:0}.inline-runner-avatar{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}.inline-runner-name{font-size:11px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inline-runner-remove{background:none;border:none;cursor:pointer;padding:2px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);border-radius:50%;flex-shrink:0;opacity:0;transition:opacity .15s,background .15s,color .15s}.inline-runner-badge:hover .inline-runner-remove{opacity:1}.inline-runner-remove:hover{background:#ef44441f;color:#ef4444}.inline-runner-empty-cell{display:flex;align-items:center;justify-content:center;width:100%;height:100%;opacity:.4;transition:opacity .15s}.inline-runner-cell:hover .inline-runner-empty-cell{opacity:.7}.schedule-name-cell[draggable=true]{cursor:grab}.schedule-name-cell[draggable=true]:active{cursor:grabbing;opacity:.8}.mobile-nav{display:none}@media (max-width: 768px){body{overflow:hidden;-webkit-overflow-scrolling:touch}.tabbar{display:none!important}.app-body{flex-direction:column;height:100%}.app-right{flex:1;overflow:hidden;display:flex;flex-direction:column}.main-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:env(safe-area-inset-bottom,0px)}.mobile-nav{display:flex;align-items:stretch;height:64px;flex-shrink:0;background:var(--tabbar-bg);border-top:1px solid var(--tabbar-border);position:relative;padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -4px 24px #0006;z-index:100}.mobile-nav-glow{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(124,58,237,.6) 30%,rgba(79,142,247,.6) 70%,transparent 100%)}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:none;background:transparent;cursor:pointer;color:#ffffff59;padding:8px 4px;position:relative;transition:all .18s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.mobile-nav-item:active{transform:scale(.92)}.mobile-nav-item--active{color:#fffffff2}.mobile-nav-pip{position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:3px;border-radius:0 0 3px 3px}.mobile-nav-icon{display:flex;align-items:center;justify-content:center;transition:transform .18s ease,color .18s ease}.mobile-nav-item--active .mobile-nav-icon{transform:translateY(-1px)}.mobile-nav-label{font-size:10px;font-weight:600;letter-spacing:.02em;transition:color .18s ease;white-space:nowrap}.sidebar{height:52px;padding:0 12px;gap:0}.sidebar-spacer,.sidebar-user-info,.header-role-preview-btn,.header-store-switcher,.sidebar-header-sep,.sidebar-nav{display:none!important}.sidebar-signout{display:flex;margin-left:auto}.sidebar-page-title-text{font-size:16px;font-weight:800}.page{padding:16px}.page-header{margin-bottom:16px;flex-direction:column;gap:12px}.page-title{font-size:20px}.page-actions{width:100%}.page-actions .btn{flex:1;justify-content:center}.schedule-page{padding:12px}.schedule-grid-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-md)}.schedule-grid{grid-template-columns:140px repeat(7,minmax(80px,1fr));min-width:700px}.schedule-name-cell{position:sticky;left:0;z-index:3}.shift-chip{font-size:10px;padding:3px 5px}.schedule-toolbar,.sched-toolbar{flex-wrap:wrap;gap:8px}.week-nav button,.week-nav .btn{min-width:40px;min-height:40px}.sched-approval-bar{flex-direction:column;gap:8px;padding:10px 12px}.form-row{grid-template-columns:1fr}.modal-overlay{align-items:flex-end;padding:0}.modal,.modal-box{width:100%!important;max-width:100%!important;border-radius:20px 20px 0 0;max-height:90vh;animation:mobileSlideUp .25s cubic-bezier(.34,1.1,.64,1)}.modal--sm{width:100%!important}.modal-header{padding:16px 20px 14px}.modal-body{padding:16px 20px}.modal-footer{padding:14px 20px;flex-direction:column-reverse;gap:8px}.modal-footer .btn{width:100%;height:44px;font-size:14px}.modal:before,.modal-box:before{content:"";display:block;width:36px;height:4px;border-radius:2px;background:#ffffff26;margin:10px auto 0;flex-shrink:0}@keyframes mobileSlideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.timeoff-table,.pto-table{font-size:12px}.timeoff-cards,.pto-cards{grid-template-columns:1fr}.stat-cards,.stats-row{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:14px}.btn{min-height:36px}.btn--primary,.btn--danger{min-height:44px;font-size:14px}.table-wrapper,[class*=-table-wrap]{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:500px}.preview-banner{font-size:11px;padding:6px 12px;flex-wrap:wrap;gap:4px}.preview-banner-note{display:none}.shift-ctx-menu{border-radius:14px 14px 0 0}.inline-runner-grid{min-width:600px}.inline-runner-section{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (min-width: 769px) and (max-width: 1024px){.tabbar{width:var(--sidebar-collapsed)!important}.tabbar-brand-name,.tab-label,.tabbar-collapse-btn span,.tabbar-admin-label{display:none!important}.tabbar-collapse-btn{justify-content:center;padding:9px}.tabbar-admin-btn{justify-content:center}.page{padding:16px 20px}.schedule-grid{grid-template-columns:150px repeat(7,minmax(90px,1fr))}}.sidebar-mobile-brand{display:none;align-items:center;justify-content:center;flex-shrink:0;margin-right:8px}@media (max-width: 768px){.sidebar-mobile-brand{display:flex}.sidebar-user{display:flex!important;margin-left:auto}.sidebar-user-info{display:none!important}.sidebar-signout{display:flex!important}.schedule-grid-wrapper:after{content:"";position:absolute;top:0;right:0;bottom:0;width:28px;background:linear-gradient(to right,transparent,rgba(0,0,0,.25));pointer-events:none;border-radius:0 var(--radius-md) var(--radius-md) 0}}
