:root{--bg:#030918;--glass:rgba(255,255,255,.05);--glass-2:rgba(255,255,255,.08);--glass-3:rgba(255,255,255,.03);--border:rgba(255,255,255,.1);--border-soft:rgba(255,255,255,.07);--border-hi:rgba(255,255,255,.22);--text-1:rgba(255,255,255,.95);--text-2:rgba(255,255,255,.55);--text-3:rgba(255,255,255,.3);--text-4:rgba(255,255,255,.16);--blue:#38BDF8;--violet:#A78BFA;--pink:#F472B6;--cyan:#22D3EE;--amber:#FBBF24;--rose:#FB7185;--emerald:#34D399;--blue-g:rgba(56,189,248,.18);--violet-g:rgba(167,139,250,.18);--amber-g:rgba(251,191,36,.18);--rose-g:rgba(251,113,133,.18);--cyan-g:rgba(34,211,238,.18);--green:#38BDF8;--green-dark:#0EA5E9;--green-deep:#0284C7;--green-light:rgba(56,189,248,.14);--green-mid:rgba(56,189,248,.28);--green-faint:rgba(255,255,255,.04);--green-pale:rgba(255,255,255,.03);--orange:#FBBF24;--orange-dark:#F59E0B;--orange-light:rgba(251,191,36,.12);--orange-mid:rgba(251,191,36,.25);--forest:rgba(255,255,255,.95);--forest-mid:rgba(255,255,255,.65);--forest-soft:rgba(255,255,255,.5);--forest-mute:rgba(255,255,255,.35);--forest-hint:rgba(255,255,255,.2);--white:rgba(255,255,255,.95);--off-white:#030918;--red:#FB7185;--red-light:rgba(251,113,133,.12);--amber-light:rgba(251,191,36,.12);--blue-light:rgba(56,189,248,.12);--sidebar-w:260px;--header-h:64px;--r:14px;--r-sm:10px;--r-md:10px;--r-lg:20px;--shadow:0 4px 20px rgba(0,0,0,.35);--shadow-md:0 8px 32px rgba(0,0,0,.45);--shadow-lg:0 16px 48px rgba(0,0,0,.55);--bg-soft:rgba(255,255,255,.04);--org:#FBBF24}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:Geist,sans-serif;background:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:17px;line-height:1.65;letter-spacing:-.01em}h1,h2,h3,h4,h5{font-family:Clash Display,Geist,sans-serif;line-height:1.2;letter-spacing:-.03em}button{font-family:Geist,sans-serif;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:Geist,sans-serif;outline:none;font-size:16px}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff38}.app-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.28;animation:drift 24s ease-in-out infinite}.orb-1{width:650px;height:650px;background:radial-gradient(circle,#7C3AED,transparent 65%);top:-200px;left:-150px;animation-delay:0s}.orb-2{width:500px;height:500px;background:radial-gradient(circle,#1D4ED8,transparent 65%);top:-100px;right:-100px;animation-delay:-7s}.orb-3{width:480px;height:480px;background:radial-gradient(circle,#BE185D,transparent 65%);bottom:50px;left:200px;animation-delay:-14s;opacity:.22}.orb-4{width:360px;height:360px;background:radial-gradient(circle,#D97706,transparent 65%);bottom:-80px;right:240px;animation-delay:-21s;opacity:.2}@keyframes drift{0%,to{transform:translate(0) scale(1)}33%{transform:translate(25px,-18px) scale(1.04)}67%{transform:translate(-18px,12px) scale(.97)}}.dot-grid{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.055) 1px,transparent 1px);background-size:28px 28px}.app-shell{display:flex;min-height:100vh;position:relative;z-index:1}.sidebar{width:var(--sidebar-w);background:#030918cc;backdrop-filter:blur(28px) saturate(160%);-webkit-backdrop-filter:blur(28px) saturate(160%);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;transition:transform .25s ease;overflow:hidden}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);pointer-events:none;z-index:1}.sidebar:after{display:none}.sidebar-logo{padding:20px 22px 16px;border-bottom:1px solid var(--border);position:relative;z-index:1}.brand-row{display:flex;align-items:center;gap:12px}.brand-icon{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#1d4ed8);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid rgba(255,255,255,.18);box-shadow:0 0 16px #7c3aed59}.brand-icon:before{display:none}.brand-bird{font-size:18px}.brand-text .brand-name{font-family:Clash Display,Geist,sans-serif;font-weight:600;font-size:15px;letter-spacing:-.02em;background:linear-gradient(125deg,#38bdf8,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-text .brand-sub{font-size:11px;color:var(--text-3);font-weight:400;margin-top:1px}.sidebar-store{padding:10px 22px;border-bottom:1px solid var(--border);position:relative;z-index:1}.store-pill{display:inline-flex;align-items:center;gap:6px;background:#38bdf81a;border:1px solid rgba(56,189,248,.22);border-radius:20px;padding:6px 14px;font-size:13px;color:var(--blue);font-weight:500}.store-dot{width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 6px var(--cyan)}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto;position:relative;z-index:1}.nav-group-label{padding:10px 22px 4px;font-size:10px;font-weight:700;color:var(--text-4);letter-spacing:.1em;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 22px;color:var(--text-2);cursor:pointer;transition:all .15s;font-size:15px;font-weight:500;border-left:3px solid transparent;margin:1px 0}.nav-item:hover{background:#ffffff0d;color:var(--text-1)}.nav-item.active{background:#38bdf81a;color:var(--blue);border-left-color:var(--blue)}.nav-icon{font-size:18px;width:22px;text-align:center;flex-shrink:0}.nav-label{flex:1}.nav-badge{background:var(--amber);color:#000;font-size:11px;font-weight:700;border-radius:10px;padding:2px 7px;min-width:20px;text-align:center}.sidebar-footer{padding:16px 22px;border-top:1px solid var(--border);position:relative;z-index:1}.user-row{display:flex;align-items:center;gap:11px}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#1d4ed8);border:1.5px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:13px;flex-shrink:0;box-shadow:0 0 12px #7c3aed4d}.user-info .u-name{font-size:14px;color:var(--text-1);font-weight:600}.user-info .u-role{font-size:11px;color:var(--text-3);margin-top:1px}.logout-btn{margin-left:auto;width:30px;height:30px;background:#fb71851a;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fb7185b3;font-size:14px;transition:all .15s;border:1px solid rgba(251,113,133,.15);cursor:pointer}.logout-btn:hover{background:#fb718540;color:var(--rose)}.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}.page-header{background:#030918b3;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-bottom:1px solid var(--border);padding:0 32px;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.ph-left .ph-title{font-family:Clash Display,Geist,sans-serif;font-size:20px;font-weight:600;color:var(--text-1);letter-spacing:-.02em}.ph-left .ph-sub{font-size:13px;color:var(--text-3);margin-top:2px}.ph-right{display:flex;align-items:center;gap:12px}.ph-date{font-size:13px;color:var(--text-3)}.ph-green-dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #22d3ee33}50%{box-shadow:0 0 0 6px #22d3ee14}}.page-body{padding:28px 32px;flex:1}.mobile-header{display:none;background:#030918e0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:14px 18px;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200}.mobile-header .m-brand{display:flex;align-items:center;gap:10px}.mobile-header .m-icon{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#1d4ed8);display:flex;align-items:center;justify-content:center;font-size:14px}.mobile-header .m-name{font-family:Clash Display,Geist,sans-serif;font-weight:600;color:var(--text-1);font-size:17px}.hamburger{background:none;border:none;color:var(--text-2);font-size:22px;cursor:pointer;padding:2px}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:199;display:none}.sidebar-overlay.open{display:block}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#030918eb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);z-index:150;padding:8px 0 max(8px,env(safe-area-inset-bottom))}.bn-inner{display:flex;justify-content:space-around}.bn-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 14px;cursor:pointer;color:var(--text-3);transition:color .15s}.bn-item.active{color:var(--blue)}.bn-icon{font-size:22px}.bn-label{font-size:11px;font-weight:600}.card{background:var(--glass);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(140deg,rgba(255,255,255,.06) 0%,transparent 55%)}.card-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:relative}.card-title{font-family:Clash Display,Geist,sans-serif;font-size:16px;font-weight:600;color:var(--text-1);letter-spacing:-.02em}.card-body{padding:22px;position:relative}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--glass);border-radius:var(--r);border:1px solid var(--border);padding:22px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:border-color .25s,transform .2s;position:relative;overflow:hidden;cursor:default}.stat-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(140deg,rgba(255,255,255,.07) 0%,transparent 55%)}.stat-card:after{content:"";position:absolute;top:14px;right:14px;width:16px;height:16px;border-top:1.5px solid rgba(255,255,255,.18);border-right:1.5px solid rgba(255,255,255,.18);border-radius:0 4px 0 0;pointer-events:none}.stat-card:hover{border-color:#fff3;transform:translateY(-1px)}.stat-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px;position:relative;z-index:1}.si-green{background:#38bdf81f;border:1px solid rgba(56,189,248,.2)}.si-orange{background:#fbbf241f;border:1px solid rgba(251,191,36,.2)}.si-red{background:#fb71851f;border:1px solid rgba(251,113,133,.2)}.si-blue{background:#a78bfa1f;border:1px solid rgba(167,139,250,.2)}.si-amber{background:#fbbf241f;border:1px solid rgba(251,191,36,.2)}.stat-value{font-family:Clash Display,Geist,sans-serif;font-size:30px;font-weight:600;color:var(--text-1);line-height:1;position:relative;z-index:1;letter-spacing:-.03em}.stat-label{font-size:13px;color:var(--text-3);margin-top:5px;font-weight:400;position:relative;z-index:1}.stat-trend{font-size:12px;margin-top:6px;font-weight:600;position:relative;z-index:1}.trend-up{color:var(--cyan)}.trend-down{color:var(--rose)}.trend-neutral{color:var(--text-3)}.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:var(--r-sm);font-size:15px;font-weight:600;transition:all .15s;cursor:pointer;border:none;font-family:Geist,sans-serif}.btn-primary{background:#38bdf826;color:var(--blue);border:1px solid rgba(56,189,248,.3);box-shadow:0 0 16px #38bdf81f}.btn-primary:hover{background:#38bdf840;box-shadow:0 0 24px #38bdf838;transform:translateY(-1px)}.btn-orange{background:#fbbf2426;color:var(--amber);border:1px solid rgba(251,191,36,.3)}.btn-orange:hover{background:#fbbf2440;transform:translateY(-1px)}.btn-secondary{background:var(--glass);color:var(--text-2);border:1px solid var(--border)}.btn-secondary:hover{background:var(--glass-2);color:var(--text-1)}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--glass);color:var(--text-1)}.btn-danger{background:#fb71851f;color:var(--rose);border:1px solid rgba(251,113,133,.25)}.btn-danger:hover{background:#fb718540;color:#fff}.btn-sm{padding:7px 13px;font-size:13px}.btn-lg{padding:16px 30px;font-size:17px;border-radius:var(--r)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid transparent}.badge-green{background:#38bdf81f;color:var(--blue);border-color:#38bdf838}.badge-orange{background:#fbbf241f;color:var(--amber);border-color:#fbbf2438}.badge-red{background:#fb71851f;color:var(--rose);border-color:#fb718538}.badge-amber{background:#fbbf241f;color:var(--amber);border-color:#fbbf2438}.badge-blue{background:#a78bfa1f;color:var(--violet);border-color:#a78bfa38}.badge-gray{background:#ffffff0f;color:var(--text-3);border-color:var(--border)}.form-group{margin-bottom:18px}.form-label{display:block;font-size:14px;font-weight:600;color:var(--text-2);margin-bottom:7px}.form-label span{color:var(--rose);margin-left:2px}.form-input{width:100%;padding:12px 15px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:15px;color:var(--text-1);background:#ffffff0a;transition:border .15s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.form-input:focus{border-color:#38bdf880;box-shadow:0 0 0 3px #38bdf81a}.form-input.has-error{border-color:#fb718580;box-shadow:0 0 0 3px #fb71851a}.form-input.has-error:focus{border-color:#fb718599;box-shadow:0 0 0 3px #fb718526}.form-error{font-size:13px;color:var(--rose);margin-top:5px;display:flex;align-items:flex-start;gap:6px;line-height:1.4}.form-error:before{content:"⚠";flex-shrink:0}.form-input::placeholder{color:var(--text-4)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='rgba(255,255,255,0.35)' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-hint{font-size:12px;color:var(--text-4);margin-top:5px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}thead th{background:#ffffff05;padding:12px 16px;text-align:left;font-size:11px;font-weight:600;color:var(--text-4);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border)}tbody td{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-2);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#ffffff06;color:var(--text-1)}.td-primary{font-weight:700;color:var(--text-1);font-size:15px}.budget-meter{background:#ffffff14;border-radius:6px;height:8px;overflow:hidden}.budget-bar{height:100%;border-radius:6px;transition:width .5s ease}.budget-bar.safe{background:linear-gradient(90deg,var(--cyan),var(--blue))}.budget-bar.warning{background:linear-gradient(90deg,var(--amber),#F59E0B)}.budget-bar.over{background:linear-gradient(90deg,var(--rose),#F43F5E)}.alert{border-radius:var(--r-sm);padding:14px 17px;font-size:14px;display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;border:1px solid transparent}.alert-icon{font-size:17px;flex-shrink:0;margin-top:1px}.alert-green{background:#38bdf814;border-color:#38bdf833;color:var(--blue)}.alert-amber{background:#fbbf2414;border-color:#fbbf2433;color:var(--amber)}.alert-red{background:#fb718514;border-color:#fb718533;color:var(--rose)}.alert-blue{background:#a78bfa14;border-color:#a78bfa33;color:var(--violet)}.alert-orange{background:#fbbf2414;border-color:#fbbf2433;color:var(--amber)}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:22px;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:12px 20px;font-size:15px;font-weight:500;color:var(--text-3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;white-space:nowrap;scroll-snap-align:start;flex-shrink:0}.tab:hover{color:var(--text-2)}.tab.active{color:var(--blue);border-bottom-color:var(--blue)}.week-nav{display:flex;align-items:center;gap:12px;background:var(--glass);border-radius:var(--r-sm);padding:7px 12px;border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.week-nav-btn{background:#ffffff0d;border:1px solid var(--border);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;font-size:16px;color:var(--text-2)}.week-nav-btn:hover{background:#38bdf81f;border-color:#38bdf84d;color:var(--blue)}.week-label{font-family:Geist,sans-serif;font-size:14px;font-weight:600;color:var(--text-1);min-width:200px;text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:#050c1ceb;-webkit-backdrop-filter:blur(32px);backdrop-filter:blur(32px);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0009;animation:slideUp .2s ease;position:relative}.modal-box:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);pointer-events:none}@keyframes slideUp{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:Clash Display,Geist,sans-serif;font-size:19px;font-weight:600;color:var(--text-1);letter-spacing:-.02em}.modal-close{width:30px;height:30px;border-radius:8px;background:#ffffff0f;border:1px solid var(--border);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:all .15s}.modal-close:hover{background:#ffffff1f;color:var(--text-1)}.modal-body{padding:24px}.modal-footer{padding:18px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.roster-grid{border-collapse:collapse;width:100%;min-width:620px}.roster-grid th{padding:8px 6px;font-size:10px;font-weight:600;color:var(--text-4);text-align:center;background:#ffffff05;border:1px solid var(--border);text-transform:uppercase;letter-spacing:.06em}.roster-grid th.emp-col{text-align:left;min-width:110px;padding-left:12px}.roster-grid td{border:1px solid var(--border);padding:3px;vertical-align:top;min-width:88px;height:52px}.roster-grid td.emp-name-cell{padding:10px 12px;font-size:13px;font-weight:600;color:var(--text-1);background:#ffffff05;vertical-align:middle}.roster-grid td.emp-name-cell .emp-sub{font-size:11px;color:var(--text-4);font-weight:400;margin-top:2px}.shift-cell{border-radius:8px;padding:5px 8px;font-size:12px;font-weight:600;cursor:pointer;min-height:50px;display:flex;flex-direction:column;justify-content:center;transition:opacity .15s}.shift-cell:hover{opacity:.8}.shift-cell.empty{background:#ffffff08;border:1.5px dashed var(--border);color:var(--text-4);cursor:pointer;align-items:center;font-size:20px;justify-content:center}.shift-cell.empty:hover{background:#38bdf814;border-color:#38bdf84d;color:var(--blue)}.shift-cell.drag-source{opacity:.45}.shift-cell.drop-target{outline:2px solid var(--blue)!important;outline-offset:-2px;background:#38bdf81f!important;border-color:#38bdf84d!important;color:var(--blue)!important}.shift-cell.morning{background:#38bdf81f;color:var(--blue);border:1px solid rgba(56,189,248,.22)}.shift-cell.afternoon{background:#fbbf241f;color:var(--amber);border:1px solid rgba(251,191,36,.22)}.shift-cell.evening{background:#fbbf241a;color:#f59e0b;border:1px solid rgba(251,191,36,.18)}.shift-cell.close{background:#a78bfa1f;color:var(--violet);border:1px solid rgba(167,139,250,.22)}.shift-cell.split{background:#22d3ee1a;color:var(--cyan);border:1px solid rgba(34,211,238,.2)}.shift-cell.off{background:#ffffff05;color:var(--text-4);border:1px solid var(--border);cursor:default}.shift-time{font-size:10px;opacity:.75;margin-top:2px;font-weight:500}.clock-hero{background:#050c1cbf;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px;color:var(--text-1);position:relative;overflow:hidden;margin-bottom:20px}.clock-hero:before{content:"";position:absolute;top:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(56,189,248,.15),transparent 70%);pointer-events:none}.clock-hero:after{content:"";position:absolute;top:-30px;right:-30px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(167,139,250,.12),transparent 70%);pointer-events:none}.hero-inner{position:relative;z-index:1}.hero-tag{display:inline-flex;align-items:center;gap:6px;background:#38bdf81f;border:1px solid rgba(56,189,248,.25);border-radius:20px;padding:5px 12px;font-size:12px;color:var(--blue);font-weight:600;margin-bottom:16px}.hero-name{font-family:Clash Display,Geist,sans-serif;font-size:24px;font-weight:600;color:var(--text-1);letter-spacing:-.03em}.hero-store{font-size:15px;color:var(--text-3);margin-top:3px;margin-bottom:18px}.hero-time{font-family:Geist,sans-serif;font-size:62px;font-weight:800;color:var(--text-1);letter-spacing:-2px;line-height:1}.hero-colon{color:var(--cyan)}.hero-date{font-size:15px;color:var(--text-3);margin-top:5px;margin-bottom:22px}.elapsed-label{font-size:13px;color:var(--text-3);margin-bottom:3px}.elapsed-time{font-family:Geist,sans-serif;font-size:30px;font-weight:700;color:var(--cyan);margin-bottom:16px}.clock-btn{width:100%;padding:18px;border-radius:var(--r);font-family:Geist,sans-serif;font-size:19px;font-weight:700;border:1.5px solid transparent;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px}.cb-out{background:#fbbf2426;color:var(--amber);border-color:#fbbf244d;box-shadow:0 0 24px #fbbf2426}.cb-out:hover{background:#fbbf2440;box-shadow:0 0 32px #fbbf2440;transform:translateY(-1px)}.cb-in{background:#fb718526;color:var(--rose);border-color:#fb71854d;box-shadow:0 0 24px #fb71851f}.cb-in:hover{background:#fb718540;box-shadow:0 0 32px #fb718538;transform:translateY(-1px)}.clock-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.cs-row{display:flex;align-items:center;gap:8px;margin-top:14px}.cs-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.cs-dot.in{background:var(--cyan);box-shadow:0 0 0 3px #22d3ee33;animation:pulse 2s infinite}.cs-dot.out{background:#fff3}.cs-text{font-size:14px;color:var(--text-3)}.gps-msg{font-size:13px;color:var(--text-3);margin-top:10px}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--text-1);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.toast-wrap{position:fixed;bottom:28px;right:28px;z-index:2000;display:flex;flex-direction:column;gap:10px}.toast{background:#050c1cf0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);color:var(--text-1);padding:14px 20px;border-radius:var(--r-sm);font-size:14px;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease;max-width:360px}.toast.success{border-left:3px solid var(--cyan)}.toast.error{border-left:3px solid var(--rose)}.toast.info{border-left:3px solid var(--amber)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:transparent;padding:20px;position:relative;overflow:hidden}.login-page:before,.login-page:after{display:none}.c3{display:none}.login-card{width:100%;max-width:420px;background:#050c1ce0;backdrop-filter:blur(32px) saturate(160%);-webkit-backdrop-filter:blur(32px) saturate(160%);border:1px solid var(--border);border-radius:24px;overflow:hidden;box-shadow:0 32px 80px #0009;position:relative;z-index:1}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);pointer-events:none}.login-hero{background:linear-gradient(135deg,#7c3aed66,#1d4ed866);border-bottom:1px solid var(--border);padding:32px 30px 28px;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;top:-50px;right:-50px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(167,139,250,.25),transparent 70%)}.login-hero:after{content:"";position:absolute;bottom:-30px;left:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(56,189,248,.18),transparent 70%)}.login-logo-row{display:flex;align-items:center;gap:14px;margin-bottom:18px;position:relative;z-index:1}.login-roundel{width:50px;height:50px;border-radius:50%;background:#ffffff1f;border:1.5px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;font-size:22px}.l-name{font-family:Clash Display,Geist,sans-serif;font-size:24px;font-weight:600;color:var(--text-1);letter-spacing:-.03em}.l-sub{font-size:14px;color:var(--text-3);margin-top:2px}.login-tagline{font-size:15px;color:var(--text-2);position:relative;z-index:1}.login-body{padding:28px 30px}.login-hint{margin-bottom:12px;padding:10px 14px;background:#22d3ee14;border:1px solid rgba(34,211,238,.2);border-radius:8px;font-size:13px;color:var(--cyan);font-weight:600}.login-err{background:#fb71851a;border:1px solid rgba(251,113,133,.22);border-radius:10px;padding:12px 16px;font-size:14px;color:var(--rose);margin-bottom:18px;display:flex;align-items:center;gap:8px}.login-footer{text-align:center;padding:0 30px 24px;font-size:13px;color:var(--text-4)}.empty-state{text-align:center;padding:48px 20px;color:var(--text-3)}.empty-icon{font-size:48px;margin-bottom:12px}.empty-text{font-size:16px;color:var(--text-3)}.chip{display:inline-block;background:var(--glass);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:13px;color:var(--text-2);font-weight:500}.divider{height:1px;background:var(--border);margin:20px 0}.accept-banner{background:#38bdf814;border:1px solid rgba(56,189,248,.2);border-radius:var(--r);padding:18px 20px;margin-bottom:18px;display:flex;align-items:center;gap:16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.accept-banner.done{background:#22d3ee0f;border-color:#22d3ee2e}.ab-icon{font-size:28px;flex-shrink:0}.ab-title{font-weight:700;font-size:15px;color:var(--text-1)}.ab-sub{font-size:13px;color:var(--text-3);margin-top:2px}.accept-btn{margin-left:auto;background:#38bdf833;color:var(--blue);border:1px solid rgba(56,189,248,.3);border-radius:var(--r-sm);padding:10px 18px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0;font-family:inherit}.accept-btn:hover{background:#38bdf84d}.task-item{background:var(--glass);border:1.5px solid var(--border);border-radius:var(--r);padding:16px 18px;margin-bottom:10px;transition:box-shadow .2s,border-color .2s;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.task-item:hover{box-shadow:var(--shadow-md);border-color:#ffffff29}.task-item.t-done{background:#22d3ee0a;border-color:#22d3ee26}.task-item.pri-high{border-left:3px solid var(--rose)}.task-item.pri-medium{border-left:3px solid var(--amber)}.task-item.pri-low{border-left:3px solid var(--blue)}.task-row{display:flex;align-items:flex-start;gap:12px}.task-check{width:26px;height:26px;border-radius:50%;border:2px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all .15s;margin-top:2px;font-size:14px}.task-check.checked{background:var(--cyan);border-color:var(--cyan);color:#000}.task-ttl{font-weight:600;font-size:15px;color:var(--text-1)}.t-done .task-ttl{text-decoration:line-through;color:var(--text-3)}.task-dsc{font-size:13px;color:var(--text-3);margin-top:3px;line-height:1.5}.task-meta-row{display:flex;align-items:center;gap:8px;margin-top:8px;flex-wrap:wrap}.task-photo-thumb{width:100%;max-height:220px;object-fit:cover;border-radius:10px;margin-top:10px;border:1px solid var(--border)}.task-bar{background:var(--glass);border:1px solid var(--border);border-radius:var(--r);padding:14px 18px;margin-bottom:18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:box-shadow .15s,border-color .15s;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.task-bar:hover{box-shadow:var(--shadow-md);border-color:#ffffff2e}.wrc-top{background:#050c1cbf;border:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:var(--text-1);border-radius:var(--r);padding:22px 24px;margin-bottom:20px}.wrc-top h2{font-family:Clash Display,Geist,sans-serif;font-size:20px;font-weight:600;margin-bottom:4px;letter-spacing:-.02em}.wrc-top p{font-size:14px;color:var(--text-3)}.wrc-meta{display:flex;gap:24px;margin-top:14px;flex-wrap:wrap}.wm-label{font-size:11px;color:var(--text-4);font-weight:700;text-transform:uppercase;letter-spacing:.07em}.wm-value{font-size:14px;color:var(--text-1);font-weight:600;margin-top:2px}.wrc-table{width:100%;border-collapse:collapse;font-size:14px;margin-bottom:16px}.wrc-table th{background:#ffffff0a;color:var(--text-3);padding:10px 11px;text-align:center;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border:1px solid var(--border)}.wrc-table th:first-child{text-align:left;min-width:150px}.wrc-table td{padding:10px 11px;border-bottom:1px solid var(--border);text-align:center;vertical-align:middle;color:var(--text-2)}.wrc-table td:first-child{text-align:left;font-weight:600;color:var(--text-1)}.wrc-table tr:nth-child(2n) td{background:#ffffff05}.wrc-totrow td{background:#38bdf81f!important;color:var(--text-1)!important;font-weight:700!important}.wrc-bh{background:#fbbf241a!important;color:var(--amber)!important;font-weight:600}.wrc-sun{background:#a78bfa1a!important;color:var(--violet)!important;font-weight:600}.wrc-off{color:var(--text-4)!important}.wrc-rules{background:#ffffff08;border:1px solid var(--border);border-radius:var(--r-sm);padding:14px 18px;font-size:13px;color:var(--text-2);margin-bottom:18px;line-height:1.9}.wrc-sig{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:28px}.wrc-sig-line{border-top:1px solid var(--border);padding-top:10px;font-size:13px;color:var(--text-3)}.flag-row{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}.flag-row:last-child{border-bottom:none}.flag-avatar{width:38px;height:38px;border-radius:50%;background:#38bdf81f;border:1px solid rgba(56,189,248,.25);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--blue);flex-shrink:0;margin-top:2px}.flag-name{font-weight:700;font-size:15px;color:var(--text-1)}.flag-times{font-size:13px;color:var(--text-3);margin-top:2px}.flag-reason{display:inline-flex;align-items:center;gap:4px;background:#fbbf241a;border:1px solid rgba(251,191,36,.22);border-radius:6px;padding:2px 8px;font-size:12px;color:var(--amber);font-weight:600;margin-top:5px}.payroll-step{display:flex;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid var(--border)}.payroll-step:last-child{border-bottom:none}.step-num{width:34px;height:34px;border-radius:50%;background:#38bdf826;border:1px solid rgba(56,189,248,.25);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:var(--blue);flex-shrink:0;margin-top:2px}.step-num.locked{background:#ffffff0d;border-color:var(--border);color:var(--text-3)}.payroll-emp-row{display:flex;align-items:center;padding:11px 0;border-bottom:1px solid var(--border);gap:10px;flex-wrap:wrap}.payroll-emp-row:last-child{border-bottom:none}.ptag{display:inline-flex;align-items:center;gap:3px;border-radius:4px;padding:2px 7px;font-size:11px;font-weight:700;border:1px solid transparent}.ptag-sun{background:#a78bfa1f;color:var(--violet);border-color:#a78bfa33}.ptag-bh{background:#fbbf241f;color:var(--amber);border-color:#fbbf2433}.ptag-ot{background:#fb71851f;color:var(--rose);border-color:#fb718533}.tp-wrap{display:flex;align-items:center;gap:6px;background:var(--glass);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:10px 12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.tp-select{flex:1;font-size:26px;font-weight:800;color:var(--text-1);background:transparent;border:none;outline:none;text-align:center;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:4px 0}.tp-select:focus{color:var(--blue)}.tp-colon{font-size:30px;font-weight:800;color:var(--text-4);flex-shrink:0;line-height:1;margin:0 2px}.shift-preview{display:flex;align-items:center;justify-content:space-between;background:var(--glass);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:10px 14px;margin-top:10px}.shift-preview-hrs{font-size:22px;font-weight:800;color:var(--cyan)}.task-for-badge{display:inline-flex;align-items:center;gap:4px;background:#38bdf81a;border:1px solid rgba(56,189,248,.2);border-radius:5px;padding:2px 7px;font-size:11px;color:var(--blue);font-weight:600}.task-for-mgr{background:#fbbf241a;border-color:#fbbf2433;color:var(--amber)}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.msg-thread{padding:13px 0;border-bottom:1px solid var(--border)}.msg-thread:last-child{border-bottom:none}.msg-subject{font-weight:700;font-size:15px;color:var(--text-1)}.msg-body{font-size:14px;color:var(--text-3);margin-top:4px;line-height:1.55}.msg-meta{font-size:12px;color:var(--text-4);margin-top:6px;display:flex;gap:12px;flex-wrap:wrap}.msg-pinned{background:#fbbf2414;border:1px solid rgba(251,191,36,.2);border-radius:var(--r-sm);padding:13px 16px;margin-bottom:10px}.abs-bar-track{flex:1;height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.abs-bar-fill{height:100%;border-radius:4px}.rtw-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border)}.rtw-row:last-child{border-bottom:none}@keyframes ldbar{0%{width:0%;margin-left:0}50%{width:100%}to{width:0%;margin-left:100%}}.im-thread-page{position:fixed;top:0;right:0;bottom:0;left:0;background:#030918f2;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);z-index:95;display:flex;flex-direction:column}.im-thread-header{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#050c1ce6;border-bottom:1px solid var(--border)}.im-back{width:40px;height:40px;background:var(--glass);border:1px solid var(--border);border-radius:10px;font-size:20px;color:var(--text-2);cursor:pointer;flex-shrink:0}.im-back:hover{background:var(--glass-2);color:var(--text-1)}.im-thread-body{flex:1;overflow-y:auto;padding:16px 14px;-webkit-overflow-scrolling:touch}.im-thread-composer{display:flex;align-items:flex-end;padding:10px 12px calc(10px + env(safe-area-inset-bottom));background:#050c1ce6;border-top:1px solid var(--border)}.im-thread-composer textarea.form-input{min-height:44px;max-height:35vh;padding:10px 12px}.roster-tp-row{display:flex;gap:12px;margin-bottom:14px}@media (max-width:900px){.roster-tp-row{flex-direction:column;gap:10px}}@media (max-width:900px){.roster-unsaved-banner{position:sticky;top:60px;z-index:80;box-shadow:0 2px 12px #0000004d}}.emp-acc-header{display:none}@media (max-width:900px){.emp-modal-tabs{display:none!important}.emp-acc-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;background:#ffffff0a;border:none;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-family:Geist,sans-serif;font-size:15px;font-weight:600;color:var(--text-2);text-align:left;cursor:pointer;margin:0 -14px}.emp-acc-header[aria-expanded=true]{background:#38bdf814;color:var(--blue)}.emp-acc-header .emp-acc-chev{transition:transform .15s;font-size:12px}.emp-acc-header[aria-expanded=true] .emp-acc-chev{transform:rotate(180deg)}}.rcl-list{display:flex;flex-direction:column;gap:10px}.rcl-sortbar{display:flex;align-items:center;gap:10px;padding:4px 2px 6px}.rcl-card{display:flex;align-items:center;gap:12px;width:100%;min-height:64px;padding:12px 14px;background:var(--glass);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);cursor:pointer;text-align:left;font-family:inherit;color:inherit;transition:box-shadow .15s,border-color .15s;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.rcl-card:hover{box-shadow:var(--shadow-md);border-color:#ffffff2e}.rcl-card:active{transform:scale(.995)}.rcl-card-main{flex:1;min-width:0}.rcl-card-primary{font-weight:700;font-size:15px;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rcl-card-secondary{font-size:13px;color:var(--text-3);margin-top:2px}.rcl-card-meta{font-size:12px;color:var(--text-4);margin-top:2px}.rcl-card-status{flex-shrink:0;display:flex;align-items:center;gap:6px}.rate-card-list{display:flex;flex-direction:column;gap:10px;padding:4px 0}.rate-card{background:var(--glass);border:1px solid var(--border);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.rate-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.rate-card-headline{display:flex;flex-wrap:wrap;align-items:center;gap:6px;min-width:0}.rate-card-eff{font-size:22px;font-weight:800;color:var(--cyan);line-height:1;white-space:nowrap;flex-shrink:0}.rate-card-eff-suffix{font-size:12px;font-weight:600;color:var(--text-3);margin-left:2px}.rate-card-desc{font-size:13px;color:var(--text-3);line-height:1.4}.rate-card-meta{display:flex;flex-wrap:wrap;gap:4px 14px;font-size:12px;color:var(--text-3)}.rate-card-actions{display:flex;gap:8px;padding-top:4px}.rate-card-actions .btn{flex:1}@media (max-width:900px){.payroll-emp-row{flex-direction:column;align-items:stretch;gap:6px;padding:12px 0}.payroll-emp-row>div:last-child{justify-content:flex-start!important;gap:6px!important}.payroll-emp-row>div:last-child>span{margin-left:0!important}}.sidebar-collapse-btn{position:absolute;top:18px;right:10px;width:26px;height:26px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-3);font-size:13px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:background .15s,color .15s}.sidebar-collapse-btn:hover{background:#ffffff1f;color:var(--text-2)}@media (min-width:901px){body[data-sidebar=collapsed] .sidebar{width:64px}body[data-sidebar=collapsed] .main-content{margin-left:64px}body[data-sidebar=collapsed] .brand-text,body[data-sidebar=collapsed] .sidebar-store,body[data-sidebar=collapsed] .nav-group-label,body[data-sidebar=collapsed] .nav-label,body[data-sidebar=collapsed] .nav-badge,body[data-sidebar=collapsed] .user-info,body[data-sidebar=collapsed] .logout-btn{display:none}body[data-sidebar=collapsed] .sidebar-logo{padding:18px 11px}body[data-sidebar=collapsed] .sidebar-collapse-btn{right:18px}body[data-sidebar=collapsed] .brand-row{justify-content:center}body[data-sidebar=collapsed] .nav-item{justify-content:center;padding:12px 6px;border-left-width:3px}body[data-sidebar=collapsed] .nav-icon{width:auto}body[data-sidebar=collapsed] .sidebar-footer{padding:14px 11px}body[data-sidebar=collapsed] .user-row{justify-content:center}}body[data-density=compact] tbody td{padding:8px 12px;font-size:13px;line-height:1.4}body[data-density=compact] thead th{padding:8px 12px;font-size:11px}body[data-density=compact] .td-primary{font-size:13px}body[data-density=compact] .card-body{padding:14px 16px}body[data-density=compact] .card-header{padding:12px 16px}body[data-density=compact] .stat-card{padding:14px 16px}body[data-density=compact] .stat-value{font-size:24px}body[data-density=compact] .stat-label{font-size:12px}body[data-density=compact] .page-body{padding:18px 24px}.sp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;justify-content:flex-end;animation:fadeIn .15s ease}.sp-panel{background:#050c1cf0;-webkit-backdrop-filter:blur(32px);backdrop-filter:blur(32px);border-left:1px solid var(--border);height:100vh;width:520px;max-width:90vw;box-shadow:-12px 0 48px #00000080;display:flex;flex-direction:column;animation:sp-slide-in .2s ease;position:relative}@keyframes sp-slide-in{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.sp-resize{position:absolute;left:0;top:0;bottom:0;width:6px;cursor:col-resize;background:transparent;transition:background .15s}.sp-resize:hover{background:#38bdf833}.sp-header{display:flex;align-items:flex-start;gap:12px;padding:18px 22px;border-bottom:1px solid var(--border);background:transparent;position:sticky;top:0;z-index:2}.sp-header-text{flex:1;min-width:0}.sp-title{font-family:Clash Display,Geist,sans-serif;font-weight:600;font-size:17px;color:var(--text-1);line-height:1.25;letter-spacing:-.02em}.sp-subtitle{font-size:13px;color:var(--text-3);margin-top:4px;line-height:1.4}.sp-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.sp-close{width:30px;height:30px;border-radius:8px;background:var(--glass);border:1px solid var(--border);cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:all .15s}.sp-close:hover{background:var(--glass-2);color:var(--text-1)}.sp-body{flex:1;overflow-y:auto;padding:22px}.sp-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}.sp-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin:0 -22px 18px;padding:0 22px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.sp-tabs::-webkit-scrollbar{display:none}.sp-tab{padding:10px 15px;font-size:14px;font-weight:500;color:var(--text-3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;transition:color .15s,border-color .15s}.sp-tab:hover{color:var(--text-2)}.sp-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.sp-tab-badge{margin-left:6px;background:var(--glass);color:var(--text-3);font-size:11px;font-weight:700;border-radius:10px;padding:1px 8px;min-width:18px;text-align:center}.sp-tab.active .sp-tab-badge{background:#38bdf81f;color:var(--blue)}@media (max-width:900px){.sp-panel{width:100vw!important;max-width:100vw}.sp-resize{display:none}.sp-header{padding:14px 16px}.sp-body{padding:16px}.sp-footer{padding:12px 16px}.sp-tabs{margin:0 -16px 14px;padding:0 16px}}.cp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1100;display:flex;justify-content:center;align-items:flex-start;padding-top:80px;padding-left:16px;padding-right:16px;animation:fadeIn .12s ease}.cp-panel{background:#050c1cf5;-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);border:1px solid var(--border);width:100%;max-width:640px;border-radius:16px;box-shadow:0 32px 80px #000000a6;display:flex;flex-direction:column;max-height:70vh;overflow:hidden;animation:cp-pop .15s ease;position:relative}.cp-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);pointer-events:none}@keyframes cp-pop{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.cp-search{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--border)}.cp-search-icon{font-size:18px;color:var(--text-3)}.cp-input{flex:1;border:none;outline:none;background:transparent;font-family:Geist,sans-serif;font-size:16px;color:var(--text-1);padding:4px 0}.cp-input::placeholder{color:var(--text-4)}.cp-esc{font-family:Geist,monospace;background:var(--glass);border:1px solid var(--border);border-radius:6px;padding:2px 8px;font-size:11px;color:var(--text-3)}.cp-list{flex:1;overflow-y:auto;padding:6px 0}.cp-empty{padding:30px 18px;text-align:center;color:var(--text-3);font-size:13px}.cp-item{display:flex;align-items:center;gap:12px;width:100%;background:none;border:none;border-radius:0;padding:9px 18px;cursor:pointer;text-align:left;font-family:Geist,sans-serif;color:var(--text-1);transition:background .08s}.cp-item:hover,.cp-item.active{background:#ffffff0d}.cp-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0}.cp-text{flex:1;min-width:0;display:flex;flex-direction:column}.cp-title{font-size:14px;font-weight:500;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cp-hint{font-size:12px;color:var(--text-3);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cp-kind{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-4);font-weight:700;background:var(--glass);padding:2px 8px;border-radius:10px;flex-shrink:0;border:1px solid var(--border)}.cp-footer{display:flex;gap:14px;padding:9px 18px;border-top:1px solid var(--border);font-size:11px;color:var(--text-4)}.cp-footer kbd{font-family:Geist,monospace;background:var(--glass);border:1px solid var(--border);border-radius:4px;padding:0 6px;font-size:11px;color:var(--text-3);margin-right:2px}.help-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1100;display:flex;justify-content:center;align-items:center;padding:16px;animation:fadeIn .12s ease}.help-panel{background:#050c1cf5;-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);border:1px solid var(--border);border-radius:16px;box-shadow:0 32px 80px #000000a6;max-width:520px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;animation:cp-pop .15s ease}.help-header{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.help-title{font-family:Clash Display,Geist,sans-serif;font-weight:600;font-size:16px;color:var(--text-1)}.help-body{padding:8px 22px 18px;overflow-y:auto}.help-section{margin-top:12px}.help-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-4);margin-bottom:6px}.help-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;color:var(--text-2)}.help-keys{display:flex;gap:4px}.help-keys kbd{font-family:Geist,monospace;background:var(--glass);border:1px solid var(--border);border-radius:5px;padding:2px 7px;font-size:11px;color:var(--text-2)}.ph-icon-btn{width:32px;height:32px;background:var(--glass);border:1px solid var(--border);border-radius:8px;color:var(--text-3);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.ph-icon-btn:hover{background:#38bdf81a;border-color:#38bdf840;color:var(--blue)}.ph-icon-btn[aria-pressed=true]{background:#38bdf81f;border-color:#38bdf847;color:var(--blue)}.ph-updated{font-size:12px;color:var(--text-4);min-width:60px;text-align:right}@media (max-width:900px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding-bottom:68px;overflow-x:hidden}.page-body{overflow-x:hidden}.page-body input.form-input,.page-body select.form-input,.page-body textarea.form-input,.page-body .form-input{max-width:100%}.mobile-header{display:flex}.page-header{display:none}.bottom-nav{display:block}.page-body{padding:12px 12px 16px}.stat-grid{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}.hero-time{font-size:46px}.accept-banner{flex-wrap:wrap;padding:14px 16px;gap:10px}.wrc-sig{grid-template-columns:1fr}.card-header,.card-body{padding:14px 16px}.roster-grid{min-width:540px}.roster-grid th{padding:6px 4px;font-size:10px}.roster-grid th.emp-col{min-width:80px;padding-left:8px}.roster-grid td{min-width:70px;height:46px}.roster-grid td.emp-name-cell{padding:8px;font-size:12px}.emp-sub{font-size:10px}.shift-cell{padding:3px 4px!important;min-height:34px!important;font-size:10px!important}.shift-time{font-size:9px!important}.modal-overlay{padding:8px}.modal-box{border-radius:14px;max-height:93vh}.modal-body{padding:14px!important}.modal-header{padding:12px 14px!important}.modal-footer{padding:10px 14px!important}.bn-item{padding:4px 6px}.bn-icon{font-size:20px}.bn-label{font-size:10px}.table-wrap{position:relative}.table-wrap:after{content:"";position:absolute;right:0;top:0;bottom:0;width:20px;background:linear-gradient(90deg,transparent,rgba(3,9,24,.85));pointer-events:none}.week-label{font-size:12px;padding:4px 6px}.table-wrap:not(.table-no-card-transform) table,.table-wrap:not(.table-no-card-transform) thead,.table-wrap:not(.table-no-card-transform) tbody,.table-wrap:not(.table-no-card-transform) th{display:block}.table-wrap:not(.table-no-card-transform) thead tr{position:absolute;top:-9999px;left:-9999px}.table-wrap:not(.table-no-card-transform) tbody tr{display:grid;grid-template-columns:1fr 1fr;gap:2px 10px;background:var(--glass);border:1px solid var(--border);border-radius:12px;margin-bottom:10px;box-shadow:var(--shadow);padding:8px 12px;overflow:hidden}.table-wrap:not(.table-no-card-transform) td{display:block;border:none;padding:4px 0!important;text-align:left!important;font-size:13px!important;color:var(--text-2);line-height:1.3;word-break:break-word;min-width:0}.table-wrap:not(.table-no-card-transform) td:before{display:block;white-space:normal;text-align:left;font-weight:700;color:var(--text-4);font-size:10px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1px;content:attr(data-label);line-height:1.15}.table-wrap:not(.table-no-card-transform) td:not([data-label]):before,.table-wrap:not(.table-no-card-transform) td[data-label=""]:before{content:none}.table-wrap:not(.table-no-card-transform) td:empty,.table-wrap:not(.table-no-card-transform) td[data-empty=true]{display:none!important}.table-wrap:not(.table-no-card-transform) td.td-primary{grid-column:1 / -1;margin:-8px -12px 4px;padding:8px 12px!important;background:#ffffff0a;border-bottom:1px solid var(--border);font-size:15px!important;font-weight:700!important;color:var(--text-1)!important}.table-wrap:not(.table-no-card-transform) td.td-primary:before{content:none}.table-wrap:not(.table-no-card-transform) td:last-child:has(button){grid-column:1 / -1;padding-top:6px!important;display:flex!important;flex-wrap:wrap;gap:6px}.table-wrap:not(.table-no-card-transform) td:last-child:has(button):before{content:none}.table-wrap:not(.table-no-card-transform) td:last-child:has(button) .btn{flex:1;min-width:0}.table-wrap.table-no-card-transform{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap.table-no-card-transform table{min-width:640px}}@media print{.no-print{display:none!important}#signoff-report{display:block!important}@page{size:A4 landscape;margin:10mm}.sidebar,.bottom-nav,.mobile-header,.page-header{display:none!important}.main-content{margin-left:0!important}.page-body{padding:4px 12px!important}.wrc-top,.wrc-table th,.wrc-totrow td{-webkit-print-color-adjust:exact;print-color-adjust:exact}}@media (prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
