:root{--bg:#faf8ff;--surface:#fff;--border:#ede8fc;--border-soft:#f4f1fd;--text:#4a4168;--text-muted:#9d90c0;--text-heading:#1a1040;--primary:#7c3aed;--primary-dark:#6d28d9;--primary-light:#f3f0ff;--primary-glow:#7c3aed2e;--green:#059669;--green-dark:#047857;--green-light:#ecfdf5;--green-glow:#05966926;--amber:#d97706;--amber-light:#fffbeb;--danger:#ef4444;--danger-light:#fef2f2;--radius:14px;--radius-sm:8px;--radius-xs:5px;--radius-pill:99px;--shadow-sm:0 1px 4px #7c3aed12, 0 1px 2px #0000000a;--shadow:0 4px 16px #7c3aed17, 0 1px 4px #0000000d;--shadow-md:0 8px 28px #7c3aed21, 0 2px 8px #0000000f;--shadow-lg:0 20px 60px #7c3aed2e, 0 4px 16px #00000014;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.6}@media (prefers-color-scheme:dark){:root{--bg:#0d0a1f;--surface:#15102d;--border:#27204a;--border-soft:#1e1840;--text:#c2b4e8;--text-muted:#6b5f90;--text-heading:#f0ecff;--primary-light:#1e1545;--primary-glow:#7c3aed40;--green-light:#042a1a;--green-glow:#05966933;--amber-light:#1c1200;--danger-light:#2d0a0a;--shadow-sm:0 1px 4px #00000080;--shadow:0 4px 16px #0000008c;--shadow-md:0 8px 28px #000000a6;--shadow-lg:0 20px 60px #000000bf}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg)}h1,h2,h3{color:var(--text-heading);letter-spacing:-.02em;font-weight:700}h1{font-size:1.7rem}h2{font-size:1.05rem}h3{font-size:.95rem}p{color:var(--text)}input,select,textarea,button{font-family:inherit;font-size:inherit}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}#root,.app-layout{flex-direction:column;min-height:100svh;display:flex}.app-header{background:var(--header-gradient,linear-gradient(150deg, #1a083f 0%, #2d1b69 55%, #3d2280 100%));flex-shrink:0;position:relative;overflow:hidden}.app-header:before{content:"";pointer-events:none;background:radial-gradient(70% 60% at 80% -10%,#a78bfa26 0%,#0000 60%),radial-gradient(50% 80% at -10% 100%,#05966914 0%,#0000 50%);position:absolute;inset:0}.header-inner{width:100%;max-width:1100px;margin:0 auto;padding:32px 40px 0;position:relative}.header-top-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.header-brand{letter-spacing:.01em;color:#ffffffe6;align-items:center;gap:4px;font-size:.9rem;font-weight:800;display:flex}.brand-blossom{font-size:1rem}.header-greeting-row{align-items:center;gap:10px;margin-bottom:4px;display:flex}.header-greeting{color:#fff;letter-spacing:-.03em;font-size:2.5rem;font-weight:800;line-height:1.1}.header-sub{color:#ffffff80;margin-bottom:28px;font-size:.88rem;font-weight:500}.name-edit-btn{color:#ffffff80;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;margin-top:2px;transition:background .2s,color .2s,border-color .2s;display:flex}.name-edit-btn:hover{color:#fff;background:#ffffff2e;border-color:#ffffff4d}.name-edit-form{align-items:center;gap:8px;margin-bottom:14px;display:flex}.name-edit-input{border-radius:var(--radius-sm);color:#fff;background:#ffffff1a;border:1px solid #fff3;outline:none;width:200px;padding:7px 12px;font-size:.9rem;transition:border-color .2s,background .2s}.name-edit-input::placeholder{color:#ffffff4d}.name-edit-input:focus{background:#ffffff26;border-color:#ffffff80}.header-stats{flex-wrap:wrap;gap:10px;margin-bottom:28px;display:flex}.hstat-card{border-radius:var(--radius);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff1a;align-items:center;gap:8px;padding:10px 16px;transition:background .2s,border-color .2s;display:flex}.hstat-card:hover{background:#ffffff1f;border-color:#ffffff2e}.hstat-icon{font-size:1rem;line-height:1}.hstat-value{color:#fff;font-size:.95rem;font-weight:700}.hstat-label{color:#ffffff73;font-size:.73rem;font-weight:500}.hstat-sub{color:#fff9;margin-top:2px;font-size:.7rem;font-weight:500}.header-clock-badge{border-radius:var(--radius-pill);background:#05966933;border:1px solid #05966959;align-items:center;gap:7px;padding:5px 14px;display:flex}.pulse-dot{background:#10b981;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.4s ease-in-out infinite pulse-live}.header-clock-emp{font-size:.78rem;font-weight:700}.header-clock-time{font-variant-numeric:tabular-nums;color:#fff;letter-spacing:.01em;font-size:.8rem;font-weight:700}.header-tabs{gap:2px;padding-bottom:20px;display:flex}.tab-link{border-radius:var(--radius-pill);color:#ffffff80;white-space:nowrap;padding:8px 20px;font-size:.875rem;font-weight:600;text-decoration:none;transition:color .2s,background .2s}.tab-link:hover{color:#ffffffd9;text-decoration:none}.tab-link.active{color:var(--primary-dark);background:#fffffff2;box-shadow:0 2px 8px #00000026}.main-content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:32px 40px;overflow-y:auto}.page{flex-direction:column;gap:24px;animation:.35s cubic-bezier(.22,1,.36,1) both fadeSlideUp;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.page-sub{color:var(--text-muted);margin-top:2px;font-size:.83rem;font-weight:500}.section{flex-direction:column;gap:14px;display:flex}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.section-header-actions{align-items:center;gap:10px;display:flex}.link{color:var(--primary);font-size:.875rem;font-weight:600}.link:hover{text-decoration:underline}.muted{color:var(--text-muted);font-size:.875rem}.btn{border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:9px 18px;font-size:.875rem;font-weight:600;text-decoration:none;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s,background .18s,opacity .18s;display:inline-flex;position:relative}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.96)!important}.btn-primary{background:linear-gradient(135deg, #8b4ff0 0%, var(--primary) 60%, var(--primary-dark) 100%);color:#fff;box-shadow:0 2px 10px var(--primary-glow)}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px var(--primary-glow);transform:translateY(-2px)}.btn-secondary{background:var(--surface);color:var(--text-heading);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--bg);transform:translateY(-1px)}.btn-ghost{color:var(--text);background:0 0;border:none}.btn-ghost:hover:not(:disabled){background:var(--primary-light);color:var(--primary)}.btn-danger{background:linear-gradient(135deg, #f87171 0%, var(--danger) 100%);color:#fff;box-shadow:0 2px 10px #ef444440}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ef44444d}.btn-sm{padding:6px 14px;font-size:.8rem}.icon-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s,transform .15s;display:inline-flex}.icon-btn:hover{background:var(--primary-light);color:var(--primary);transform:scale(1.1)}.icon-btn.danger:hover{background:var(--danger-light);color:var(--danger)}.header-actions{align-items:center;gap:10px;display:flex}.view-toggle{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);display:flex;overflow:hidden}.toggle-btn{width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.toggle-btn:hover{background:var(--bg);color:var(--text)}.toggle-btn.active{background:var(--primary);color:#fff}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px 24px;transition:transform .22s cubic-bezier(.34,1.26,.64,1),box-shadow .22s;position:relative;overflow:hidden}.stat-card:after{content:"";background:linear-gradient(90deg, var(--primary), var(--green));transform-origin:0;border-radius:0 0 var(--radius) var(--radius);height:3px;transition:transform .3s;position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.stat-card:hover:after{transform:scaleX(1)}.stat-card.accent{border-left:3px solid var(--green)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;font-size:.72rem;font-weight:700}.stat-value{color:var(--text-heading);font-size:1.7rem;font-weight:800;line-height:1}.stat-sub{color:var(--text-muted);margin-top:4px;font-size:.78rem;font-weight:500}.card-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px;display:grid}.employer-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:18px;padding:22px;transition:transform .22s cubic-bezier(.34,1.26,.64,1),box-shadow .22s;display:flex}.employer-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.employer-card-top{justify-content:space-between;align-items:flex-start;display:flex}.employer-info{align-items:center;gap:10px;display:flex}.employer-role{color:var(--text-muted);margin-top:2px;font-size:.78rem;font-weight:500}.card-actions{gap:4px;display:flex}.employer-stats{border-top:1px solid var(--border-soft);grid-template-columns:1fr 1fr;gap:12px;padding-top:14px;display:grid}.stat-val{color:var(--text-heading);font-size:.9rem;font-weight:700}.shift-list{flex-direction:column;display:flex}.shift-list.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.shift-row{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;transition:background .15s;display:flex}.shift-row:last-child{border-bottom:none}.shift-row:hover{background:var(--primary-light)}.shift-row-left{align-items:flex-start;gap:12px;min-width:0;display:flex}.shift-row-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.shift-employer{color:var(--text-heading);font-size:.9rem;font-weight:700}.shift-date{color:var(--text-muted);margin-top:1px;font-size:.79rem;font-weight:500}.shift-notes{color:var(--text-muted);margin-top:2px;font-size:.76rem;font-style:italic}.shift-pay{color:var(--green);font-size:.95rem;font-weight:800}.shift-hours{color:var(--text-muted);font-size:.79rem;font-weight:600}.shift-tips{color:var(--green);font-size:.76rem;font-weight:600}.shift-overtime{color:var(--amber);font-size:.76rem;font-weight:700}.shift-undertime{color:var(--primary);font-size:.76rem;font-weight:700}.overtime-text{color:var(--amber);font-weight:700}.undertime-text{color:var(--primary);font-weight:700}.row-actions{gap:2px;display:flex}.employer-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px;box-shadow:0 0 0 2px #fffc}.employer-dot.large{width:14px;height:14px;margin-top:0}.shift-times-stack{flex-direction:column;gap:4px;margin-top:2px;display:flex}.shift-time-line{align-items:center;gap:6px;display:flex}.time-badge{letter-spacing:.06em;border-radius:var(--radius-xs);background:var(--border);color:var(--text-muted);text-transform:uppercase;flex-shrink:0;padding:1px 6px;font-size:.6rem;font-weight:800}.time-badge.actual-badge{background:var(--green-light);color:var(--green-dark)}@media (prefers-color-scheme:dark){.time-badge.actual-badge{color:#6ee7b7;background:#042a1a}}.form{flex-direction:column;gap:16px;display:flex}.field{color:var(--text-heading);flex-direction:column;gap:6px;min-width:0;font-size:.875rem;font-weight:600;display:flex}.field-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.field input,.field select,.field textarea{box-sizing:border-box;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text-heading);outline:none;padding:10px 13px;font-weight:500;transition:border-color .2s,box-shadow .2s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.field textarea{resize:vertical}.form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.color-picker{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.color-swatch{cursor:pointer;border:3px solid #0000;border-radius:50%;width:28px;height:28px;transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .15s}.color-swatch.selected{border-color:var(--text-heading);transform:scale(1.2);box-shadow:0 2px 8px #0003}.pay-preview{background:linear-gradient(135deg, var(--green-light), #fff0);border-radius:var(--radius-sm);color:var(--green-dark);border:1.5px solid #05966933;justify-content:space-between;align-items:center;padding:12px 16px;font-size:.875rem;font-weight:600;display:flex}.pay-preview-amount{color:var(--green);font-size:1.05rem;font-weight:800}.pay-preview-row{align-items:center;gap:10px;display:flex}.pay-preview-label{text-transform:uppercase;letter-spacing:.08em;color:var(--green-dark);opacity:.7;min-width:64px;font-size:.68rem;font-weight:800}.shift-section{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:10px;padding:14px;display:flex}.shift-section-actual{background:var(--green-light);border-color:#0596694d}@media (prefers-color-scheme:dark){.shift-section-actual{background:#042a1a}}.shift-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.68rem;font-weight:800}.shift-section-label.actual{color:var(--green-dark)}.actual-toggle{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:.875rem;font-weight:500;display:flex}.actual-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--green);cursor:pointer}.filter-bar{color:var(--text-muted);align-items:center;gap:10px;display:flex}.filter-bar select{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);outline:none;padding:7px 12px;font-size:.875rem;font-weight:500;transition:border-color .2s}.filter-bar select:focus{border-color:var(--primary)}.month-select{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);outline:none;padding:8px 14px;font-size:.875rem;font-weight:600;transition:border-color .2s,box-shadow .2s}.month-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0f05288c;justify-content:center;align-items:center;padding:16px;animation:.15s both fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:calc(var(--radius) + 4px);box-shadow:var(--shadow-lg);border:1px solid var(--border);width:100%;max-width:490px;max-height:92svh;animation:.25s cubic-bezier(.34,1.4,.64,1) both scaleSpring;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;padding:22px 22px 0;display:flex}.modal-body{padding:22px}.welcome-modal{text-align:center;max-width:380px}.welcome-emoji{margin-bottom:10px;font-size:3rem}.welcome-sub{color:var(--text-muted);margin-top:6px;font-size:.9rem;font-weight:500}.welcome-name-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text-heading);text-align:center;outline:none;padding:12px 15px;font-size:1rem;font-weight:600;transition:border-color .2s,box-shadow .2s}.welcome-name-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.calendar-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:18px;padding:24px;display:flex}.calendar-nav{align-items:center;gap:12px;display:flex}.calendar-month{color:var(--text-heading);flex:1;font-size:1rem;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:5px;display:grid}.cal-header-cell{text-align:center;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:8px 0;font-size:.7rem;font-weight:800}.cal-cell{border-radius:var(--radius-sm);cursor:pointer;background:var(--bg);border:1.5px solid #0000;flex-direction:column;gap:4px;min-height:110px;padding:8px;transition:background .15s,border-color .15s,transform .15s;display:flex}.cal-cell:hover{background:var(--primary-light);border-color:#7c3aed33;transform:scale(1.02)}.cal-cell.out-month{opacity:.3}.cal-cell.today .cal-day-num{background:var(--primary);color:#fff;width:26px;height:26px;box-shadow:0 2px 8px var(--primary-glow);border-radius:50%;justify-content:center;align-items:center;display:flex}.cal-cell.selected{background:var(--primary-light);border-color:var(--primary)}.cal-cell.has-shifts{border-color:var(--border)}.cal-day-num{color:var(--text-heading);justify-content:center;align-items:center;width:26px;height:26px;font-size:.82rem;font-weight:700;line-height:1;display:flex}.cal-pills{flex-direction:column;gap:2px;display:flex}.cal-pill{color:#fff;white-space:nowrap;text-overflow:ellipsis;border-radius:4px;max-width:100%;padding:2px 5px;font-size:.68rem;font-weight:700;overflow:hidden;box-shadow:0 1px 3px #00000026}.cal-pill-more{color:var(--text-muted);padding:1px 3px;font-size:.66rem;font-weight:600}.cal-cell.is-holiday{background:#dc26260f}.cal-cell.is-holiday .cal-day-num{color:#dc2626;font-weight:700}.cal-holiday-label{color:#dc2626;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.58rem;font-weight:600;line-height:1.2;display:block;overflow:hidden}.cal-holiday-banner{color:#dc2626;margin:4px 0 0;font-size:.82rem;font-weight:600}.calendar-legend{color:var(--text-muted);align-items:center;gap:16px;padding:8px 4px;font-size:.78rem;display:flex}.cal-legend-item{align-items:center;gap:6px;display:flex}.cal-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cal-legend-holiday-dot{background:#dc262626;border:1.5px solid #dc2626;border-radius:3px;flex-shrink:0;width:10px;height:10px}.cal-detail{border-top:1.5px solid var(--border-soft);flex-direction:column;gap:14px;padding-top:18px;animation:.2s both fadeSlideUp;display:flex}.cal-detail-header{justify-content:space-between;align-items:center;display:flex}.cal-detail-empty{color:var(--text-muted);font-size:.875rem;font-weight:500}.cal-detail-list{flex-direction:column;gap:8px;display:flex}.cal-detail-row{border-left:3px solid var(--border);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:var(--bg);cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;transition:background .15s,transform .15s;display:flex}.cal-detail-row:hover{background:var(--primary-light);transform:translate(3px)}.cal-detail-times{flex:1;min-width:0}.cal-detail-pay{text-align:right;flex-shrink:0}.cal-day-total{background:var(--primary-light);border:1.5px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;margin-top:8px;padding:10px 14px;display:flex}.cal-day-total-label{color:var(--text-muted);font-size:13px;font-weight:600}.cal-day-total-amount{color:var(--primary);font-size:16px;font-weight:800}.clock-widget{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:14px;padding:20px 24px;transition:box-shadow .2s;display:flex}.clock-idle{gap:16px}.clock-idle-status{align-items:center;gap:10px;display:flex}.clock-idle-body{flex-direction:column;gap:14px;display:flex}.clock-idle-employer-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.clock-employer-name{color:var(--text-heading);align-items:center;gap:7px;font-size:.9rem;font-weight:700;display:flex}.clock-rate-badge{color:var(--green-dark);background:var(--green-light);border-radius:var(--radius-pill);border:1px solid #05966933;padding:3px 10px;font-size:.78rem;font-weight:700}@media (prefers-color-scheme:dark){.clock-rate-badge{color:#6ee7b7;background:#042a1a;border-color:#6ee7b726}}.btn-clock-in{background:linear-gradient(135deg, #34d399 0%, var(--green) 60%, var(--green-dark) 100%);color:#fff;box-shadow:0 4px 18px var(--green-glow);border-radius:var(--radius-pill);cursor:pointer;letter-spacing:.01em;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:16px 32px;font-size:1.05rem;font-weight:700;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s;display:inline-flex}.btn-clock-in:hover:not(:disabled){box-shadow:0 8px 28px var(--green-glow);transform:translateY(-3px)}.btn-clock-in:active:not(:disabled){transform:scale(.97)}.btn-clock-in:disabled{opacity:.45;cursor:not-allowed}.btn-clock-out{background:linear-gradient(135deg, #f87171 0%, var(--danger) 100%);color:#fff;border-radius:var(--radius-pill);cursor:pointer;letter-spacing:.01em;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:16px 32px;font-size:1.05rem;font-weight:700;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s;display:inline-flex;box-shadow:0 4px 18px #ef44444d}.btn-clock-out:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 28px #ef444466}.btn-clock-out:active:not(:disabled){transform:scale(.97)}.clock-live-earning{background:var(--green-light);border-radius:var(--radius-sm);border:1px solid #0596692e;justify-content:space-between;align-items:center;padding:11px 16px;display:flex}.clock-live-amount{color:var(--green);font-variant-numeric:tabular-nums;font-size:1.2rem;font-weight:800}@media (prefers-color-scheme:dark){.clock-live-earning{background:#042a1a;border-color:#6ee7b71f}}.clock-monthly-total{background:var(--primary-light);border-radius:var(--radius-sm);border:1px solid #7c3aed26;justify-content:space-between;align-items:center;padding:11px 16px;display:flex}.clock-monthly-amount{color:var(--primary);font-size:1rem;font-weight:800}.clock-employer-select{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);outline:none;padding:8px 12px;font-size:.875rem;font-weight:600;transition:border-color .2s}.clock-employer-select:focus{border-color:var(--primary)}.clock-active{border-left:4px solid var(--green);background:linear-gradient(135deg, var(--surface) 0%, #05966908 100%);box-shadow:var(--shadow), 0 0 0 1px #0596691a}.clock-active-header{justify-content:space-between;align-items:center;display:flex}.clock-active-left{align-items:center;gap:10px;display:flex}.clock-timer{font-variant-numeric:tabular-nums;color:var(--green);letter-spacing:-.02em;font-size:1.65rem;font-weight:800}.clock-time-row{align-items:center;gap:8px;display:flex}.clock-time-value{color:var(--text-muted);font-size:.875rem;font-weight:500}.clock-field-label{text-transform:uppercase;letter-spacing:.09em;color:var(--text-muted);flex-shrink:0;font-size:.66rem;font-weight:800}.clock-override-form{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.clock-override-input{border:1.5px solid var(--primary);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-heading);box-shadow:0 0 0 3px var(--primary-glow);outline:none;padding:7px 12px;font-size:.875rem;font-weight:500}.clock-active-actions{justify-content:flex-end;display:flex}.clock-review{border-left:4px solid var(--primary);background:linear-gradient(135deg, var(--surface) 0%, #7c3aed08 100%)}.clock-review-header{align-items:center;gap:10px;display:flex}.clock-review-title{color:var(--text-heading);font-size:.95rem;font-weight:700}.clock-review-form{flex-direction:column;gap:14px;display:flex}.clock-review-times{grid-template-columns:1fr 1fr;gap:12px;display:grid}.clock-review-field{color:var(--text-heading);flex-direction:column;gap:6px;font-size:.875rem;font-weight:600;display:flex}.clock-review-field input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-heading);outline:none;padding:9px 12px;font-size:.875rem;font-weight:500;transition:border-color .2s,box-shadow .2s}.clock-review-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.clock-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.clock-dot.off{background:var(--border)}.clock-dot.on{background:var(--green);box-shadow:0 0 0 3px var(--green-glow);animation:1.6s ease-in-out infinite pulse-green}.clock-status-label{color:var(--text);font-size:.875rem;font-weight:600}.clock-employer-chip{color:#fff;border-radius:var(--radius-pill);padding:3px 10px;font-size:.75rem;font-weight:700;box-shadow:0 2px 6px #00000026}.log-actual-btn{color:var(--primary)!important}.log-actual-btn:hover{background:var(--primary-light)!important;color:var(--primary-dark)!important}.roster-list{flex-direction:column;gap:10px;display:flex}.roster-entry{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:10px;padding:14px 16px;transition:transform .2s,box-shadow .2s;display:flex}.roster-entry:hover{box-shadow:var(--shadow);transform:translate(3px)}.roster-entry.status-upcoming{border-left-color:var(--primary)}.roster-entry.status-completed{border-left-color:var(--green)}.roster-entry.status-missed{border-left-color:var(--danger)}.roster-entry-header{align-items:center;gap:8px;display:flex}.roster-entry-header .shift-employer{flex:1;min-width:0;margin:0}.roster-entry-body{flex-direction:column;gap:6px;padding-left:20px;display:flex}.roster-time-block{align-items:flex-start;gap:8px;display:flex}.roster-time-detail{flex-direction:column;gap:2px;display:flex}.roster-date{color:var(--text-primary);font-size:.82rem;font-weight:600}.roster-timerange{color:var(--text-muted);font-size:.79rem}.roster-entry-actions{justify-content:flex-end;gap:4px;display:flex}.status-badge{letter-spacing:.07em;text-transform:uppercase;border-radius:var(--radius-pill);padding:3px 10px;font-size:.65rem;font-weight:800}.status-upcoming{background:var(--primary-light);color:var(--primary-dark)}.status-completed{background:var(--green-light);color:var(--green-dark)}.status-missed{background:var(--danger-light);color:var(--danger)}@media (prefers-color-scheme:dark){.status-upcoming{color:#a78bfa;background:#1e1545}.status-completed{color:#6ee7b7;background:#042a1a}.status-missed{color:#fca5a5;background:#2d0a0a}}.charts-stack{flex-direction:column;gap:20px;display:flex}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 28px 20px;transition:transform .2s,box-shadow .2s}.chart-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.chart-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:24px;font-size:.75rem;font-weight:800}.chart-tooltip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:160px;padding:12px 16px;font-size:.85rem}.chart-tooltip-label{color:var(--text-heading);margin-bottom:6px;font-size:.88rem;font-weight:700}.employer-breakdown{flex-direction:column;gap:22px;display:flex}.breakdown-row{flex-direction:column;gap:7px;display:flex}.breakdown-header{justify-content:space-between;align-items:center;display:flex}.breakdown-nums{align-items:center;gap:14px;font-size:.9rem;display:flex}.breakdown-meta{color:var(--text-muted);font-size:.76rem;font-weight:500}.progress-bar{background:var(--border);border-radius:var(--radius-pill);height:7px;overflow:hidden}.progress-fill{border-radius:var(--radius-pill);height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.empty-state{text-align:center;background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:14px;padding:56px 24px;display:flex}.empty-icon{filter:drop-shadow(0 4px 8px #0000001a);font-size:3rem}.empty-state h3{color:var(--text-heading);font-size:1rem}.empty-state p{color:var(--text-muted);max-width:300px;font-size:.875rem;font-weight:500;line-height:1.5}.onboarding-banner{background:linear-gradient(135deg, var(--primary-light), #fff0);border-radius:var(--radius);border:1.5px solid #7c3aed33;align-items:center;gap:16px;padding:18px 22px;font-size:.875rem;display:flex}.onboarding-banner span{font-size:1.6rem}.onboarding-banner strong{color:var(--text-heading);font-size:.9rem}.onboarding-banner p{color:var(--text-muted);margin-top:2px;font-weight:500}.onboarding-banner .btn{flex-shrink:0;margin-left:auto}.auth-page{background:radial-gradient(80% 60% at 20% 10%,#7c3aed59 0%,#0000 60%),radial-gradient(60% 70% at 80% 90%,#0596694d 0%,#0000 55%),linear-gradient(160deg,#0d0622 0%,#1a083f 40%,#0b2e24 75%,#071a16 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100svh;padding:24px 16px;display:flex;position:relative;overflow:hidden}.auth-blob{pointer-events:none;filter:blur(70px);opacity:.4;border-radius:50%;position:absolute}.auth-blob-1{background:radial-gradient(circle,#7c3aed 0%,#0000 70%);width:480px;height:480px;animation:14s ease-in-out infinite alternate blobDrift;top:-160px;left:-140px}.auth-blob-2{background:radial-gradient(circle,#059669 0%,#0000 70%);width:400px;height:400px;animation:18s ease-in-out infinite alternate-reverse blobDrift;bottom:-120px;right:-100px}.auth-blob-3{background:radial-gradient(circle,#a78bfa 0%,#0000 70%);width:260px;height:260px;animation:22s ease-in-out infinite alternate blobDrift;top:45%;left:60%}@keyframes blobDrift{0%{transform:translate(0)scale(1)}to{transform:translate(30px,20px)scale(1.08)}}.auth-card{background:var(--surface);z-index:1;border:1px solid #ffffff0f;border-radius:24px;width:100%;max-width:440px;padding:44px 40px 40px;animation:.45s cubic-bezier(.22,1,.36,1) both authCardIn;position:relative;box-shadow:0 24px 80px #00000080,0 0 0 1px #ffffff0a}@keyframes authCardIn{0%{opacity:0;transform:translateY(24px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-shake{animation:.5s cubic-bezier(.36,.07,.19,.97) both authShake!important}@keyframes authShake{0%,to{transform:translate(0)}12%{transform:translate(-7px)}37%{transform:translate(7px)}62%{transform:translate(-4px)}87%{transform:translate(4px)}}.auth-brand-block{text-align:center;margin-bottom:30px}.auth-logo-wrap{background:linear-gradient(135deg,#7c3aed1f,#0596691f);border:1.5px solid #7c3aed33;border-radius:20px;justify-content:center;align-items:center;width:68px;height:68px;margin:0 auto 14px;font-size:2rem;animation:.55s cubic-bezier(.34,1.56,.64,1) both scaleSpring;display:flex;box-shadow:0 4px 20px #7c3aed26}.auth-brand-name{color:var(--text-heading);letter-spacing:-.02em;font-size:1.55rem;font-weight:800;line-height:1.1}.auth-tagline{color:var(--text-muted);margin-top:5px;font-size:.82rem;font-weight:500}.auth-tabs{background:var(--bg);border-radius:12px;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:26px;padding:4px;display:grid}.auth-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:9px;padding:10px 8px;font-family:inherit;font-size:.88rem;font-weight:600;line-height:1;transition:background .2s,color .2s,box-shadow .2s}.auth-tab.active{background:var(--surface);color:var(--primary);box-shadow:0 2px 8px #0000001a, 0 0 0 1px var(--border)}.auth-alert{border-radius:10px;align-items:flex-start;gap:8px;margin-bottom:16px;padding:12px 14px;font-size:.85rem;font-weight:600;line-height:1.45;animation:.2s both fadeSlideUp;display:flex}.auth-alert-icon{flex-shrink:0;margin-top:1px;font-size:.95rem}.auth-alert-error{background:var(--danger-light);color:var(--danger);border:1px solid #ef444433}.auth-alert-success{background:var(--green-light);color:var(--green-dark);border:1px solid #05966933}@media (prefers-color-scheme:dark){.auth-alert-success{color:#6ee7b7;background:#042a1a}}.auth-form{flex-direction:column;gap:18px;animation:.28s cubic-bezier(.22,1,.36,1) both fadeSlideUp;display:flex}.auth-field{flex-direction:column;gap:7px;display:flex}.auth-field label{color:var(--text-heading);letter-spacing:.01em;font-size:.8rem;font-weight:700}.auth-input{border:1.5px solid var(--border);background:var(--bg);width:100%;height:52px;color:var(--text-heading);-webkit-appearance:none;border-radius:12px;outline:none;padding:0 16px;font-family:inherit;font-size:.975rem;font-weight:500;transition:border-color .2s,box-shadow .2s}.auth-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.auth-input::placeholder{color:var(--text-muted);font-weight:400}.auth-input-wrap{position:relative}.auth-input-wrap .auth-input{padding-right:50px}.auth-eye-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:5px;line-height:0;transition:color .15s,background .15s;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.auth-eye-btn:hover{color:var(--text);background:var(--border-soft)}.auth-options-row{justify-content:space-between;align-items:center;margin-top:-4px;display:flex}.auth-remember{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:.85rem;font-weight:500;display:flex}.auth-remember input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;border-radius:4px}.auth-text-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.85rem;font-weight:600;transition:color .15s}.auth-text-btn:hover{color:var(--primary)}.auth-text-btn.bold{color:var(--primary);text-underline-offset:2px;font-weight:700;text-decoration:underline}.auth-text-btn.bold:hover{color:var(--primary-dark)}.auth-google-btn{color:#3c4043;cursor:pointer;background:#fff;border:1.5px solid #dadce0;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;height:52px;margin-bottom:4px;font-family:inherit;font-size:.9375rem;font-weight:600;transition:box-shadow .18s,border-color .18s,transform .15s;display:flex;box-shadow:0 1px 4px #0000001a,0 0 #4285f400}.auth-google-btn:hover:not(:disabled){border-color:#bdc1c6;transform:translateY(-1px);box-shadow:0 2px 10px #00000024}.auth-google-btn:active:not(:disabled){transform:scale(.98)}.auth-google-btn:disabled{opacity:.65;cursor:not-allowed}.auth-google-spinner{border:2.5px solid #dadce0;border-top-color:#4285f4;border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.65s linear infinite spin}.auth-submit-btn{color:#fff;letter-spacing:.01em;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#7c3aed 100%);border:none;border-radius:14px;justify-content:center;align-items:center;gap:9px;width:100%;height:54px;margin-top:4px;font-family:inherit;font-size:1rem;font-weight:700;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #7c3aed59,0 1px 4px #00000026}.auth-submit-btn:before{content:"";border-radius:inherit;background:linear-gradient(135deg,#ffffff1f 0%,#0000 60%);position:absolute;inset:0}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px #7c3aed73,0 2px 8px #00000026}.auth-submit-btn:active:not(:disabled){transform:scale(.97)}.auth-submit-btn:disabled{opacity:.65;cursor:not-allowed}.auth-btn-spinner{border:2.5px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.65s linear infinite spin}.auth-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:12px;margin:22px 0 16px;font-size:.78rem;font-weight:700;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-switch-text{text-align:center;color:var(--text-muted);font-size:.875rem;font-weight:500}.auth-forgot-header{align-items:center;gap:12px;margin-bottom:4px;display:flex}.auth-mode-title{color:var(--text-heading);flex:1;font-size:1.1rem;font-weight:800}.auth-mode-sub{color:var(--text-muted);margin-top:-4px;font-size:.875rem;font-weight:500;line-height:1.5}.auth-back-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:4px 0;font-family:inherit;font-size:.85rem;font-weight:700;transition:color .15s}.auth-back-btn:hover{color:var(--primary)}.auth-confirm-block{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:8px 0 4px;animation:.3s both fadeSlideUp;display:flex}.auth-confirm-icon{font-size:3.5rem;line-height:1;animation:.45s cubic-bezier(.34,1.56,.64,1) both scaleSpring}.auth-confirm-title{color:var(--text-heading);letter-spacing:-.02em;font-size:1.3rem;font-weight:800}.auth-confirm-body{color:var(--text-muted);max-width:300px;font-size:.9rem;font-weight:500;line-height:1.55}.auth-confirm-body strong{color:var(--text-heading)}.auth-spinner-wrap{justify-content:center;align-items:center;display:flex}.header-top-right{align-items:center;gap:12px;display:flex}.btn-signout{color:#ffffffa6;border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff26;align-items:center;gap:6px;padding:6px 14px;font-family:inherit;font-size:.8rem;font-weight:600;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.btn-signout:hover:not(:disabled){color:#fff;background:#ffffff24;border-color:#ffffff4d}.btn-signout:disabled{opacity:.5;cursor:not-allowed}.loading-screen{min-height:100svh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:.9rem;font-weight:600;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.data-loading-bar{z-index:999;background:#7c3aed26;height:3px;position:fixed;top:0;left:0;right:0}.data-loading-progress{background:linear-gradient(90deg, var(--primary), var(--green));border-radius:0 2px 2px 0;height:100%;animation:1.4s ease-in-out infinite loadProgress}@keyframes loadProgress{0%{opacity:1;width:0%}60%{opacity:1;width:85%}to{opacity:0;width:100%}}.access-pending-card{text-align:center}.access-pending-icon{margin:4px 0 12px;font-size:3rem}.access-pending-title{color:var(--text-primary);margin:0 0 10px;font-size:1.25rem;font-weight:700}.access-pending-body{color:var(--text-muted);margin:0 0 8px;font-size:.9rem;line-height:1.6}.inactivity-overlay{z-index:9999;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.inactivity-modal{background:var(--card-bg);text-align:center;border-radius:20px;width:min(340px,88vw);padding:36px 28px 28px;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleSpring;box-shadow:0 24px 64px #0000004d}.inactivity-icon{margin-bottom:12px;font-size:2.5rem}.inactivity-title{color:var(--text-primary);margin:0 0 10px;font-size:1.2rem;font-weight:700}.inactivity-body{color:var(--text-muted);margin:0 0 24px;font-size:.9375rem;line-height:1.5}.inactivity-countdown{color:var(--primary);font-variant-numeric:tabular-nums;font-size:1.05rem}.inactivity-btn{justify-content:center;width:100%;padding:13px}.earnings-pie-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.earnings-pie-empty{text-align:center;color:var(--text-muted);padding:40px 0;font-size:.9rem}.earnings-pie-legend{border-top:1px solid var(--border-soft);flex-direction:column;gap:10px;margin-top:16px;padding-top:16px;display:flex}.earnings-pie-row{align-items:center;gap:10px;display:flex}.earnings-pie-row-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.earnings-pie-name{color:var(--text-heading);font-size:.88rem;font-weight:700}.earnings-pie-meta{color:var(--text-muted);font-size:.75rem}.earnings-pie-amounts{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.earnings-pie-earned{color:var(--green);font-size:.95rem;font-weight:800}.earnings-pie-projected{color:var(--primary);font-size:.72rem;font-weight:600}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleSpring{0%{opacity:0;transform:scale(.93)}to{opacity:1;transform:scale(1)}}@keyframes pulse-green{0%,to{box-shadow:0 0 0 3px #05966940}50%{box-shadow:0 0 0 7px #05966914}}@keyframes pulse-live{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}@media (width<=768px){.header-inner{padding:22px 16px 0}.header-greeting{font-size:1.9rem}.header-stats{gap:8px}.hstat-card{padding:8px 12px}.hstat-label{display:none}.header-tabs{gap:2px;padding-bottom:14px;overflow-x:auto}.tab-link{padding:7px 14px;font-size:.82rem}.btn-signout span{display:none}.main-content{padding:16px}.field-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.clock-idle{flex-direction:column;align-items:flex-start}.clock-review-times{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start}.charts-grid{grid-template-columns:1fr}.cal-cell{min-height:72px;padding:5px}.cal-pill{padding:1px 3px;font-size:.6rem}.page-header{flex-direction:column;gap:10px}.emp-month-grid{grid-template-columns:1fr 1fr}.auth-card{padding:32px 24px}}@media (width<=480px){.header-greeting{font-size:1.6rem}.stats-grid{grid-template-columns:1fr 1fr}.shift-row{padding:12px 14px}.shift-row-right{gap:6px}.cal-cell{min-height:56px}.cal-pills{display:none}.cal-cell.has-shifts:after{content:"●";color:var(--primary);font-size:6px;display:block}.emp-month-grid{grid-template-columns:1fr}.emp-month-stats{grid-template-columns:repeat(4,1fr)}}html[data-theme=ocean]{--bg:#eff6ff;--surface:#fff;--border:#bfdbfe;--border-soft:#dbeafe;--text:#1e3a5f;--text-muted:#64748b;--text-heading:#0f2942;--primary:#3b82f6;--primary-dark:#2563eb;--primary-light:#eff6ff;--primary-glow:#3b82f62e;--green:#0ea5e9;--green-dark:#0284c7;--green-light:#e0f2fe;--green-glow:#0ea5e926;--shadow-sm:0 1px 4px #3b82f612, 0 1px 2px #0000000a;--shadow:0 4px 16px #3b82f61f, 0 1px 4px #0000000d;--shadow-md:0 8px 28px #3b82f624, 0 2px 8px #0000000f;--shadow-lg:0 20px 60px #3b82f62e, 0 4px 16px #00000014;--header-gradient:linear-gradient(150deg, #1e3a5f 0%, #1d4ed8 55%, #0ea5e9 100%)}html[data-theme=forest]{--bg:#f0fdf4;--surface:#fff;--border:#bbf7d0;--border-soft:#dcfce7;--text:#14532d;--text-muted:#4b7a5e;--text-heading:#052e16;--primary:#16a34a;--primary-dark:#15803d;--primary-light:#f0fdf4;--primary-glow:#16a34a2e;--green:#16a34a;--green-dark:#15803d;--green-light:#dcfce7;--green-glow:#16a34a26;--shadow-sm:0 1px 4px #16a34a12, 0 1px 2px #0000000a;--shadow:0 4px 16px #16a34a1f, 0 1px 4px #0000000d;--shadow-md:0 8px 28px #16a34a24, 0 2px 8px #0000000f;--shadow-lg:0 20px 60px #16a34a2e, 0 4px 16px #00000014;--header-gradient:linear-gradient(150deg, #052e16 0%, #166534 55%, #15803d 100%)}html[data-theme=sunset]{--bg:#fff7ed;--surface:#fff;--border:#fed7aa;--border-soft:#ffedd5;--text:#431407;--text-muted:#92400e;--text-heading:#431407;--primary:#ea580c;--primary-dark:#c2410c;--primary-light:#fff7ed;--primary-glow:#ea580c2e;--green:#f59e0b;--green-dark:#d97706;--green-light:#fffbeb;--green-glow:#f59e0b26;--shadow-sm:0 1px 4px #ea580c12, 0 1px 2px #0000000a;--shadow:0 4px 16px #ea580c1f, 0 1px 4px #0000000d;--shadow-md:0 8px 28px #ea580c24, 0 2px 8px #0000000f;--shadow-lg:0 20px 60px #ea580c2e, 0 4px 16px #00000014;--header-gradient:linear-gradient(150deg, #431407 0%, #9a3412 55%, #ea580c 100%)}html[data-theme=midnight]{--bg:#0f172a;--surface:#1e293b;--border:#334155;--border-soft:#1e293b;--text:#f1f5f9;--text-muted:#94a3b8;--text-heading:#f8fafc;--primary:#818cf8;--primary-dark:#6366f1;--primary-light:#1e1b4b;--primary-glow:#818cf840;--green:#34d399;--green-dark:#10b981;--green-light:#042a1a;--green-glow:#34d39933;--amber-light:#1c1200;--danger-light:#2d0a0a;--shadow-sm:0 1px 4px #00000080;--shadow:0 4px 16px #0000008c;--shadow-md:0 8px 28px #000000a6;--shadow-lg:0 20px 60px #000000bf;--header-gradient:linear-gradient(150deg, #0f172a 0%, #1e1b4b 55%, #312e81 100%)}html[data-theme=blossom]{--bg:#fceef0;--surface:#fff;--border:#efcdd4;--border-soft:#fceef0;--text:#3d2a2e;--text-muted:#8b5c65;--text-heading:#3d2a2e;--primary:#d4a0aa;--primary-dark:#b8808e;--primary-light:#fceef0;--primary-glow:#d4a0aa2e;--green:#7d8f72;--green-dark:#6a7a60;--green-light:#c2cebc;--green-glow:#7d8f7226;--danger:#e07070;--danger-light:#fce8e8;--shadow-sm:0 1px 4px #d4a0aa12, 0 1px 2px #0000000a;--shadow:0 4px 16px #d4a0aa1f, 0 1px 4px #0000000d;--shadow-md:0 8px 28px #d4a0aa24, 0 2px 8px #0000000f;--shadow-lg:0 20px 60px #d4a0aa2e, 0 4px 16px #00000014;--header-gradient:linear-gradient(135deg, #d4a0aa, #7d8f72)}.theme-panel-backdrop{z-index:200;background:#00000059;position:fixed;inset:0}.theme-panel{z-index:201;background:var(--surface);border-left:1px solid var(--border);width:280px;box-shadow:var(--shadow-lg);flex-direction:column;animation:.22s slideInRight;display:flex;position:fixed;top:0;bottom:0;right:0}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.theme-panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 20px 12px;display:flex}.theme-panel-header h3{color:var(--text-heading);font-size:1rem}.theme-panel-close{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-xs);background:0 0;border:none;padding:4px;font-size:1rem;transition:color .15s}.theme-panel-close:hover{color:var(--text-heading)}.theme-cards{flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;overflow-y:auto}.theme-card{border:2px solid var(--border);border-radius:var(--radius);background:var(--bg);cursor:pointer;text-align:left;padding:0;transition:border-color .15s,box-shadow .15s;overflow:hidden}.theme-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.theme-card-active{border-color:var(--primary)!important;box-shadow:var(--shadow)!important}.theme-card-gradient{width:100%;height:36px}.theme-card-dots{gap:6px;padding:8px 12px 4px;display:flex}.theme-dot{border:1px solid #0000001a;border-radius:50%;width:14px;height:14px}.theme-card-footer{align-items:center;gap:6px;padding:4px 12px 10px;display:flex}.theme-card-label{color:var(--text-heading);flex:1;font-size:.82rem;font-weight:600}.theme-default-badge{letter-spacing:.05em;background:var(--primary-light);color:var(--primary);border-radius:var(--radius-pill);padding:2px 6px;font-size:.65rem;font-weight:700}.theme-check{color:var(--primary);font-weight:700}.btn-theme-icon{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#ffffff1f;border:1px solid #fff3;align-items:center;padding:6px 8px;transition:background .15s;display:flex}.btn-theme-icon:hover{background:#ffffff38}.btn-admin{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#ffffff26;border:1px solid #ffffff40;align-items:center;gap:5px;padding:6px 12px;font-size:.8rem;font-weight:700;transition:background .15s;display:flex}.btn-admin:hover{background:#ffffff40}.admin-tab-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);gap:4px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.admin-tab{cursor:pointer;border-radius:var(--radius-sm);color:var(--text-muted);background:0 0;border:none;padding:8px 20px;font-size:.875rem;font-weight:600;transition:all .15s}.admin-tab:hover{color:var(--text-heading);background:var(--bg)}.admin-tab-active{background:var(--primary)!important;color:#fff!important}.admin-method-bar{gap:8px;margin-bottom:20px;display:flex}.admin-method-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);padding:8px 18px;font-size:.85rem;font-weight:600;transition:all .15s}.admin-method-btn:hover{border-color:var(--primary);color:var(--primary)}.admin-method-active{border-color:var(--primary)!important;color:var(--primary)!important;background:var(--primary-light)!important}.admin-section{flex-direction:column;gap:16px;display:flex}.admin-table-wrap{border-radius:var(--radius);border:1px solid var(--border);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.85rem}.admin-table th{background:var(--bg);text-align:left;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);padding:10px 14px;font-size:.75rem;font-weight:700}.admin-table td{border-bottom:1px solid var(--border-soft);vertical-align:middle;padding:10px 14px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr.row-error{background:var(--danger-light)}.admin-table tr.user-row-revoked{opacity:.6}.admin-cell-input{border-radius:var(--radius-xs);color:var(--text);background:0 0;border:1px solid #0000;width:100%;min-width:80px;padding:3px 6px;font-size:.82rem;transition:border-color .15s}.admin-cell-input:focus{border-color:var(--primary);background:var(--surface);outline:none}.error-cell{max-width:180px}.error-tag{background:var(--danger-light);color:var(--danger);border-radius:var(--radius-pill);margin:2px 2px 0 0;padding:2px 7px;font-size:.7rem;font-weight:600;display:inline-block}.admin-preview-stats{align-items:center;gap:12px;display:flex}.preview-stat{align-items:center;gap:5px;font-size:.85rem;font-weight:600;display:flex}.preview-stat.ok{color:var(--green)}.preview-stat.err{color:var(--danger)}.admin-publish-bar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-result{border-radius:var(--radius-sm);padding:12px 16px;font-size:.875rem;font-weight:600}.admin-result-ok{background:var(--green-light);color:var(--green-dark)}.admin-result-err{background:var(--danger-light);color:var(--danger)}.ai-prompt-card{background:var(--primary-light);border:1.5px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:12px;padding:18px 20px;display:flex}.ai-prompt-header{color:var(--text-heading);align-items:center;gap:8px;font-size:.875rem;font-weight:700;display:flex}.ai-spark-icon{color:var(--primary)}.ai-prompt-textarea{box-sizing:border-box;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text-heading);resize:vertical;min-height:90px;padding:12px 14px;font-family:inherit;font-size:.9rem;line-height:1.5;transition:border-color .2s,box-shadow .2s}.ai-prompt-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);outline:none}.ai-example-row{flex-wrap:wrap;align-items:center;gap:6px;font-size:.78rem;display:flex}.ai-example-label{color:var(--text-muted);flex-shrink:0;font-weight:600}.ai-example-chip{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;text-align:left;border-radius:20px;padding:3px 10px;font-size:.75rem;transition:background .15s,color .15s}.ai-example-chip:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.ai-prompt-footer{justify-content:space-between;align-items:center;gap:10px;display:flex}.ai-model-badge{color:var(--text-muted);background:var(--border);border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:700}.ai-spinner{vertical-align:middle;border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:12px;height:12px;margin-right:6px;animation:.7s linear infinite spin;display:inline-block}.ai-users-hint{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:6px;padding:10px 14px;font-size:.8rem;display:flex}.ai-hint-label{color:var(--text-muted);flex-shrink:0;font-weight:600}.ai-user-chip{background:var(--primary-light);color:var(--primary);border-radius:20px;padding:2px 10px;font-size:.75rem;font-weight:600}.ai-drop-zone{border:1.5px dashed var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:16px;font-size:.85rem;font-weight:600;transition:border-color .2s,background .2s;display:flex}.ai-drop-zone:hover{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.ai-drop-hint{color:var(--text-muted);margin-top:2px;font-size:.72rem;font-weight:400}.ai-image-preview{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:10px;padding:8px 10px;display:flex}.ai-image-thumb{object-fit:cover;border-radius:6px;flex-shrink:0;width:52px;height:52px}.ai-image-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.ai-image-name{color:var(--text-heading);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.ai-image-size{color:var(--text-muted);font-size:.72rem}.admin-upload-top{flex-direction:column;gap:10px;display:flex}.admin-user-controls{flex-wrap:wrap;gap:10px;display:flex}.user-name-cell{align-items:center;gap:8px;display:flex}.user-avatar{background:var(--primary-light);width:28px;height:28px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:800;display:flex}.user-email,.user-date{color:var(--text-muted);font-size:.82rem}.admin-badge{background:var(--primary-light);color:var(--primary);border-radius:var(--radius-pill);letter-spacing:.05em;padding:2px 8px;font-size:.7rem;font-weight:800}.btn-danger-outline{border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius-pill);cursor:pointer;background:0 0;padding:4px 10px;font-size:.75rem;font-weight:700;transition:all .15s}.btn-danger-outline:hover{background:var(--danger-light)}.btn-danger{background:var(--danger);color:#fff;border-radius:var(--radius-pill);cursor:pointer;border:none;padding:4px 10px;font-size:.75rem;font-weight:700}.admin-toast{background:var(--text-heading);color:var(--surface);border-radius:var(--radius-pill);box-shadow:var(--shadow-md);z-index:300;padding:10px 20px;font-size:.875rem;font-weight:600;animation:.2s fadeInUp;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--bg);padding:40px 24px;transition:border-color .15s,background .15s}.upload-zone:hover,.upload-zone-drag{border-color:var(--primary);background:var(--primary-light)}.upload-zone-icon{margin-bottom:8px;font-size:2rem}.upload-zone-text{color:var(--text-heading);font-weight:600}.upload-zone-hint{color:var(--text-muted);margin-top:4px;font-size:.8rem}.roster-cal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.roster-cal-grid-header{background:var(--bg);border-bottom:1px solid var(--border);grid-template-columns:repeat(7,1fr);display:grid}.roster-cal-dayname{text-align:center;color:var(--text-muted);text-transform:uppercase;padding:8px 4px;font-size:.72rem;font-weight:700}.roster-cal-grid{grid-template-columns:repeat(7,1fr);display:grid}.roster-cal-cell{border-right:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);cursor:pointer;min-height:72px;padding:4px;transition:background .15s}.roster-cal-cell:hover{background:var(--primary-light)}.roster-cal-empty{cursor:default}.roster-cal-empty:hover{background:0 0}.roster-cal-today{background:var(--primary-light)}.roster-cal-date{color:var(--text-muted);margin-bottom:2px;font-size:.78rem;font-weight:700;display:block}.roster-cal-chips{flex-direction:column;gap:2px;display:flex}.roster-cal-chip{color:#fff;white-space:nowrap;text-overflow:ellipsis;border-radius:3px;padding:1px 4px;font-size:.65rem;font-weight:700;overflow:hidden}.roster-cal-more{background:var(--text-muted)!important}.admin-builder-controls{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.admin-shift-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.admin-shift-row{border-bottom:1px solid var(--border-soft);align-items:center;gap:12px;padding:8px 0;font-size:.85rem;display:flex}.admin-shift-row:last-child{border-bottom:none}.upcoming-shifts-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:4px;padding:18px 20px}.upcoming-shifts-title{color:var(--text-heading);margin-bottom:12px;font-size:1rem;font-weight:700}.upcoming-shifts-list{flex-direction:column;gap:10px;display:flex}.upcoming-shift-row{background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border-soft);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.upcoming-shift-left{flex-direction:column;gap:2px;display:flex}.upcoming-shift-date{color:var(--text-heading);font-size:.82rem;font-weight:700}.upcoming-shift-employer{color:var(--primary);font-size:.79rem;font-weight:600}.upcoming-shift-right{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.upcoming-shift-time{color:var(--text-muted);font-size:.82rem}.upcoming-shift-hours{color:var(--text-heading);font-size:.79rem;font-weight:700}.field-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:8px 12px;font-family:inherit;font-size:.875rem;transition:border-color .15s}.field-input:focus{border-color:var(--primary);outline:none}.user-employers-panel{border-top:1px solid var(--border-soft);padding:14px 20px 14px 48px}.user-employers-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.user-employers-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;font-weight:700}.employer-mgmt-list{flex-direction:column;gap:4px;margin-bottom:8px;display:flex}.employer-mgmt-row{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border-soft);align-items:center;gap:10px;padding:6px 10px;font-size:.85rem;display:flex}.employer-mgmt-editing{flex-wrap:wrap;gap:6px}.employer-mgmt-name{color:var(--text-heading);flex:1;font-weight:600}.employer-mgmt-role{color:var(--text-muted);font-size:.8rem}.employer-mgmt-rate{color:var(--primary);margin-left:auto;font-size:.82rem;font-weight:700}.emp-color-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px;display:inline-block}.employer-inline-form{background:var(--primary-light);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:8px;margin-top:8px;padding:12px 14px;display:flex}.employer-inline-title{color:var(--primary);font-size:.82rem;font-weight:700}.emp-select-row{align-items:center;gap:8px;display:flex}.emp-empty-state{align-items:center;gap:10px;display:flex}.color-swatch-row{flex-wrap:nowrap;gap:4px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:16px;height:16px;transition:transform .15s,border-color .15s}.color-swatch:hover{transform:scale(1.2)}.site-footer{text-align:center;border-top:1px solid var(--border);padding:20px 24px 24px}.site-footer-desc{color:var(--text-muted);max-width:480px;margin:0 auto 6px;font-size:.78rem;line-height:1.6}.site-footer-meta{color:var(--text-muted);font-size:.74rem}.site-footer-link{color:var(--primary);text-decoration:none}.site-footer-link:hover{text-decoration:underline}.auth-center-col{z-index:1;flex-direction:column;align-items:center;width:100%;display:flex}.site-footer--dark{border-top:1px solid #ffffff14;margin-top:16px}.site-footer--dark .site-footer-desc{color:#fff6}.site-footer--dark .site-footer-meta{color:#ffffff4d}.site-footer--dark .site-footer-link{color:#fff9}.color-swatch-active{transform:scale(1.2);border-color:var(--text-heading)!important}
