:root{--bg: #ffffff;--surface: #ffffff;--surface-2: #f5f7fa;--surface-3: #edf1f7;--text-primary: #0d1b2a;--text-secondary:#4e6070;--text-muted: #93aabb;--primary: #3563e9;--primary-hover: #2449c8;--primary-light: rgba(53,99,233,.1);--primary-grad: linear-gradient(135deg,#3563e9 0%,#5b8af5 100%);--accent-grad: linear-gradient(180deg, #0d1b2a 30%, #3563e9 100%);--success: #0ea56e;--success-light: rgba(14,165,110,.1);--success-grad: linear-gradient(135deg,#0ea56e 0%,#34d399 100%);--danger: #e53535;--danger-light: rgba(229,53,53,.09);--danger-grad: linear-gradient(135deg,#e53535 0%,#f87171 100%);--warning: #f0900d;--warning-light: rgba(240,144,13,.1);--warning-grad: linear-gradient(135deg,#f0900d 0%,#fbbf24 100%);--border: #dde4ee;--border-focus: #3563e9;--shadow-sm: 0 2px 10px rgba(13,27,42,.08);--shadow-md: 0 8px 24px rgba(13,27,42,.11);--shadow-lg: 0 20px 48px rgba(13,27,42,.15);--r: 16px;--r-sm: 10px;--r-lg: 22px}[data-theme=light]{--bg: #ffffff;--surface: #ffffff;--surface-2: #f5f7fa;--surface-3: #edf1f7;--text-primary: #0d1b2a;--text-secondary:#4e6070;--text-muted: #93aabb;--border: #dde4ee;--shadow-md: 0 8px 24px rgba(13,27,42,.11);--shadow-lg: 0 20px 48px rgba(13,27,42,.15)}[data-theme=dark]{--bg: #080e1a;--surface: rgba(16, 24, 39, .95);--surface-2: #162032;--surface-3: #1c2a40;--text-primary: #e2ecfa;--text-secondary:#7a96b5;--text-muted: #3d5570;--accent-grad: linear-gradient(180deg, #f8fafc 30%, #3563e9 100%);--primary-light: rgba(91,138,245,.13);--border: #1e2f47;--shadow-md: 0 8px 24px rgba(0,0,0,.5);--shadow-lg: 0 20px 48px rgba(0,0,0,.6)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,sans-serif;background:var(--bg);color:var(--text-primary);line-height:1.55;-webkit-font-smoothing:antialiased;min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(53,99,233,.05) 0%,transparent 70%);pointer-events:none;z-index:-1}#app{width:100%;max-width:800px;margin:0 auto;padding:20px;transition:max-width .3s ease}body.admin-mode #app{max-width:1100px}.card{background:var(--surface);border-radius:var(--r);padding:20px;border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dash-card{background:var(--surface);border-radius:var(--r-sm);padding:16px;border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;transition:transform .2s,box-shadow .2s;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.dash-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.badge{font-size:.65rem;font-weight:800;padding:2px 8px;border-radius:20px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;text-transform:uppercase;border:1px solid transparent}.badge-dot{width:5px;height:5px;border-radius:50%}.badge-admin{background:#eef2ff;color:#4338ca;border-color:#c7d2fe}.badge-admin .badge-dot{background:#4338ca}.badge-foreman{background:#fdf2f8;color:#be185d;border-color:#fbcfe8}.badge-foreman .badge-dot{background:#be185d}.badge-worker{background:#f0fdf4;color:#15803d;border-color:#bbf7d0}.badge-worker .badge-dot{background:#15803d}.badge-storekeeper{background:#fff7ed;color:#c2410c;border-color:#ffedd5}.badge-storekeeper .badge-dot{background:#c2410c}[data-theme=dark] .badge-admin{background:#4338ca33;color:#818cf8;border-color:#4338ca66}[data-theme=dark] .badge-foreman{background:#be185d33;color:#f472b6;border-color:#be185d66}[data-theme=dark] .badge-worker{background:#15803d33;color:#4ade80;border-color:#15803d66}[data-theme=dark] .badge-storekeeper{background:#c2410c33;color:#fb923c;border-color:#c2410c66}.tabs{display:flex;gap:8px;background:var(--surface-2);padding:6px;border-radius:14px;border:1px solid var(--border);margin-bottom:24px}.tab-btn{flex:1;padding:10px;border:none;background:none;border-radius:10px;font-size:.85rem;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:all .2s}.tab-btn.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.filter-chip{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--surface);font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:var(--r-sm);border:none;font-weight:800;font-family:inherit;cursor:pointer;transition:all .2s;color:#fff;background:var(--primary-grad);font-size:.9rem}.btn-sm{padding:8px 14px;font-size:.8rem}.btn-ghost{background:var(--surface-2);color:var(--text-secondary)}.btn-danger{background:var(--danger-grad)}.btn-success{background:var(--success-grad)}.btn:disabled{opacity:.6;cursor:not-allowed}.input-control{width:100%;padding:12px 14px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.input-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.action-icon-btn{border:none;padding:7px 10px;border-radius:8px;font-size:.75rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .2s ease;font-family:inherit}.action-icon-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.btn-action-primary{background:var(--primary-light);color:var(--primary)}.btn-action-primary:hover{background:#3563e926}.btn-action-purple{background:#7c3aed1a;color:#7c3aed}.btn-action-purple:hover{background:#7c3aed26}[data-theme=dark] .btn-action-primary{background:#5b8af526;color:#7ba7ff}[data-theme=dark] .btn-action-primary:hover{background:#5b8af540}[data-theme=dark] .btn-action-purple{background:#a78bfa26;color:#a78bfa}[data-theme=dark] .btn-action-purple:hover{background:#a78bfa40}.btn-action-danger{background:transparent;color:var(--danger);font-size:1.2rem;padding:4px 8px;opacity:.6}.btn-action-danger:hover{opacity:1;background:var(--danger-light);color:var(--danger)}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:10px;z-index:9999;pointer-events:none}.toast{background:var(--surface);padding:14px 20px;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);display:flex;align-items:center;gap:10px;font-size:.9rem;font-weight:700;color:var(--text-primary);animation:slideUpToast .3s cubic-bezier(.34,1.56,.64,1);pointer-events:auto;white-space:nowrap}.toast.toast-out{animation:fadeOutToast .3s ease forwards}.toast-success{border-bottom:3px solid var(--success)}.toast-error{border-bottom:3px solid var(--danger)}.toast-warning{border-bottom:3px solid var(--warning)}@keyframes slideUpToast{0%{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeOutToast{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}.skeleton{background:var(--surface-2);border-radius:8px;animation:pulse 1.5s infinite}@keyframes pulse{50%{opacity:.5}}.login-wrap{min-height:80vh;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative}.login-wrap:before{content:"";position:absolute;width:300px;height:300px;background:var(--primary);filter:blur(120px);opacity:.15;z-index:-1}.login-card{width:100%;max-width:400px;margin:0 auto}.login-logo{text-align:center;margin-bottom:32px}.login-logo-icon{width:80px;height:80px;background:var(--surface);border-radius:24px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:var(--shadow-md);border:1px solid var(--border);margin-left:auto;margin-right:auto}.login-logo-icon svg{width:60%;height:60%}.login-logo-icon svg #logo-grad stop:first-child{stop-color:var(--primary)}.login-logo-icon svg #logo-grad stop:last-child{stop-color:var(--primary-hover)}.company-name{font-size:.65rem;font-weight:400;color:var(--text-secondary);letter-spacing:.45em;text-transform:uppercase;margin-top:12px;opacity:.6;position:relative;display:inline-block;padding-top:10px}.company-name:before{content:"";position:absolute;top:0;left:25%;right:25%;height:1px;background:var(--primary);opacity:.3}.input-wrapper{position:relative;margin-bottom:16px;margin-top:6px}.input-wrapper svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:18px;height:18px;fill:var(--text-muted);transition:all .2s}.input-control:focus+svg{fill:var(--primary);transform:scale(1.1) translateY(-45%)}.input-wrapper input{padding-left:44px}.alert{padding:16px;border-radius:16px;margin-bottom:20px;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:12px;border:1px solid transparent;animation:slideDown .3s ease}.alert-success{background:var(--success-light);color:var(--success);border-color:#22c55e33}.alert-error{background:var(--danger-light);color:var(--danger);border-color:#ef444433}.alert-warning{background:#f59e0b1a;color:#f59e0b;border-color:#f59e0b33}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.modal-content{background:var(--surface);width:100%;max-width:500px;max-height:80dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-lg);border:1px solid var(--border);position:relative;animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
