:root{--color-primary:#00897b;--color-primary-light:#4db6ac;--color-primary-dark:#00695c;--color-primary-50:#00897b0f;--color-primary-100:#00897b1f;--color-primary-200:#00897b33;--color-primary-500:#00897b;--color-primary-600:#00796b;--color-primary-700:#00695c;--color-teal:var(--color-primary);--color-teal-light:var(--color-primary-light);--color-teal-lighter:#80cbc4;--color-teal-dark:var(--color-primary-dark);--color-teal-50:var(--color-primary-50);--color-teal-100:var(--color-primary-100);--color-secondary:#475569;--color-secondary-light:#64748b;--color-secondary-dark:#334155;--color-secondary-50:#4755690f;--color-secondary-100:#4755691f;--color-accent:#4f46e5;--color-accent-light:#818cf8;--color-accent-dark:#3730a3;--color-accent-50:#4f46e50f;--color-accent-100:#4f46e51f;--color-info:#2563eb;--color-info-light:#60a5fa;--color-info-dark:#1d4ed8;--color-info-50:#2563eb0f;--color-info-100:#2563eb1f;--color-blue:#2563eb;--color-blue-light:#60a5fa;--color-blue-dark:#1d4ed8;--color-blue-50:#eff6ff;--color-blue-200:#bfdbfe;--color-purple:#7c3aed;--color-purple-50:#7c3aed0f;--color-indigo:var(--color-accent);--color-indigo-light:var(--color-accent-light);--color-indigo-50:var(--color-accent-50);--color-indigo-100:var(--color-accent-100);--color-sky:var(--color-info);--color-sky-50:var(--color-info-50);--color-warning:#d97706;--color-warning-light:#fbbf24;--color-warning-dark:#b45309;--color-warning-50:#d977060f;--color-warning-100:#d977061f;--color-orange:var(--color-warning);--color-orange-50:#fffbeb;--color-gold:#d97706;--color-gold-50:#d9770614;--color-danger:#dc2626;--color-danger-light:#f87171;--color-danger-dark:#b91c1c;--color-danger-50:#dc26260f;--color-danger-100:#dc26261f;--color-red:var(--color-danger);--color-red-light:var(--color-danger-light);--color-red-dark:var(--color-danger-dark);--color-red-50:#fef2f2;--color-pink:var(--color-danger);--color-pink-50:var(--color-red-50);--color-pink-100:#dc26261a;--color-success:#059669;--color-success-light:#34d399;--color-success-dark:#047857;--color-success-50:#0596690f;--color-success-100:#0596691f;--color-success-bg:#f0fdf4;--color-success-border:#bbf7d0;--color-green:var(--color-success);--color-green-50:#ecfdf5;--color-green-100:#d1fae5;--color-green-600:#059669;--color-green-700:#047857;--color-gray-25:#fcfcfd;--color-gray-50:#f8fafc;--color-gray-100:#f1f5f9;--color-gray-200:#e2e8f0;--color-gray-300:#cbd5e1;--color-gray-400:#94a3b8;--color-gray-500:#64748b;--color-gray-600:#475569;--color-gray-700:#334155;--color-gray-800:#1e293b;--color-gray-900:#0f172a;--color-gray-950:#020617;--surface-primary:#fff;--surface-secondary:#f8fafc;--surface-tertiary:#f1f5f9;--surface-elevated:#fff;--surface-sunken:#f1f5f9;--surface-overlay:#0f172a99;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#64748b;--text-disabled:#94a3b8;--text-inverse:#fff;--text-link:var(--color-primary);--text-link-hover:var(--color-primary-dark);--text-on-primary:#fff;--text-on-danger:#fff;--border-light:#f1f5f9;--border-default:#e2e8f0;--border-strong:#cbd5e1;--border-color:#e2e8f0;--border-focus:var(--color-primary);--input-bg:#fff;--focus-ring-color:var(--color-primary);--focus-ring-offset:2px;--focus-ring-width:2px;--focus-ring:var(--focus-ring-width) solid var(--focus-ring-color);--focus-ring-shadow:0 0 0 var(--focus-ring-offset) var(--surface-primary),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color);--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #00000014,0 1px 2px -1px #0000000f;--shadow-md:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000f;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014,0 8px 10px -6px #0000000a;--shadow-2xl:0 25px 50px -12px #0003;--shadow-inner:inset 0 2px 4px 0 #0000000a;--shadow-primary:0 4px 14px 0 #00897b40;--shadow-card-hover:0 8px 25px -5px #00000014,0 4px 10px -6px #0000000a;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--radius-2xl:16px;--radius-3xl:20px;--radius-full:9999px;--space-0:0px;--space-px:1px;--space-0-5:2px;--space-1:4px;--space-1-5:6px;--space-2:8px;--space-2-5:10px;--space-3:12px;--space-3-5:14px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:28px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--space-24:96px;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","SF Mono","Fira Code","Cascadia Code",monospace;--text-2xs:0.625rem;--text-xs:0.75rem;--text-sm:0.8125rem;--text-base:0.875rem;--text-md:0.9375rem;--text-lg:1rem;--text-xl:1.125rem;--text-2xl:1.25rem;--text-3xl:1.5rem;--text-4xl:1.875rem;--text-5xl:2.25rem;--text-6xl:3rem;--leading-none:1;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;--tracking-tighter:-0.05em;--tracking-tight:-0.025em;--tracking-normal:0em;--tracking-wide:0.025em;--tracking-wider:0.05em;--tracking-widest:0.1em;--weight-light:300;--weight-normal:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--weight-extrabold:800;--transition-fast:120ms ease;--transition-base:200ms ease;--transition-slow:300ms ease;--transition-spring:350ms cubic-bezier(0.34,1.56,0.64,1);--ease-in-out:cubic-bezier(0.4,0,0.2,1);--ease-out:cubic-bezier(0,0,0.2,1);--ease-in:cubic-bezier(0.4,0,1,1);--sidebar-width-collapsed:60px;--sidebar-width-expanded:228px;--sidebar-w:var(--sidebar-width-expanded);--topbar-height:64px;--content-max-width:1280px;--z-base:0;--z-dropdown:100;--z-sticky:200;--z-overlay:500;--z-modal:1000;--z-toast:1100;--z-tooltip:1200;--z-skip-link:9999}[data-theme=dark]{--surface-primary:#1e293b;--surface-secondary:#0f172a;--surface-tertiary:#334155;--surface-elevated:#1e293b;--surface-sunken:#0f172a;--surface-overlay:#000000b3;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-tertiary:#64748b;--text-disabled:#475569;--text-inverse:#0f172a;--border-light:#1e293b;--border-default:#334155;--border-strong:#475569;--border-color:#334155;--input-bg:#1e293b;--focus-ring-shadow:0 0 0 var(--focus-ring-offset) var(--surface-primary),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color);--shadow-xs:0 1px 2px 0 #0000004d;--shadow-sm:0 1px 3px 0 #0006,0 1px 2px -1px #0000004d;--shadow-md:0 4px 6px -1px #0006,0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #0006,0 4px 6px -4px #0000004d;--shadow-xl:0 20px 25px -5px #00000080,0 8px 10px -6px #0006;--shadow-card-hover:0 8px 25px -5px #0006,0 4px 10px -6px #0000004d;--color-green-50:#0596691f;--color-red-50:#dc26261f;--color-blue-50:#2563eb1f;--color-purple-50:#7c3aed1f;--color-orange-50:#d977061f;--color-primary-50:#00897b1f;--color-primary-100:#00897b2e;--color-accent-50:#4f46e51f;--color-green-100:#0596692e;--color-blue-200:#2563eb38;--color-teal-50:#00897b1a;--color-teal-100:#00897b2e;--color-pink-50:#dc26261f;--color-pink-100:#dc26262e;--color-success-50:#0596691a;--color-success-100:#0596692e;--color-success-bg:#05966914;--color-success-border:#05966938;--color-sky-50:#2563eb1f;--color-gold-50:#d977061f;--color-indigo-50:#4f46e51a;--color-indigo-100:#4f46e52e;--color-info-50:#2563eb1f;--color-info-100:#2563eb2e;--color-secondary-50:#4755691f;--color-secondary-100:#4755692e;--color-warning-50:#d977061a;--color-warning-100:#d977062e;--color-danger-50:#dc26261a;--color-danger-100:#dc26262e}[data-theme=light]{--surface-primary:#fff;--surface-secondary:#f8fafc;--surface-tertiary:#f1f5f9;--surface-elevated:#fff;--surface-sunken:#f1f5f9;--surface-overlay:#0f172a99;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#64748b;--text-disabled:#94a3b8;--text-inverse:#fff;--text-link:var(--color-primary);--text-link-hover:var(--color-primary-dark);--border-light:#f1f5f9;--border-default:#e2e8f0;--border-strong:#cbd5e1;--border-color:#e2e8f0;--input-bg:#fff;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #00000014,0 1px 2px -1px #0000000f;--shadow-md:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000f;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014,0 8px 10px -6px #0000000a;--shadow-card-hover:0 8px 25px -5px #00000014,0 4px 10px -6px #0000000a}[data-theme=blue]{--color-primary:#2563eb;--color-primary-light:#60a5fa;--color-primary-dark:#1d4ed8;--color-primary-50:#2563eb0f;--color-primary-100:#2563eb1f;--color-primary-200:#2563eb33;--color-primary-500:#2563eb;--color-primary-600:#1d4ed8;--color-primary-700:#1e40af;--color-teal:var(--color-primary);--color-teal-light:var(--color-primary-light);--color-teal-dark:var(--color-primary-dark);--color-teal-50:var(--color-primary-50);--color-teal-100:var(--color-primary-100);--focus-ring-color:#2563eb;--color-accent:#7c3aed;--color-accent-light:#a78bfa;--color-accent-dark:#5b21b6;--color-accent-50:#7c3aed0f;--color-accent-100:#7c3aed1f;--surface-primary:#fff;--surface-secondary:#f0f4ff;--surface-tertiary:#e8effe;--surface-elevated:#fff;--surface-sunken:#eef2ff;--surface-overlay:#0f172a99;--text-primary:#0f172a;--text-secondary:#374151;--text-tertiary:#6b7280;--text-disabled:#9ca3af;--text-inverse:#fff;--text-link:#2563eb;--text-link-hover:#1d4ed8;--text-on-primary:#fff;--border-light:#eef2ff;--border-default:#dbeafe;--border-strong:#bfdbfe;--border-color:#dbeafe;--input-bg:#fff;--shadow-xs:0 1px 2px 0 #2563eb0f;--shadow-sm:0 1px 3px 0 #2563eb1a,0 1px 2px -1px #0000000f;--shadow-md:0 4px 6px -1px #2563eb1a,0 2px 4px -2px #0000000f;--shadow-lg:0 10px 15px -3px #2563eb1a,0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #2563eb1a,0 8px 10px -6px #0000000a;--shadow-primary:0 4px 14px 0 #2563eb4d;--shadow-card-hover:0 8px 25px -5px #2563eb1f,0 4px 10px -6px #0000000a}[data-theme=corporate]{--color-primary:#1e3a5f;--color-primary-light:#2e5f99;--color-primary-dark:#122540;--color-primary-50:#1e3a5f0f;--color-primary-100:#1e3a5f1f;--color-primary-200:#1e3a5f33;--color-primary-500:#1e3a5f;--color-primary-600:#183250;--color-primary-700:#122540;--color-teal:var(--color-primary);--color-teal-light:var(--color-primary-light);--color-teal-dark:var(--color-primary-dark);--color-teal-50:var(--color-primary-50);--color-teal-100:var(--color-primary-100);--focus-ring-color:#1e3a5f;--color-accent:#2e5f99;--color-accent-light:#5b8ec4;--color-accent-dark:#1e3a5f;--color-accent-50:#2e5f990f;--color-accent-100:#2e5f991f;--surface-primary:#f9fafb;--surface-secondary:#f4f6f8;--surface-tertiary:#eaedf0;--surface-elevated:#fff;--surface-sunken:#eaedf0;--surface-overlay:#122540a6;--text-primary:#1a2535;--text-secondary:#3d4f64;--text-tertiary:#6b7a8d;--text-disabled:#9baab8;--text-inverse:#fff;--text-link:#1e3a5f;--text-link-hover:#122540;--text-on-primary:#fff;--border-light:#eaedf0;--border-default:#d6dbe2;--border-strong:#b8c0cc;--border-color:#d6dbe2;--input-bg:#fff;--shadow-xs:0 1px 2px 0 #1e3a5f0f;--shadow-sm:0 1px 3px 0 #1e3a5f1a,0 1px 2px -1px #0000000d;--shadow-md:0 4px 6px -1px #1e3a5f1a,0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #1e3a5f1a,0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #1e3a5f1a,0 8px 10px -6px #0000000a;--shadow-primary:0 4px 14px 0 #1e3a5f40;--shadow-card-hover:0 8px 25px -5px #1e3a5f1f,0 4px 10px -6px #0000000a}[data-theme=ocean]{--color-primary:#0ea5e9;--color-primary-light:#38bdf8;--color-primary-dark:#0284c7;--color-primary-100:#0ea5e92e;--color-primary-200:#0ea5e940;--color-primary-500:#0ea5e9;--color-primary-600:#0284c7;--color-primary-700:#0369a1;--color-teal:var(--color-primary);--color-teal-light:var(--color-primary-light);--color-teal-dark:var(--color-primary-dark);--color-teal-50:var(--color-primary-50);--color-teal-100:var(--color-primary-100);--focus-ring-color:#0ea5e9;--color-accent:#22d3ee;--color-accent-light:#67e8f9;--color-accent-dark:#0891b2;--color-accent-50:#22d3ee1f;--color-accent-100:#22d3ee2e;--surface-primary:#0f2744;--surface-secondary:#0b1e36;--surface-tertiary:#163354;--surface-elevated:#163354;--surface-sunken:#071629;--surface-overlay:#071629cc;--text-primary:#e0f2fe;--text-secondary:#93c5fd;--text-tertiary:#60a5fa;--text-disabled:#3b5b8a;--text-inverse:#0f2744;--text-link:#38bdf8;--text-link-hover:#0ea5e9;--text-on-primary:#fff;--border-light:#163354;--border-default:#1e4070;--border-strong:#2e5f99;--border-color:#1e4070;--input-bg:#0f2744;--color-green-50:#05966924;--color-red-50:#dc262624;--color-blue-50:#0ea5e924;--color-orange-50:#d9770624;--color-primary-50:#0ea5e91f;--color-success-bg:#0596691a;--color-success-border:#05966940;--shadow-xs:0 1px 2px 0 #0006;--shadow-sm:0 1px 3px 0 #00000080,0 1px 2px -1px #0006;--shadow-md:0 4px 6px -1px #00000080,0 2px 4px -2px #0006;--shadow-lg:0 10px 15px -3px #00000080,0 4px 6px -4px #0006;--shadow-xl:0 20px 25px -5px #0009,0 8px 10px -6px #00000080;--shadow-primary:0 4px 14px 0 #0ea5e959;--shadow-card-hover:0 8px 25px -5px #00000080,0 4px 10px -6px #0006;--focus-ring-shadow:0 0 0 var(--focus-ring-offset) var(--surface-primary),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}[data-theme=high-contrast]{--color-primary:#ff0;--color-primary-light:#ff6;--color-primary-dark:#cc0;--color-primary-50:#ffff001f;--color-primary-100:#ff03;--color-primary-200:#ffff004d;--color-primary-500:#ff0;--color-primary-600:#e6e600;--color-primary-700:#cc0;--color-teal:var(--color-primary);--color-teal-light:var(--color-primary-light);--color-teal-dark:var(--color-primary-dark);--color-teal-50:var(--color-primary-50);--color-teal-100:var(--color-primary-100);--focus-ring-color:#ff0;--focus-ring-width:3px;--focus-ring-offset:3px;--color-accent:#0ff;--color-accent-light:#6ff;--color-accent-dark:#0cc;--color-accent-50:#00ffff1f;--color-accent-100:#0ff3;--surface-primary:#000;--surface-secondary:#0a0a0a;--surface-tertiary:#141414;--surface-elevated:#1a1a1a;--surface-sunken:#000;--surface-overlay:#000000e6;--text-primary:#fff;--text-secondary:#e5e5e5;--text-tertiary:#ccc;--text-disabled:#666;--text-inverse:#000;--text-link:#ff0;--text-link-hover:#ff6;--text-on-primary:#000;--border-light:#333;--border-default:#fff;--border-strong:#fff;--border-color:#fff;--input-bg:#000;--color-green-50:#00ff0024;--color-red-50:#ff505024;--color-blue-50:#00c8ff24;--color-orange-50:#ffc80024;--color-success:#0f0;--color-success-light:#6f6;--color-success-dark:#0c0;--color-success-bg:#00ff001a;--color-success-border:#00ff004d;--color-danger:#f55;--color-danger-light:#f88;--color-danger-dark:#c00;--color-warning:#fa0;--color-warning-light:#fc4;--color-warning-dark:#c80;--shadow-xs:none;--shadow-sm:none;--shadow-md:0 0 0 1px #fff;--shadow-lg:0 0 0 2px #fff;--shadow-xl:0 0 0 2px #fff;--shadow-primary:0 0 0 2px #ff0;--shadow-card-hover:0 0 0 2px #ff0;--focus-ring-shadow:0 0 0 var(--focus-ring-offset) var(--surface-primary),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}:root{font-size:14px;font-size:var(--ui-font-size,14px);font-weight:400;font-weight:var(--ui-font-weight,400)}:root,[data-theme=dark],[data-theme=light]{--color-primary:var(--ui-primary,#00897b);--color-primary-light:var(--ui-primary,#4db6ac);--color-primary-dark:var(--ui-primary,#00695c);--color-primary-600:var(--ui-primary,#00796b)}[data-theme=blue]{--color-primary:var(--ui-primary,#2563eb);--color-primary-light:var(--ui-primary,#60a5fa);--color-primary-dark:var(--ui-primary,#1d4ed8);--color-primary-600:var(--ui-primary,#1d4ed8)}[data-theme=corporate]{--color-primary:var(--ui-primary,#1e3a5f);--color-primary-light:var(--ui-primary,#2e5f99);--color-primary-dark:var(--ui-primary,#122540);--color-primary-600:var(--ui-primary,#183250)}[data-theme=ocean]{--color-primary:var(--ui-primary,#0ea5e9);--color-primary-light:var(--ui-primary,#38bdf8);--color-primary-dark:var(--ui-primary,#0284c7);--color-primary-600:var(--ui-primary,#0284c7)}[data-theme=high-contrast]{--color-primary:var(--ui-primary,#ff0);--color-primary-light:var(--ui-primary,#ff6);--color-primary-dark:var(--ui-primary,#cc0);--color-primary-600:var(--ui-primary,#e6e600)}:root,[data-theme=blue],[data-theme=corporate],[data-theme=dark],[data-theme=high-contrast],[data-theme=light],[data-theme=ocean]{--color-orange:var(--ui-warning,#d97706);--color-warning:var(--ui-warning,#d97706);--color-red:var(--ui-error,#dc2626);--color-danger:var(--ui-error,#dc2626);--color-red-light:var(--ui-error,#f87171);--color-red-dark:var(--ui-error,#b91c1c)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"tnum";font-size:16px;font-variant-numeric:tabular-nums;text-rendering:optimizeLegibility}body{font-feature-settings:"cv02","cv03","cv04","cv11";background:linear-gradient(160deg,#eff9f8,#f8fafc 55%,#f0f4fd) fixed;color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);overflow-x:hidden}[data-theme=dark] body{background:var(--surface-secondary)}[data-theme=blue] body{background:linear-gradient(160deg,#eff4ff,#f5f8ff 55%,#eef2ff) fixed}[data-theme=corporate] body{background:linear-gradient(160deg,#f0f3f7,#f4f6f8 55%,#eef1f5) fixed}[data-theme=ocean] body{background:var(--surface-secondary)}[data-theme=high-contrast] body{background:#000}::selection{background:var(--color-primary-200);color:var(--color-primary-700)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-family:var(--font-sans);font-weight:var(--weight-semibold);line-height:var(--leading-tight);margin:0}h1{font-size:var(--text-4xl);letter-spacing:var(--tracking-tight)}h2{font-size:var(--text-2xl);letter-spacing:-.02em}h3{font-size:var(--text-xl);letter-spacing:-.015em}h4{font-size:var(--text-lg)}h5{font-size:var(--text-md)}h5,h6{font-weight:var(--weight-medium)}h6{font-size:var(--text-base)}p{line-height:var(--leading-normal);margin:0}small{color:var(--text-secondary);font-size:var(--text-xs)}.text-display{font-size:var(--text-5xl);font-weight:var(--weight-extrabold);letter-spacing:var(--tracking-tighter);line-height:var(--leading-tight)}.text-h1{font-size:var(--text-4xl);letter-spacing:var(--tracking-tight)}.text-h1,.text-h2{font-weight:var(--weight-semibold);line-height:var(--leading-tight)}.text-h2{font-size:var(--text-2xl)}.text-h3{font-size:var(--text-xl)}.text-h3,.text-h4{font-weight:var(--weight-semibold);line-height:var(--leading-snug)}.text-h4{font-size:var(--text-lg)}.text-body{font-size:var(--text-base)}.text-body,.text-body-sm{font-weight:var(--weight-normal);line-height:var(--leading-normal)}.text-body-sm{font-size:var(--text-sm)}.text-label{font-weight:var(--weight-semibold);letter-spacing:var(--tracking-wide);line-height:var(--leading-snug);text-transform:uppercase}.text-caption,.text-label{color:var(--text-tertiary);font-size:var(--text-xs)}.text-caption{font-weight:var(--weight-normal);line-height:var(--leading-normal)}.text-overline{color:var(--text-tertiary);font-size:var(--text-2xs);font-weight:var(--weight-bold);letter-spacing:var(--tracking-widest);text-transform:uppercase}.text-mono{font-family:var(--font-mono)}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-wrap{overflow-wrap:break-word;word-break:break-word}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-tertiary)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:var(--color-gray-200);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-300)}@keyframes scaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.97)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}@keyframes pulse-ring{0%,to{opacity:.6}50%{opacity:1}}.modal-overlay{align-items:center;animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--surface-overlay);display:flex;inset:0;justify-content:center;padding:var(--space-6);position:fixed;z-index:var(--z-modal)}.modal-content{animation:scaleIn .2s ease;background:var(--surface-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);display:flex;flex-direction:column;max-height:90vh;max-width:640px;overflow:hidden;width:100%}.modal-content.closing{animation:scaleOut .15s ease}.modal-content.modal-sm{max-width:480px}.modal-content.modal-md{max-width:720px}.modal-content.modal-lg{max-width:960px}.modal-content.modal-xl{max-width:1200px}.modal-header{align-items:center;border-bottom:1px solid var(--border-default);display:flex;flex-shrink:0;justify-content:space-between;padding:var(--space-5) var(--space-6)}.modal-header h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:600;margin:0}.close-btn,.modal-close{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;display:flex;font-size:1.1rem;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.close-btn:hover,.modal-close:hover{background:var(--color-gray-100);color:var(--text-primary)}.modal-body{flex:1 1;overflow-y:auto;padding:var(--space-6)}.modal-footer{background:var(--surface-secondary);border-top:1px solid var(--border-default);display:flex;flex-shrink:0;gap:var(--space-3);padding:var(--space-4) var(--space-6)}.modal-footer .btn{flex:1 1}.company-container,.component-container,.department-container,.employee-container,.page-container,.user-container{animation:fadeInUp .35s ease-out;max-width:100%;padding:var(--space-6)}.company-header,.component-header,.department-header,.designation-header,.employee-header,.page-header,.salary-type-header,.shift-header,.user-header{align-items:center;border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;margin-bottom:var(--space-6);padding-bottom:var(--space-4)}.company-header h2,.component-header h2,.department-header h2,.designation-header h2,.employee-header h2,.header-left h2,.salary-type-header h2,.shift-header h2,.user-header h2{color:var(--text-primary);font-size:var(--text-xl);font-weight:600;letter-spacing:-.01em;margin:0 0 var(--space-1) 0}.employee-id,.header-subtitle,.total-count{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.btn{background:var(--color-primary);border-radius:var(--radius-lg);color:var(--text-on-primary);font-family:var(--font-sans);font-weight:var(--weight-semibold);gap:var(--space-2);height:36px;justify-content:center;line-height:1;position:relative;transition:background var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast),opacity var(--transition-fast);-webkit-user-select:none;user-select:none}.btn:hover:not(:disabled){box-shadow:var(--shadow-sm);filter:brightness(1.05);transform:translateY(-1px)}.btn:active:not(:disabled){box-shadow:none;filter:brightness(.95);transform:translateY(0)}.btn:disabled,.btn[aria-disabled=true]{cursor:not-allowed;opacity:.45;pointer-events:none}.btn svg{flex-shrink:0;height:16px;width:16px}.btn-add,.btn-create,.btn-primary,.btn-save,.btn-submit{background:var(--color-primary);border-color:var(--color-primary);color:var(--text-on-primary)}.btn-add:hover:not(:disabled),.btn-create:hover:not(:disabled),.btn-primary:hover:not(:disabled),.btn-save:hover:not(:disabled),.btn-submit:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:var(--shadow-primary)}.btn-edit,.btn-modify,.btn-secondary{background:var(--surface-primary);border-color:var(--border-default);color:var(--text-primary)}.btn-edit:hover:not(:disabled),.btn-modify:hover:not(:disabled),.btn-secondary:hover:not(:disabled){background:var(--surface-tertiary);border-color:var(--border-strong);color:var(--text-primary)}.btn-danger,.btn-delete{background:var(--color-danger);border-color:var(--color-danger);color:var(--text-on-danger)}.btn-danger:hover:not(:disabled),.btn-delete:hover:not(:disabled){background:var(--color-danger-dark);border-color:var(--color-danger-dark)}.btn-clear,.btn-warning{background:var(--color-warning);border-color:var(--color-warning);color:var(--text-on-primary)}.btn-clear:hover:not(:disabled),.btn-warning:hover:not(:disabled){background:var(--color-warning-dark);border-color:var(--color-warning-dark)}.btn-info,.btn-print{background:var(--color-info);border-color:var(--color-info);color:var(--text-on-primary)}.btn-info:hover:not(:disabled),.btn-print:hover:not(:disabled){background:var(--color-info-dark);border-color:var(--color-info-dark)}.btn-cancel,.btn-exit,.btn-gray{background:var(--surface-primary);border-color:var(--border-default);color:var(--text-secondary)}.btn-cancel:hover:not(:disabled),.btn-exit:hover:not(:disabled),.btn-gray:hover:not(:disabled){background:var(--surface-tertiary);border-color:var(--border-strong);color:var(--text-primary)}.btn-ghost{background:#0000;border-color:#0000;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--surface-tertiary);box-shadow:none;color:var(--text-primary);transform:none}.btn-outline{background:#0000;border-color:var(--color-primary);color:var(--color-primary)}.btn-outline:hover:not(:disabled){background:var(--color-primary-50);color:var(--color-primary-dark)}.btn-outline-danger{background:#0000;border-color:var(--color-danger);color:var(--color-danger)}.btn-outline-danger:hover:not(:disabled){background:var(--color-danger-50);color:var(--color-danger-dark)}.btn-xs{border-radius:var(--radius-md);font-size:var(--text-2xs);height:26px;padding:0 var(--space-2)}.btn-sm{height:30px}.btn-lg{font-size:var(--text-base);height:42px;padding:0 var(--space-6)}.btn-xl{border-radius:var(--radius-xl);font-size:var(--text-md);height:48px;padding:0 var(--space-8)}.btn-block{width:100%}.btn-icon{border-radius:var(--radius-lg);height:36px;padding:0;width:36px}.btn-icon.btn-sm{height:30px;width:30px}.btn-icon.btn-lg{height:42px;width:42px}.btn-loading{opacity:.7;pointer-events:none}.btn-loading:after{animation:spin .6s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:initial;content:"";height:14px;margin-left:var(--space-2);width:14px}.filter-group input[type=date],.filter-group input[type=number],.filter-group input[type=text],.filter-group select,.filter-input,.filter-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);height:36px;outline:none;padding:0 var(--space-3);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.filter-group select,.filter-select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:16px;padding-right:32px}.filter-group input:focus,.filter-group select:focus,.filter-input:focus,.filter-select:focus{border-color:var(--color-primary);box-shadow:none}.filter-group input:hover:not(:focus),.filter-group select:hover:not(:focus),.filter-input:hover:not(:focus),.filter-select:hover:not(:focus){border-color:var(--border-strong)}.filter-group{display:flex;flex-direction:column;gap:var(--space-1-5)}.filter-group label{font-weight:500;letter-spacing:.04em}.filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:var(--space-4)}.radio-item,.status-item{align-items:center;cursor:pointer;display:flex;gap:var(--space-2)}.radio-item input[type=radio],.status-item input[type=radio]{appearance:none;border:2px solid var(--border-strong);border-radius:50%;cursor:pointer;flex-shrink:0;height:16px;margin:0;position:relative;transition:all var(--transition-fast);width:16px}.radio-item input[type=radio]:checked,.status-item input[type=radio]:checked{background:var(--color-primary);border-color:var(--color-primary);box-shadow:inset 0 0 0 3px #fff}.radio-item input[type=radio]:hover,.status-item input[type=radio]:hover{border-color:var(--color-primary-light)}.radio-item label,.status-item label{color:var(--text-primary);cursor:pointer;font-size:var(--text-sm);-webkit-user-select:none;user-select:none}.report-type-card input[type=checkbox]{appearance:none;border:2px solid var(--border-strong);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;height:18px;margin:0;position:relative;transition:all var(--transition-fast);width:18px}.report-type-card input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}.report-type-card input[type=checkbox]:checked:after{border:solid #fff;border-width:0 2px 2px 0;content:"";height:10px;left:4px;position:absolute;top:1px;transform:rotate(45deg);width:6px}.report-type-card input[type=checkbox]:hover{border-color:var(--color-primary-light)}.alert{animation:fadeInDown .25s ease-out;border:1px solid #0000;border-radius:var(--radius-md)}.alert-error{border-color:var(--color-red-light)}.alert-success{background:var(--color-green-50);border-color:var(--color-green-100);color:var(--color-green-700)}.alert-warning{background:var(--color-orange-50);border-color:var(--color-orange);color:var(--color-orange)}.alert-info{background:var(--color-blue-50);border-color:var(--color-blue-200);color:var(--color-blue-dark)}.alert-close{align-items:center;border-radius:var(--radius-sm);display:inline-flex;justify-content:center;opacity:.6;padding:4px;transition:opacity var(--transition-fast)}.form-group{margin-bottom:var(--space-5)}.form-group label{color:var(--text-primary);display:block;font-size:var(--text-sm);font-weight:500;margin-bottom:var(--space-1-5)}.form-group input[type=date],.form-group input[type=email],.form-group input[type=number],.form-group input[type=password],.form-group input[type=tel],.form-group input[type=text],.form-group input[type=time],.form-group input[type=url],.form-group select,.form-group textarea{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);height:38px;outline:none;padding:0 var(--space-3);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.form-group select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:16px;cursor:pointer;padding-right:32px}.form-group textarea{height:auto;min-height:80px;padding:var(--space-2-5) var(--space-3);resize:vertical}.form-group input:hover:not(:focus):not(:disabled),.form-group select:hover:not(:focus):not(:disabled),.form-group textarea:hover:not(:focus):not(:disabled){border-color:var(--border-strong)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:none}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:var(--surface-tertiary);color:var(--text-tertiary);cursor:not-allowed}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-tertiary)}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:var(--text-base);gap:var(--space-2);-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;height:16px;width:16px}.form-actions{border-top:1px solid var(--border-default);display:flex;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-5)}.form-actions .btn{flex:1 1}.form-row{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,1fr);margin-bottom:var(--space-4)}.form-columns{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(2,1fr)}.form-column-left,.form-column-right{display:flex;flex-direction:column}.form-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,1fr)}.form-grid .form-group.full-width{grid-column:1/-1}.form-section{margin-bottom:var(--space-6)}.form-section h3{align-items:center;border-bottom:1px solid var(--border-default);color:var(--text-primary);display:flex;font-size:var(--text-md);font-weight:600;gap:var(--space-2);margin-bottom:var(--space-4);padding-bottom:var(--space-2)}.form-hint{color:var(--text-tertiary);display:block;font-size:var(--text-xs);margin-top:var(--space-1)}.checkbox-group{margin-bottom:var(--space-4)}.company-table-container,.department-table-container,.employee-table-container,.table-container,.user-table-container{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-bottom:var(--space-5);max-height:calc(100vh - 280px);overflow-x:auto;overflow-y:auto}.company-table,.data-table,.department-table,.employee-table,.user-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.company-table thead,.data-table thead,.department-table thead,.designation-table thead,.employee-table thead,.shift-table thead,.user-table thead{background:var(--surface-primary);border-bottom:2px solid var(--border-default);position:sticky;top:0;z-index:1}.company-table th,.data-table th,.department-table th,.designation-table th,.employee-table th,.shift-table th,.user-table th{color:var(--color-primary);font-size:var(--text-xs);font-weight:700;letter-spacing:.04em;padding:6px var(--space-4);text-align:left;text-transform:uppercase;white-space:nowrap}.company-table tbody tr,.data-table tbody tr,.department-table tbody tr,.designation-table tbody tr,.employee-table tbody tr,.shift-table tbody tr,.user-table tbody tr{border-bottom:1px solid var(--border-light);transition:background var(--transition-fast)}.company-table tbody tr:hover,.data-table tbody tr:hover,.department-table tbody tr:hover,.designation-table tbody tr:hover,.employee-table tbody tr:hover,.shift-table tbody tr:hover,.user-table tbody tr:hover{background:var(--color-primary-50)}.company-table tbody tr:last-child,.data-table tbody tr:last-child,.department-table tbody tr:last-child,.designation-table tbody tr:last-child,.employee-table tbody tr:last-child,.shift-table tbody tr:last-child,.user-table tbody tr:last-child{border-bottom:none}.company-table td,.data-table td,.department-table td,.designation-table td,.employee-table td,.shift-table td,.user-table td{color:var(--text-secondary);padding:4px var(--space-4)}.company-name,.department-name,.employee-name,.user-name-cell{color:var(--text-primary);font-weight:500}.empty-cell,.loading-cell{color:var(--text-tertiary);font-style:italic;padding:var(--space-10) var(--space-5)!important;text-align:center}.error-message{background:var(--color-red-50);border:1px solid var(--color-red-light);border-radius:var(--radius-md);color:var(--color-red-dark);margin-bottom:var(--space-5);padding:var(--space-3) var(--space-4)!important;text-align:center}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-xs);font-weight:500;line-height:1.6;padding:2px 8px}.badge.badge-success,.status-badge.active{background:var(--color-green-100);color:var(--color-green-700)}.badge.badge-danger,.status-badge.inactive{background:var(--color-red-50);color:var(--color-red)}.badge.badge-warning{background:var(--color-orange-50);color:var(--color-orange)}.badge.badge-info{background:var(--color-blue-50);color:var(--color-blue-dark)}.badge.badge-gray{background:var(--color-gray-100);color:var(--color-gray-600)}.action-buttons{align-items:center;display:flex;gap:var(--space-2);justify-content:center}.action-btn,.action-buttons .btn-delete,.action-buttons .btn-edit{align-items:center;background:none;border:1px solid #0000;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;display:inline-flex;height:32px;justify-content:center;padding:0;transition:all var(--transition-fast);width:32px}.action-btn:hover{border-color:var(--border-default)}.action-btn.btn-view{color:var(--color-gray-500)}.action-btn.btn-view:hover{background:var(--color-gray-50);border-color:var(--border-default);color:var(--text-primary)}.action-btn.btn-edit,.action-buttons .btn-edit{color:var(--color-primary)}.action-btn.btn-edit:hover,.action-buttons .btn-edit:hover{background:var(--color-primary-50);border-color:var(--color-primary-200);color:var(--color-primary-dark)}.action-btn.btn-delete,.action-buttons .btn-delete{color:var(--color-red)}.action-btn.btn-delete:hover,.action-buttons .btn-delete:hover{background:var(--color-red-50);border-color:var(--color-red-light);color:var(--color-red-dark)}.action-btn.btn-toggle{color:var(--color-primary)}.action-btn.btn-toggle:hover{background:var(--color-primary-50);border-color:var(--color-primary-200)}.pagination{display:flex;gap:var(--space-1);margin-top:var(--space-5)}.page-btn,.pagination{align-items:center;justify-content:center}.page-btn{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:var(--text-sm);height:32px;min-width:32px;padding:0 var(--space-2);transition:all var(--transition-fast)}.page-btn:hover:not(:disabled){background:var(--surface-tertiary);border-color:var(--border-strong)}.page-btn:disabled{cursor:not-allowed;opacity:.4}.page-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--text-inverse);font-weight:600}.page-numbers{display:flex;gap:var(--space-1)}.page-info{color:var(--text-tertiary);font-size:var(--text-sm);margin-left:var(--space-3)}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,var(--color-gray-100) 25%,var(--color-gray-200) 50%,var(--color-gray-100) 75%);background-size:200% 100%;border-radius:var(--radius-md)}.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-text.short{width:60%}.skeleton-circle{border-radius:50%;height:36px;width:36px}@media (max-width:768px){.page-container{padding:var(--space-3)}.modal-content{margin:var(--space-3);max-height:85vh;width:95%}.form-actions{flex-direction:column}.form-columns,.form-grid,.form-row{grid-template-columns:1fr}.data-table{font-size:var(--text-xs)}.data-table td,.data-table th{padding:var(--space-2) var(--space-3)}.pagination{gap:var(--space-1)}.page-numbers,.pagination{flex-wrap:wrap}.page-info{margin-left:0;text-align:center;width:100%}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}.table-container{-webkit-overflow-scrolling:touch}.action-btn,.action-buttons .btn-delete,.action-buttons .btn-edit{height:36px;width:36px}.btn,.btn-primary,.btn-secondary,button[type=submit]{font-size:var(--text-sm);min-height:42px}}@media (max-width:480px){.modal-content{border-radius:var(--radius-lg) var(--radius-lg) 0 0;bottom:0;left:0;margin:0;max-height:90vh;position:fixed;right:0;width:100%}.form-actions button{width:100%}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-0{margin-top:0}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-0{padding:0}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.flex,.flex-col{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-center{justify-content:center}.flex-between,.flex-center{align-items:center;display:flex}.flex-between{justify-content:space-between}.flex-start{justify-content:flex-start}.flex-end,.flex-start{align-items:center;display:flex}.flex-end{justify-content:flex-end}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.flex-1{flex:1 1}.flex-shrink-0{flex-shrink:0}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-1{grid-template-columns:1fr}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.col-span-full{grid-column:1/-1}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.border{border:1px solid var(--border-default)}.border-b{border-bottom:1px solid var(--border-default)}.border-t{border-top:1px solid var(--border-default)}.shadow-xs{box-shadow:var(--shadow-xs)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-none{box-shadow:none}.hidden{display:none}.block{display:block}.inline-flex{display:inline-flex}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.relative{position:relative}.w-full{width:100%}.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}.fade-in{animation:fadeInUp .35s ease-out both}.fade-in-1{animation-delay:.04s}.fade-in-2{animation-delay:.08s}.fade-in-3{animation-delay:.12s}.fade-in-4{animation-delay:.16s}.fade-in-5{animation-delay:.2s}.divider{background:var(--border-default);border:none;height:1px;margin:var(--space-4) 0}.no-data{padding:var(--space-10) var(--space-5)}.no-data,.no-data td{color:var(--text-tertiary);text-align:center}.no-data td{padding:var(--space-10) var(--space-5)!important}.photo-upload-box{min-height:120px}.photo-upload-box,.photo-upload-trigger{align-items:center;display:flex;justify-content:center}.photo-upload-trigger{background:#f9fafb;background:var(--surface-secondary,#f9fafb);border:2px dashed #d1d5db;border:2px dashed var(--border-default,#d1d5db);border-radius:8px;border-radius:var(--radius-md,8px);color:#9ca3af;color:var(--text-tertiary,#9ca3af);cursor:pointer;flex-direction:column;font-family:var(--font-sans);font-size:.875rem;font-size:var(--text-sm,.875rem);gap:8px;height:120px;transition:all .15s;width:100%}.photo-upload-trigger:hover:not(:disabled){background:#eff6ff;background:var(--color-primary-50,#eff6ff);border-color:#2563eb;border-color:var(--color-primary,#2563eb);color:#2563eb;color:var(--color-primary,#2563eb)}.photo-upload-trigger:disabled{cursor:not-allowed;opacity:.6}.photo-preview{align-items:center;display:flex;justify-content:center;position:relative;width:100%}.photo-preview img{border:1px solid #e5e7eb;border:1px solid var(--border-light,#e5e7eb);border-radius:8px;border-radius:var(--radius-md,8px);height:100px;object-fit:cover;width:100px}.photo-remove-btn{align-items:center;background:var(--color-red-50);border:none;border-radius:50%;color:var(--color-red);cursor:pointer;display:flex;height:28px;justify-content:center;position:absolute;right:0;top:0;transition:all .15s;width:28px}.photo-remove-btn:hover{background:#fca5a5;color:#dc2626}.photo-display{align-items:center;display:flex;justify-content:center;min-height:60px}.photo-display img{border:1px solid #e5e7eb;border:1px solid var(--border-light,#e5e7eb);border-radius:8px;border-radius:var(--radius-md,8px);height:80px;object-fit:cover;width:80px}.v3-page{animation:v3FadeUp .3s ease;display:flex;flex-direction:column;gap:14px;min-height:0}@keyframes v3FadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.v3-toolbar{align-items:center;background:#fff;background:var(--toolbar-bg,#fff);border:1px solid color-mix(in srgb,#fff 80%,#000 20%);border:1px solid color-mix(in srgb,var(--toolbar-bg,#fff) 80%,#000 20%);border-radius:var(--radius-xl);box-shadow:0 1px 3px #0000000d;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;min-height:44px;padding:var(--space-3) var(--space-5);transition:background .25s ease,color .25s ease,border-color .25s ease}.v3-toolbar,.v3-toolbar .v3-badge{color:var(--text-primary);color:var(--toolbar-text,var(--text-primary))}.v3-toolbar .v3-badge{text-shadow:none}.v3-toolbar .ss-searchable__trigger,.v3-toolbar input,.v3-toolbar select{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border-color:#ffffff40;color:var(--text-primary);color:var(--toolbar-text,var(--text-primary))}:root:not([style*="--toolbar-bg"]) .v3-toolbar .ss-searchable__trigger,:root:not([style*="--toolbar-bg"]) .v3-toolbar input,:root:not([style*="--toolbar-bg"]) .v3-toolbar select{background:var(--surface-secondary);border-color:var(--border-default);color:var(--text-primary)}.v3-toolbar-left{flex-wrap:wrap}.v3-toolbar-left,.v3-toolbar-right{align-items:center;display:flex;gap:8px}.v3-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-2xl);box-shadow:0 1px 4px #0000000f,0 1px 2px #0000000a;min-width:0}.v3-card-h{border-bottom:1px solid var(--border-default);padding:14px 18px}.v3-card-h,.v3-card-t{align-items:center;display:flex;gap:10px}.v3-card-t{color:var(--text-primary);font-size:var(--text-md);font-weight:700}.v3-ci{align-items:center;border-radius:var(--radius-lg);display:flex;flex-shrink:0;font-size:13px;height:24px;justify-content:center;width:24px}.v3-card-b{padding:14px 18px}.v3-card-link{background:none;border:none;color:var(--color-green);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600}.v3-card-link:hover{opacity:.7}.v3-g2{grid-gap:14px;grid-template-columns:1fr 1fr}.v3-g2,.v3-g3{display:grid;gap:14px}.v3-g3{grid-gap:14px;grid-template-columns:1fr 1fr 1fr}.v3-g4{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.v3-ga{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}@media (max-width:1200px){.v3-g4{grid-template-columns:1fr 1fr}}@media (max-width:900px){.v3-g3,.v3-g4{grid-template-columns:1fr 1fr}}@media (max-width:600px){.v3-g2,.v3-g3{grid-template-columns:1fr}}.v3-kpi{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:0 1px 3px #0000000d;overflow:hidden;padding:8px 10px;position:relative;transition:transform .2s,box-shadow .2s}.v3-g-compact{gap:10px}.v3-g-compact .v3-kpi{padding:6px 8px}.v3-g-compact .v3-kpi-icon{font-size:12px;height:24px;width:24px}.v3-g-compact .v3-kpi-icon svg{height:12px;width:12px}.v3-g-compact .v3-kpi-top{margin-bottom:3px}.v3-g-compact .v3-kpi-label{font-size:9px;letter-spacing:.5px;margin-bottom:1px}.v3-g-compact .v3-kpi-value{font-size:18px}.v3-kpi:hover{box-shadow:0 6px 16px #00000017;transform:translateY(-2px)}.v3-kpi.att-kpi-click{cursor:pointer;-webkit-user-select:none;user-select:none}.v3-kpi.att-kpi-click:hover{box-shadow:0 2px 10px #0000001a}.v3-kpi.att-kpi-active{box-shadow:0 0 0 4px #2563eb1f;outline:2px solid #2563eb;outline:2px solid var(--color-primary,#2563eb);outline-offset:-2px}.v3-kpi-accent{border-radius:var(--radius-xl) var(--radius-xl) 0 0;height:3px;left:0;position:absolute;right:0;top:0}.v3-kpi-glow{border-radius:50%;filter:blur(10px);height:40px;opacity:.07;position:absolute;right:-10px;top:-10px;width:40px}.v3-kpi-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:4px}.v3-kpi-icon{align-items:center;border-radius:var(--radius-lg);display:flex;font-size:14px;height:28px;justify-content:center;width:28px}.v3-kpi-icon svg{height:14px;width:14px}.v3-kpi-badge{border-radius:var(--radius-3xl);font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:700;padding:2px 7px}.v3-kpi-label{color:var(--text-tertiary);font-size:9px;font-weight:700;letter-spacing:.6px;margin-bottom:2px;text-transform:uppercase}.v3-kpi-value{color:var(--text-primary);font-family:var(--font-mono);font-size:20px;font-weight:800;line-height:1}.v3-kpi-sub{color:var(--text-tertiary);font-size:var(--text-2xs);margin-top:3px}.v3-kpi-bar{background:var(--border-default);border-radius:2px;height:3px;margin-top:7px;overflow:hidden}.v3-kpi-fill{border-radius:2px;height:100%;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.v3-tw{max-height:calc(100vh - 280px);overflow-x:auto;overflow-y:auto}.v3-tw::-webkit-scrollbar{height:3px;width:3px}.v3-tw::-webkit-scrollbar-thumb{background:var(--border-strong)}.v3-tbl{border-collapse:collapse;font-size:var(--text-sm);width:100%}.v3-tbl th{background:color-mix(in srgb,var(--color-teal) 5%,var(--surface-primary));color:var(--color-teal-dark);font-size:var(--text-2xs);font-weight:700;letter-spacing:.8px;padding:7px 10px;position:sticky;text-align:left;text-transform:uppercase;top:0;white-space:nowrap;z-index:1}.v3-tbl td,.v3-tbl th{border-bottom:1px solid var(--border-default)}.v3-tbl td{color:var(--text-secondary);line-height:1.3;padding:5px 10px;vertical-align:middle}.v3-tbl tr:last-child td{border-bottom:none}.v3-tbl tr:hover td{background:color-mix(in srgb,var(--color-teal) 5%,var(--surface-primary))}.v3-section-hdr{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.v3-section-title{color:var(--text-primary);flex:1 1;font-size:15px;font-weight:700}.v3-section-sub{color:var(--text-tertiary);font-size:12px;margin-top:2px}.v3-section-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.v3-tbl-wrap{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-2xl);overflow-x:auto;overflow-y:clip;width:100%}.v3-tbl-wrap .v3-tbl th{position:sticky;top:0;z-index:1}.v3-col-action{padding-right:12px!important;text-align:right;white-space:nowrap;width:1%}.v3-col-num{color:var(--text-tertiary);font-size:12px;padding-left:4px!important;padding-right:4px!important;text-align:center!important;white-space:nowrap;width:1px}.v3-badge{align-items:center;border-radius:var(--radius-3xl);display:inline-flex;font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:700;gap:3px;padding:2px 7px;white-space:nowrap}.v3-badge.green{background:var(--color-teal-100);color:var(--color-green)}.v3-badge.red{background:var(--color-pink-100);color:var(--color-pink)}.v3-badge.amber{background:var(--color-gold-50);color:#d97706}.v3-badge.blue{background:color-mix(in srgb,var(--text-primary) 8%,#0000);color:var(--color-gray-800)}.v3-badge.purple{background:var(--color-accent-50);color:#a67eff}.v3-badge.teal{background:var(--color-teal-100);color:var(--color-teal)}.v3-badge.pink{background:var(--color-pink-100);color:var(--color-pink)}.v3-badge.cyan{background:var(--color-teal-50);color:var(--color-teal)}.v3-btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:var(--weight-bold);gap:var(--space-1);padding:var(--space-2) var(--space-4);transition:all .15s;-webkit-user-select:none;user-select:none;white-space:nowrap}.v3-btn:hover{transform:translateY(-1px)}.v3-btn:active{transform:translateY(0);transition:none}.v3-btn-p{background:linear-gradient(135deg,var(--color-teal) 0,color-mix(in srgb,#00897b 75%,#0097a7) 100%);background:linear-gradient(135deg,var(--gs-btn-primary,var(--color-teal)) 0,color-mix(in srgb,var(--gs-btn-primary,#00897b) 75%,#0097a7) 100%);box-shadow:0 2px 8px color-mix(in srgb,var(--color-teal) 35%,#0000),inset 0 1px 0 #ffffff1f;box-shadow:0 2px 8px color-mix(in srgb,var(--gs-btn-primary,var(--color-teal)) 35%,#0000),inset 0 1px 0 #ffffff1f;color:var(--text-inverse)}.v3-btn-p:hover{background:linear-gradient(135deg,var(--color-teal-dark) 0,color-mix(in srgb,#00695c 80%,#00838f) 100%);background:linear-gradient(135deg,var(--gs-btn-hover,var(--color-teal-dark)) 0,color-mix(in srgb,var(--gs-btn-hover,#00695c) 80%,#00838f) 100%);box-shadow:0 4px 14px color-mix(in srgb,var(--color-teal) 45%,#0000);box-shadow:0 4px 14px color-mix(in srgb,var(--gs-btn-primary,var(--color-teal)) 45%,#0000)}.v3-btn-o{background:#0000;border:1px solid color-mix(in srgb,var(--color-teal) 40%,#0000);color:var(--color-teal)}.v3-btn-o:hover{background:var(--color-teal-50)}.v3-btn-g{background:var(--surface-primary);border:1px solid var(--border-default);box-shadow:0 1px 2px #0000000d;color:var(--text-secondary)}.v3-btn-g:hover{background:var(--surface-secondary);border-color:var(--border-strong);color:var(--text-primary)}.v3-btn-r{background:var(--color-pink-100);border:1px solid color-mix(in srgb,var(--color-pink) 20%,#0000);color:var(--color-pink)}.v3-btn-r:hover{background:var(--color-pink);color:var(--text-inverse)}.v3-btn-sm{font-size:var(--text-2xs);padding:var(--space-1) var(--space-3)}.v3-inp{background:var(--surface-primary);border:1.5px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:inset 0 1px 2px #0000000a;color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;padding:var(--space-2) var(--space-3);transition:border-color .2s,box-shadow .2s;width:100%}.v3-inp:focus{border-color:var(--color-teal);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-teal) 12%,#0000)}.v3-inp::placeholder{color:var(--text-tertiary)}select.v3-inp{cursor:pointer}textarea.v3-inp{resize:vertical}.v3-fg{display:flex;flex-direction:column;gap:4px}.v3-fl{color:var(--text-tertiary);font-size:var(--text-2xs);font-weight:700;letter-spacing:.6px;text-transform:uppercase}.v3-search{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);display:flex;gap:7px;padding:var(--space-1-5) var(--space-2-5)}.v3-search input{background:none;border:none;color:var(--text-primary);flex:1 1;font-family:var(--font-sans);font-size:var(--text-xs);outline:none}.v3-search input::placeholder{color:var(--text-tertiary)}.v3-sep{background:var(--border-default);height:1px;margin:9px 0}.v3-stat{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);display:flex;font-size:var(--text-sm);justify-content:space-between;padding:6px 9px}.v3-stat-label{color:var(--text-tertiary)}.v3-stat-value{font-family:var(--font-mono);font-weight:700}.v3-av{align-items:center;border-radius:50%;color:var(--text-inverse);display:flex;flex-shrink:0;font-size:var(--text-sm);font-weight:700;height:32px;justify-content:center;width:32px}.v3-feed{display:flex;flex-direction:column}.v3-fi{align-items:flex-start;border-bottom:1px solid var(--border-default);display:flex;gap:8px;padding:7px 0}.v3-fi:last-child{border-bottom:none}.v3-empty{color:var(--text-tertiary);padding:26px 14px;text-align:center}.v3-empty-icon{font-size:var(--text-4xl);margin-bottom:6px}.v3-empty-text{color:var(--text-secondary);font-size:var(--text-sm);font-weight:600;margin-bottom:3px}.v3-act{align-items:center;display:inline-flex;gap:6px}.v3-act button{align-items:center;background:var(--color-pink-50);border:none;border-radius:50%;color:var(--color-pink);cursor:pointer;display:flex;font-size:var(--text-sm);height:24px;justify-content:center;transition:all .15s;width:24px}.v3-act button:hover{background:var(--color-pink-50);transform:scale(1.1)}.v3-act button.approve{color:var(--color-green-600)}.v3-act button.approve,.v3-act button.approve:hover{background:var(--color-green-100)}.v3-toolbar select{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border:1px solid #ffffff40;border-radius:var(--radius-lg);color:var(--text-primary);color:var(--toolbar-text,var(--text-primary));cursor:pointer;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:600;padding:6px 12px;transition:background .2s,border-color .2s,color .2s}.v3-color-dot{border-radius:50%;display:inline-block;height:14px;width:14px}.v3-num{color:var(--color-teal);font-family:var(--font-mono);font-size:var(--text-xl);font-weight:800}.v3-status-text{font-size:var(--text-xs);font-weight:700}.v3-status-text.approved{color:var(--color-green-600)}.v3-status-text.pending{color:#d97706}.v3-status-text.rejected{color:var(--color-red-dark)}.v3-status-text.cancelrequested{color:#b45309}.v3-status-text.cancelled{color:var(--color-gray-500)}.v3-emp-cell{align-items:center;display:flex;gap:10px}.v3-emp-name{color:var(--text-primary);font-size:var(--text-sm);font-weight:700}.v3-emp-code{color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--text-2xs)}.skip-link{background:var(--color-primary);border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-lg);color:var(--text-on-primary);font-size:var(--text-base);font-weight:var(--weight-semibold);left:var(--space-4);padding:var(--space-3) var(--space-5);position:fixed;text-decoration:none;top:-100%;transition:top var(--transition-fast);z-index:var(--z-skip-link)}.skip-link:focus{outline:none;top:0}:focus-visible{box-shadow:var(--focus-ring-shadow);outline:none}.btn:focus-visible,.v3-btn:focus-visible,[role=button]:focus-visible,button:focus-visible{box-shadow:var(--focus-ring-shadow);outline:none}.v3-inp:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{border-color:var(--focus-ring-color);box-shadow:0 0 0 1px var(--focus-ring-color);outline:none}a:focus-visible{border-radius:var(--radius-sm);box-shadow:var(--focus-ring-shadow);outline:none}[role=listbox]:focus-visible,[role=menuitem]:focus-visible,[role=option]:focus-visible,[role=tab]:focus-visible,[tabindex]:focus-visible{box-shadow:var(--focus-ring-shadow);outline:none}input[type=checkbox]:focus-visible,input[type=radio]:focus-visible{box-shadow:0 0 0 var(--focus-ring-offset) var(--surface-primary),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color)}:focus:not(:focus-visible){box-shadow:none;outline:none}.btn:hover:not(:disabled):not(:focus-visible),.v3-btn:hover:not(:focus-visible){box-shadow:var(--shadow-sm)}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.sr-only-focusable:active,.sr-only-focusable:focus{margin:inherit;padding:inherit}.not-sr-only,.sr-only-focusable:active,.sr-only-focusable:focus{clip:auto;height:auto;overflow:visible;position:static;white-space:normal;width:auto}.not-sr-only{margin:0;padding:0}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}@media (forced-colors:active){.btn,.v3-btn{border:1px solid ButtonText}.badge,.v3-badge{border:1px solid}input,select,textarea{border:1px solid ButtonText}}[aria-disabled=true],[disabled]{cursor:not-allowed;opacity:.5;pointer-events:none}[aria-busy=true]{cursor:progress}[aria-invalid=true]{border-color:var(--color-danger)!important}[aria-invalid=true]:focus-visible{box-shadow:0 0 0 1px var(--color-danger)}[aria-live]{position:relative}@media (hover:none) and (pointer:coarse){.action-btn,.btn,.page-btn,.sb-item,.v3-btn,[role=button],button{min-height:44px;min-width:44px}input,select,textarea{font-size:16px!important;min-height:44px}}*{-webkit-tap-highlight-color:transparent}.att-table-wrap,.dashboard-main,.hm-feed,.lm-table-wrap,.notif-list,.sb-nav,.table-container,.table-wrapper,.v3-tw{-webkit-overflow-scrolling:touch}.dashboard-main{overscroll-behavior-y:contain}@media (hover:none) and (pointer:coarse){.btn,.hm-punch-btn,.hm-qa-item,.inv-btn,.lm-btn,.pr-btn,.quick-action-item,.sb-item,[role=button],button{min-height:44px}input,select,textarea{font-size:16px!important;min-height:44px}}@media (max-width:1200px){.company-header,.component-header,.department-header,.designation-header,.employee-header,.page-header,.salary-type-header,.shift-header,.user-header{flex-wrap:wrap;gap:var(--space-3)}}@media (max-width:900px){.filter-row,.form-grid{flex-wrap:wrap}.notif-dropdown{right:-60px;width:320px}.profile-panel{max-width:100%!important;width:100%!important}}@media (max-width:768px){.company-container,.component-container,.department-container,.employee-container,.page-container,.user-container{padding:var(--space-3)}.company-header,.component-header,.department-header,.designation-header,.employee-header,.page-header,.salary-type-header,.shift-header,.user-header{align-items:flex-start;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-3);padding-bottom:var(--space-3)}.company-header h2,.component-header h2,.department-header h2,.employee-header h2,.page-header h2{font-size:var(--text-lg)}.header-actions,.header-right{display:flex;flex-wrap:wrap;gap:var(--space-2);width:100%}.data-table-wrapper,.lm-table-wrap,.table-container,.table-wrapper,.v3-tw{-webkit-overflow-scrolling:touch;margin:0 calc(var(--space-3)*-1);overflow-x:auto;padding:0 var(--space-3)}table td,table th{white-space:nowrap}.modal-overlay{padding:var(--space-2)}.modal-content{border-radius:var(--radius-lg);max-height:95vh}.modal-content.modal-lg,.modal-content.modal-xl{max-width:100%}.modal-header{padding:var(--space-3) var(--space-4)}.modal-body{padding:var(--space-4)}.modal-footer{flex-wrap:wrap;padding:var(--space-3) var(--space-4)}.filter-row{align-items:stretch;flex-direction:column;gap:var(--space-2)}.filter-row .filter-group,.filter-row .filter-input,.filter-row .filter-select{width:100%}.v3-toolbar{gap:6px;padding:var(--space-2) var(--space-3)}.v3-toolbar-left,.v3-toolbar-right{justify-content:center;width:100%}.v3-tw{max-height:none;overflow-x:auto}.v3-g4{grid-template-columns:1fr}.btn-lg{width:100%}.att-search,.lm-search,.search-bar,.v3-search{max-width:100%;width:100%}.employee-actions,.employee-toolbar{align-items:stretch;flex-direction:column;gap:var(--space-2)}.emp-form-body{grid-template-columns:1fr}.emp-form-row{flex-direction:column;gap:4px}.emp-form-row label{width:auto}.cs-root{padding:var(--space-3)}.cs-header{align-items:flex-start;flex-direction:column;gap:var(--space-2)}.cs-grid-2,.cs-tab-grid-2{grid-template-columns:1fr}.cs-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.lm-header{align-items:flex-start;flex-direction:column}.lm-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.lm-modal-row-2{grid-template-columns:1fr}.lm-toolbar{align-items:stretch;flex-direction:column;gap:var(--space-2)}.attendance-modal .form-grid,.biometric-grid,.device-grid{grid-template-columns:1fr}.sh-sidebar{display:none}.sh-content{margin-left:0}.sh-mobile-nav{display:flex}.shift-roster-table{-webkit-overflow-scrolling:touch;overflow-x:auto}.login-container{flex-direction:column}.login-hero{display:none}.login-form-side{max-width:none;padding:var(--space-6) var(--space-4);width:100%}.topbar-left{flex:1 1;min-width:0;overflow:hidden}.tb-title{overflow:hidden;white-space:nowrap}.tb-name{overflow:hidden;text-overflow:ellipsis}.tb-chip.tb-date,.tb-chip.tb-time-chip,.tb-theme span:last-child{display:none}.cl-toolbar,.dc-toolbar{align-items:stretch;flex-direction:column;gap:var(--space-2)}.cl-footer,.cl-header,.cp-content-hdr,.cp-page-hdr,.dc-footer,.dc-header{align-items:flex-start;flex-direction:column;gap:var(--space-2)}.cp-table-wrap,.cp-tbl-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.cp-form-row,.cp-form-row-3{grid-template-columns:1fr}.ss-page-hdr{margin-bottom:var(--space-4);padding-bottom:var(--space-3)}.ss-content-hdr,.ss-page-hdr{align-items:flex-start;flex-direction:column;gap:var(--space-2)}.ss-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.ss-form-row{grid-template-columns:1fr}.ss-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.shift-planner-header,.sp-header,.st-header,.st-toolbar{align-items:flex-start;flex-direction:column;gap:var(--space-2)}.sp-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.audit-header{align-items:flex-start;flex-direction:column;gap:var(--space-2)}}@media (max-width:480px){.company-container,.component-container,.department-container,.employee-container,.page-container,.user-container{padding:var(--space-2)}.modal-content{border-radius:var(--radius-md);margin:var(--space-1)}.modal-header h3{font-size:var(--text-base)}.v3-g2,.v3-g3,.v3-g4{grid-template-columns:1fr}.btn{font-size:var(--text-xs);height:38px;padding:0 var(--space-3)}.company-header h2,.component-header h2,.department-header h2,.employee-header h2,.page-header h2{font-size:var(--text-base)}.v3-card-b,.v3-card-h{padding:10px 12px}.pagination-container{align-items:stretch;flex-direction:column;gap:var(--space-2)}.pagination-controls,.pagination-pages{flex-wrap:wrap;justify-content:center}.pagination-info{font-size:var(--text-xs);text-align:center}.hm-att-grid,.hm-punch-grid{grid-template-columns:1fr 1fr}.hm-punch-grid{gap:6px}.hm-punch-btn{padding:8px 6px}.hm-punch-btn svg{height:16px;width:16px}.hm-leave-stats,.lm-kpi-grid{grid-template-columns:1fr}.emp-form-section{padding:var(--space-3)}.cs-root{padding:var(--space-2)}.cs-header-title{font-size:var(--text-lg)}.notif-dropdown{left:var(--space-2);position:fixed;right:var(--space-2);top:56px;width:auto}.profile-panel{left:0!important;max-width:100vw!important;width:100vw!important}.pr-form-grid-2,.pr-form-grid-3,.pr-run-stats{grid-template-columns:1fr}.inv-header{flex-wrap:wrap;gap:6px;height:auto;padding:10px}.inv-grid-2,.inv-grid-3,.inv-stats-grid{grid-template-columns:1fr}.inv-list-toolbar{align-items:stretch;flex-direction:column}.inv-search{width:100%}.tb-bread,.tb-theme{display:none}.cl-kpis,.dc-kpis,.st-kpis{grid-template-columns:1fr!important}.cp-root{padding:var(--space-2)!important}.ss-form-row{grid-template-columns:1fr}.ss-tc-metrics{grid-template-columns:1fr 1fr}}@media (max-height:500px) and (orientation:landscape){.modal-overlay{align-items:flex-start;padding:var(--space-1)}.modal-content{max-height:98vh}.sidebar.mobile-open{max-height:100vh;overflow-y:auto}}@supports (padding:env(safe-area-inset-bottom)){.app-footer-bar{padding-bottom:env(safe-area-inset-bottom)}.dashboard-main{padding-bottom:calc(var(--space-6) + 44px + env(safe-area-inset-bottom))}@media (max-width:768px){.dashboard-main{padding-bottom:calc(var(--space-3) + 44px + env(safe-area-inset-bottom))}}}@media print{.app-footer-bar,.dashboard-topbar,.sidebar,.sidebar-backdrop,.tb-hamburger{display:none!important}.dashboard-layout{padding-left:0!important}.dashboard-main{padding:0}}code{font-family:var(--font-mono)}.electemb-arcs{animation:electemb-spin 1.2s linear infinite;transform-origin:50px 50px}@keyframes electemb-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.electemb-center-text{fill:#555;font-family:inherit;font-size:14px;font-weight:400}[data-theme=dark] .electemb-center-text{fill:#cbd5e1}.electemb-page{flex-direction:column;gap:12px;min-height:180px;padding:48px 16px;width:100%}.electemb-overlay,.electemb-page{align-items:center;display:flex;justify-content:center}.electemb-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#fff9;inset:0;position:fixed;z-index:9999}[data-theme=dark] .electemb-overlay{background:#0f172a99}.electemb-overlay-card{align-items:center;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f;display:flex;flex-direction:column;gap:12px;padding:32px 40px}[data-theme=dark] .electemb-overlay-card{background:#1e293b;box-shadow:0 8px 32px #0006}.electemb-inline{align-items:center;display:inline-flex;line-height:1;vertical-align:middle}.electemb-message{color:#64748b;font-size:13px;font-weight:500;letter-spacing:.01em}[data-theme=dark] .electemb-message{color:#94a3b8}.bs-overlay{align-items:center;animation:bs-fade-in .15s ease;background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}@keyframes bs-fade-in{0%{opacity:0}to{opacity:1}}.bs-modal{animation:bs-slide-up .2s ease;background:var(--color-gray-800);border:1px solid var(--color-gray-700);border-radius:var(--radius-3xl);box-shadow:0 24px 64px #0006;box-sizing:border-box;flex-shrink:0;max-height:460px;max-width:370px;overflow:hidden;width:370px}@keyframes bs-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.bs-header{border-bottom:1px solid var(--color-gray-700);padding:18px 20px 14px}.bs-title{color:var(--text-inverse);font-size:var(--text-lg);font-weight:700;gap:8px}.bs-close,.bs-title{align-items:center;display:flex}.bs-close{background:none;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;justify-content:center;padding:4px;transition:background .15s,color .15s}.bs-close:hover{background:var(--color-gray-700);color:var(--text-inverse)}.bs-list{display:flex;flex:1 1;flex-direction:column;gap:8px;overflow-y:auto;padding:12px}.bs-item{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;display:flex;gap:12px;padding:14px 16px;transition:background .15s,border-color .15s,box-shadow .15s}.bs-item:hover{border-color:var(--border-strong);box-shadow:0 2px 8px #00000014}.bs-item.active{background:var(--color-green-50);border-color:#00d4aa50;box-shadow:0 0 0 2px #00d4aa20}.bs-item-name{color:var(--color-gray-800);flex:1 1;font-size:var(--text-base);font-weight:600}.bs-item.active .bs-item-name{color:var(--color-teal-dark)}.bs-badge{background:#e8edf3;border-radius:var(--radius-3xl);color:var(--text-secondary);font-size:var(--text-sm);font-weight:600;padding:3px 10px;white-space:nowrap}.bs-badge.active{background:var(--color-green-100);color:var(--color-green-600)}.bs-badge.branch{background:var(--color-indigo-50);color:var(--color-indigo)}.bs-empty{padding:32px}.login-page{display:flex;min-height:100vh}.login-hero{background:var(--color-gray-900);color:#fff;display:flex;flex:0 0 480px;flex-direction:column;justify-content:space-between;overflow:hidden;padding:var(--space-10) var(--space-10);position:relative}.login-hero:before{background:#2563eb14;height:400px;right:-120px;top:-120px;width:400px}.login-hero:after,.login-hero:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.login-hero:after{background:#2563eb0f;bottom:-80px;height:280px;left:-80px;width:280px}.hero-content{position:relative;z-index:1}.hero-logo{align-items:center;background:var(--color-primary);border-radius:var(--radius-lg);color:#fff;color:var(--text-on-primary,#fff);display:flex;height:52px;justify-content:center;margin-bottom:var(--space-8);width:52px}.hero-title{font-size:2rem;font-weight:700;letter-spacing:-.03em;line-height:1.2;margin-bottom:var(--space-3)}.hero-desc{color:var(--color-gray-400);font-size:var(--text-md);line-height:var(--leading-relaxed);margin-bottom:var(--space-10);max-width:340px}.hero-features{display:flex;flex-direction:column;gap:var(--space-4)}.hero-feature{align-items:center;color:var(--color-gray-300);display:flex;font-size:var(--text-sm);gap:var(--space-3)}.feature-dot{background:var(--color-primary);border-radius:50%;flex-shrink:0;height:6px;width:6px}.hero-footer{color:var(--color-gray-500);font-size:var(--text-xs);position:relative;z-index:1}.login-form-panel{align-items:center;background:var(--surface-primary);display:flex;flex:1 1;justify-content:center;padding:var(--space-10)}.login-form-wrapper{max-width:380px;width:100%}.form-heading{margin-bottom:var(--space-8)}.form-heading h2{color:var(--text-primary);font-size:var(--text-3xl);font-weight:700;letter-spacing:-.02em;margin-bottom:var(--space-2)}.form-heading p{color:var(--text-tertiary);font-size:var(--text-base);line-height:var(--leading-normal)}.login-server-banner{align-items:center;animation:fadeInDown .25s ease-out;border:1px solid #0000;border-radius:var(--radius-md);display:flex;font-size:var(--text-sm);gap:10px;margin-bottom:var(--space-4);padding:12px 14px;transition:background .4s ease,border-color .4s ease}.login-server-banner.offline{background:#fff7ed;border-color:#ea580c40;color:#c2410c}.login-server-banner.checking{background:#f8fafc;border-color:#64748b33;color:#475569}.login-server-banner.online{background:#f0fdf4;border-color:#22c55e4d;color:#166534}.lsb-icon{align-items:center;display:flex;flex-shrink:0}.lsb-body{display:flex;flex:1 1;flex-direction:column;gap:2px;line-height:1.4}.lsb-title{font-weight:600}.lsb-sub{font-size:12px;opacity:.85}.lsb-dots{align-items:flex-end;display:flex;flex-shrink:0;gap:3px;height:18px}.dot{background:currentColor;border-radius:2px;opacity:.35;width:4px}.d1{height:6px}.d2{height:10px}.d3{height:14px}.dot.offline{opacity:.25}.dot.checking{animation:dotPulse 1.2s ease-in-out infinite;opacity:.6}.d1.checking{animation-delay:0s}.d2.checking{animation-delay:.2s}.d3.checking{animation-delay:.4s}.dot.online{opacity:1}@keyframes dotPulse{0%,to{opacity:.25}50%{opacity:1}}.lsb-retry{background:none;border:1px solid;border-radius:4px;color:inherit;cursor:pointer;flex-shrink:0;font-size:11px;opacity:.75;padding:3px 8px;transition:opacity .15s}.lsb-retry:hover{opacity:1}.lsb-spinner{animation:lsbSpin .8s linear infinite;flex-shrink:0;height:18px;width:18px}@keyframes lsbSpin{to{transform:rotate(1turn)}}.login-server-banner.online{animation:fadeInDown .3s ease-out}.login-warn{align-items:flex-start;animation:fadeInDown .25s ease-out;background:#fff7ed;border:1px solid #ea580c33;border-radius:var(--radius-md);color:#c2410c;display:flex;font-size:var(--text-sm);gap:var(--space-2);line-height:var(--leading-normal);margin-bottom:var(--space-4);padding:var(--space-3) var(--space-4)}.login-warn svg{flex-shrink:0;margin-top:1px}.login-error{align-items:flex-start;animation:fadeInDown .25s ease-out;background:var(--color-red-50);border:1px solid #ef444426;border-radius:var(--radius-md);color:var(--color-red-dark);display:flex;font-size:var(--text-sm);gap:var(--space-2);line-height:var(--leading-normal);margin-bottom:var(--space-5);padding:var(--space-3) var(--space-4)}.login-error svg{flex-shrink:0;margin-top:1px}.field{margin-bottom:var(--space-5)}.field label{color:var(--text-primary);display:block;font-size:var(--text-sm);font-weight:500;margin-bottom:var(--space-1-5)}.field input{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);height:42px;outline:none;padding:0 var(--space-3-5);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.field input:hover{border-color:var(--border-strong)}.field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1f}.field input::placeholder{color:var(--text-tertiary)}.password-wrapper{position:relative}.password-wrapper input{padding-right:var(--space-10)}.toggle-pw{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;display:flex;justify-content:center;padding:var(--space-1);position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);transition:color var(--transition-fast)}.toggle-pw:hover{color:var(--text-secondary)}.login-btn{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;color:var(--text-on-primary,#fff);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:var(--text-base);font-weight:600;gap:var(--space-2);height:42px;justify-content:center;margin-top:var(--space-2);padding:0 var(--space-5);transition:background var(--transition-fast),box-shadow var(--transition-fast);width:100%}.login-btn:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-primary)}.login-btn:active:not(:disabled){background:var(--color-primary-dark);box-shadow:none}.login-btn:disabled{cursor:not-allowed;opacity:.65}@media (max-width:900px){.login-hero{display:none}.login-form-panel{padding:var(--space-6)}.login-form-wrapper{max-width:420px}.form-heading h2{font-size:var(--text-2xl)}}@media (max-width:480px){.login-form-panel{padding:var(--space-5)}}.forgot-password-link{color:var(--color-primary);display:block;font-size:var(--text-sm);font-weight:500;margin-top:var(--space-4);text-align:center;text-decoration:none;transition:color var(--transition-fast)}.forgot-password-link:hover{color:var(--color-primary-dark);text-decoration:underline}.back-to-login{align-items:center;color:var(--text-tertiary);display:flex;font-size:var(--text-sm);font-weight:500;gap:var(--space-1-5);justify-content:center;margin-top:var(--space-5);text-decoration:none;transition:color var(--transition-fast)}.back-to-login:hover{color:var(--text-primary)}.reset-token-result{align-items:center;display:flex;flex-direction:column;text-align:center}.reset-success-icon{color:var(--color-green)}.login-mode-field,.reset-success-icon{margin-bottom:var(--space-4)}.login-mode-toggle,.login-mode-toggle .mode-btn{display:flex;gap:var(--space-2)}.login-mode-toggle .mode-btn{align-items:center;background:var(--bg-primary);border:1.5px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:500;justify-content:center;padding:var(--space-2) var(--space-3);transition:all .15s ease}.login-mode-toggle .mode-btn.active,.login-mode-toggle .mode-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.login-mode-toggle .mode-btn.active{background:#2563eb14;background:var(--color-primary-light,#2563eb14)}.reset-info{color:var(--text-secondary);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin-bottom:var(--space-5)}.token-display{align-items:center;background:#f8f9fa;background:var(--surface-secondary,#f8f9fa);border:1px solid var(--border-default);border-radius:var(--radius-md);display:flex;gap:var(--space-2);margin-bottom:var(--space-2);padding:var(--space-3);width:100%}.token-code{color:var(--text-primary);flex:1 1;font-family:monospace;font-family:var(--font-mono,monospace);font-size:var(--text-xs);text-align:left;word-break:break-all}.token-copy-btn{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-sm);color:#fff;color:var(--text-on-primary,#fff);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:var(--text-xs);font-weight:600;gap:var(--space-1);padding:var(--space-1-5) var(--space-3);transition:background var(--transition-fast);white-space:nowrap}.token-copy-btn:hover{background:var(--color-primary-dark)}.ss-searchable{display:inline-flex;flex:1 1;min-width:0;position:relative}.ss-searchable--disabled{opacity:.55;pointer-events:none}.ss-searchable__trigger{align-items:center;background:#fff;background:var(--input-bg,#fff);border:1px solid #ccc;border:1px solid var(--border-color,#ccc);border-radius:6px;border-radius:var(--radius-sm,6px);color:#333;color:var(--text-primary,#333);cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-size:var(--text-sm,13px);gap:6px;justify-content:space-between;line-height:1.45;min-height:32px;outline:none;padding:6px 10px;text-align:left;transition:border-color .2s;width:100%}.ss-searchable--open .ss-searchable__trigger,.ss-searchable__trigger:focus{border-color:#2563eb;border-color:var(--primary,#2563eb);box-shadow:none}.ss-searchable__value{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ss-searchable__chevron,.ss-searchable__placeholder{color:#999;color:var(--text-tertiary,#999)}.ss-searchable__chevron{flex-shrink:0;transition:transform .2s}.ss-searchable__chevron--up{transform:rotate(180deg)}.ss-searchable__dropdown{animation:ssDropIn .12s ease-out;background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:6px;border-radius:var(--radius-sm,6px);box-shadow:none;left:0;margin-top:4px;min-width:180px;overflow:hidden;position:absolute;right:0;top:100%;z-index:9999}.ss-searchable__dropdown--up{bottom:100%;margin-bottom:4px;margin-top:0;top:auto}@keyframes ssDropIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ss-searchable__search-wrap{align-items:center;border-bottom:1px solid #eee;border-bottom:1px solid var(--border-color,#eee);display:flex;padding:6px 8px;position:relative}.ss-searchable__search-icon{color:#aaa;color:var(--text-tertiary,#aaa);left:14px;pointer-events:none;position:absolute}.ss-searchable__search{background:#f8f8f8;background:var(--surface-secondary,#f8f8f8);border:1px solid #ddd;border:1px solid var(--border-color,#ddd);border-radius:6px;border-radius:var(--radius-sm,6px);color:#333;color:var(--text-primary,#333);font-family:inherit;font-size:13px;font-size:var(--text-sm,13px);outline:none;padding:5px 24px 5px 28px;width:100%}.ss-searchable__search:focus{border-color:#2563eb;border-color:var(--primary,#2563eb)}.ss-searchable__search::placeholder{color:#aaa;color:var(--text-tertiary,#aaa)}.ss-searchable__clear{background:none;border:none;color:#999;color:var(--text-tertiary,#999);cursor:pointer;font-size:16px;line-height:1;padding:0 2px;position:absolute;right:14px}.ss-searchable__clear:hover{color:#333;color:var(--text-primary,#333)}.ss-searchable__list{max-height:200px;overflow-y:auto;padding:4px 0}.ss-searchable__list::-webkit-scrollbar{width:5px}.ss-searchable__list::-webkit-scrollbar-thumb{background:#ccc;background:var(--border-color,#ccc);border-radius:3px}.ss-searchable__item{align-items:center;color:#333;color:var(--text-primary,#333);cursor:pointer;display:flex;font-size:13px;font-size:var(--text-sm,13px);justify-content:space-between;line-height:1.4;padding:6px 12px;transition:background .1s}.ss-searchable__item--highlighted{background:#f0f4ff;background:var(--surface-secondary,#f0f4ff)}.ss-searchable__item--selected{color:#2563eb;color:var(--primary,#2563eb);font-weight:600}.ss-searchable__item:active{background:#2563eb1a}.ss-searchable__check{color:#2563eb;color:var(--primary,#2563eb);flex-shrink:0;font-size:13px;margin-left:8px}.ss-searchable__empty{color:#999;color:var(--text-tertiary,#999);font-size:13px;font-size:var(--text-sm,13px);padding:16px 12px;text-align:center}.emp-dropdown-with-actions .ss-searchable__trigger,.emp-form-row .ss-searchable__trigger{font-size:13px;font-size:var(--text-sm,13px);padding:6px 10px}.ss-searchable.v3-inp .ss-searchable__trigger{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);color:var(--text-primary);font-size:var(--text-sm);padding:var(--space-2) var(--space-3)}.ss-searchable.v3-inp .ss-searchable__trigger:focus,.ss-searchable.v3-inp.ss-searchable--open .ss-searchable__trigger{border-color:var(--color-teal);box-shadow:none}.ss-searchable.ss-select .ss-searchable__trigger{background:#fff;background:var(--surface-primary,#fff);border:1px solid #cbd5e1;border:1px solid var(--border-default,#cbd5e1);border-radius:8px;font-size:13px;padding:7px 10px}.ss-searchable.ss-select .ss-searchable__trigger:focus{border-color:#6366f1}.ss-searchable.pr-co-select .ss-searchable__trigger{border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:8px;font-size:13px;padding:6px 14px}.ss-searchable.inv-select .ss-searchable__trigger{background:#fff;background:var(--inv-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--inv-border,#e2e8f0);border-radius:8px;font-size:12px;padding:7px 12px}.ss-searchable.prs-select .ss-searchable__trigger{border:1px solid #cbd5e1;border-radius:8px;font-size:13px;padding:7px 10px}.ss-searchable.filter-select{appearance:none;-webkit-appearance:unset;background:#0000;background-image:none;border:none;box-shadow:none;height:auto;padding:0}.ss-searchable.filter-select:focus,.ss-searchable.filter-select:hover{border:none;box-shadow:none}.ss-searchable.filter-select .ss-searchable__trigger{background:#fff;background:var(--surface-primary,#fff);border:1px solid #ccc;border:1px solid var(--border-default,#ccc);border-radius:6px;border-radius:var(--radius-md,6px);font-size:13px;font-size:var(--text-sm,13px);height:36px}.ss-searchable.filter-select .ss-searchable__trigger:focus,.ss-searchable.filter-select.ss-searchable--open .ss-searchable__trigger{border-color:#2563eb;border-color:var(--color-primary,#2563eb);box-shadow:none}.ss-searchable.filter-select .ss-searchable__trigger:hover:not(:focus){border-color:#94a3b8;border-color:var(--border-strong,#94a3b8)}.v3-page .v3-tbl td:first-child,.v3-page .v3-tbl th:first-child{width:48px}.v3-page .v3-tbl td:nth-child(2),.v3-page .v3-tbl th:nth-child(2){width:auto}.v3-page .v3-tbl td:nth-child(3),.v3-page .v3-tbl th:nth-child(3){text-align:center;width:110px}.v3-page .v3-tbl td:nth-child(4),.v3-page .v3-tbl th:nth-child(4){width:110px}.v3-page .v3-tbl td:nth-child(5),.v3-page .v3-tbl th:nth-child(5){width:90px}.ss-root,.ss-tab-content{--ss-bg:#080d18;--ss-bg-2:#0c1222;--ss-bg-card:#ffffff0a;--ss-border:#ffffff12;--ss-text-1:#e2e8f0;--ss-text-2:#cbd5e1;--ss-text-3:#94a3b8;--ss-text-4:#64748b;--ss-blue:#0ea5e9;--ss-blue-dim:#0ea5e91f;--ss-green:#4ade80;--ss-green-dim:#4ade801f;--ss-amber:#fbbf24;--ss-amber-dim:#fbbf241f;--ss-red:#f87171;--ss-red-dim:#f871711f;--ss-purple:#a78bfa;--ss-border-r:10px}.ss-root{background:var(--ss-bg);color:var(--ss-text-1);font-family:Inter,Segoe UI,system-ui,sans-serif;min-height:100vh;padding:24px 28px 40px}.ss-page-hdr{align-items:flex-start;border-bottom:1px solid var(--ss-border);display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:20px}.ss-page-title{color:var(--ss-text-1);font-size:22px;font-weight:700;letter-spacing:-.3px;margin-bottom:4px}.ss-page-sub{color:var(--ss-text-4);font-size:13px}.ss-tabs{border-bottom:1px solid var(--ss-border);display:flex;gap:4px;margin-bottom:24px;padding-bottom:0}.ss-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--ss-text-3);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:7px;margin-bottom:-1px;padding:10px 18px;transition:all .15s ease;white-space:nowrap}.ss-tab:hover{background:var(--ss-bg-card);border-radius:6px 6px 0 0;color:var(--ss-text-1)}.ss-tab--active{border-bottom-color:var(--ss-blue);color:var(--ss-blue);font-weight:600}.ss-tab-content{animation:ssFadeIn .2s ease}@keyframes ssFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.ss-content-hdr{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px}.ss-content-title{color:var(--ss-text-1);font-size:16px;font-weight:600;margin-bottom:3px}.ss-content-sub{color:var(--ss-text-4);font-size:12px}.ss-hdr-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.ss-btn{border:none;border-radius:7px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .15s;white-space:nowrap}.ss-btn-primary{background:var(--ss-blue);color:#fff}.ss-btn-primary:hover{background:#0284c7}.ss-btn-ghost{background:var(--ss-bg-card);border:1px solid var(--ss-border);color:var(--ss-text-2)}.ss-btn-ghost:hover{background:#ffffff12}.ss-icon-btn{align-items:center;background:var(--ss-bg-card);border:1px solid var(--ss-border);border-radius:6px;color:var(--ss-text-3);cursor:pointer;display:inline-flex;font-size:13px;height:30px;justify-content:center;transition:all .15s;width:30px}.ss-icon-btn:hover{background:#ffffff14;color:var(--ss-text-1)}.ss-icon-btn-danger:hover{background:var(--ss-red-dim);border-color:var(--ss-red);color:var(--ss-red)}.ss-search{background:var(--ss-bg-2);border:1px solid var(--ss-border);border-radius:7px;color:var(--ss-text-1);font-size:13px;outline:none;padding:8px 12px;transition:border .15s;width:220px}.ss-search:focus{border-color:var(--ss-blue)}.ss-select{background:var(--ss-bg-2);border:1px solid var(--ss-border);border-radius:7px;color:var(--ss-text-1);cursor:pointer;font-size:13px;outline:none;padding:8px 12px}.ss-select-full{width:100%}.ss-template-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(310px,1fr))}.ss-template-card{background:var(--ss-bg-card);border:1px solid var(--ss-border);border-radius:12px;padding:20px;transition:all .18s}.ss-template-card:hover{background:#ffffff0d;border-color:#0ea5e94d;transform:translateY(-1px)}.ss-template-card--inactive{opacity:.55}.ss-template-card--add{align-items:center;border-color:#ffffff26;border-style:dashed;color:var(--ss-text-4);cursor:pointer;display:flex;flex-direction:column;gap:8px;justify-content:center;min-height:180px}.ss-template-card--add:hover{background:var(--ss-blue-dim);border-color:var(--ss-blue);color:var(--ss-blue)}.ss-tc-add-icon{font-size:28px;opacity:.6}.ss-tc-add-label{font-size:13px;font-weight:500}.ss-tc-header{align-items:flex-start;display:flex;gap:8px;justify-content:space-between;margin-bottom:10px}.ss-tc-name{color:var(--ss-text-1);font-size:15px;font-weight:600;margin-bottom:3px}.ss-tc-dept{background:var(--ss-bg-2);border-radius:100px;color:var(--ss-text-4);display:inline-block;font-size:11px;padding:2px 8px}.ss-tc-actions{display:flex;flex-shrink:0;gap:4px}.ss-tc-desc{color:var(--ss-text-3);font-size:12px;line-height:1.5;margin:0 0 12px}.ss-tc-range{align-items:center;background:var(--ss-bg-2);border-radius:7px;display:flex;justify-content:space-between;margin-bottom:12px;padding:8px 12px}.ss-tc-range-label{color:var(--ss-text-4);font-size:11px;letter-spacing:.5px;text-transform:uppercase}.ss-tc-range-value{color:var(--ss-blue);font-size:13px;font-weight:600}.ss-tc-metrics{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr 1fr;margin-bottom:12px}.ss-tc-metric{background:var(--ss-bg-2);border-radius:7px;display:flex;flex-direction:column;gap:2px;padding:8px}.ss-tc-metric span{color:var(--ss-text-4);font-size:10px;text-transform:uppercase}.ss-tc-metric strong{color:var(--ss-text-1);font-size:13px}.ss-tc-footer{align-items:center;display:flex;justify-content:space-between}.ss-tc-components{color:var(--ss-text-4);font-size:11px}.ss-badge{border-radius:100px;font-size:11px;font-weight:500;padding:3px 8px}.ss-badge-active,.ss-badge-approved{background:#4ade8026;color:#4ade80}.ss-badge-inactive,.ss-badge-rejected{background:#f8717126;color:var(--ss-red)}.ss-badge-pending{background:#fbbf2426;color:var(--ss-amber)}.ss-badge-revised{background:#0ea5e926;color:var(--ss-blue)}.ss-badge-new{background:#a78bfa26;color:var(--ss-purple)}.ss-badge-worker{background:#fb923c26;color:#fb923c}.ss-badge-staff{background:#6366f126;color:#818cf8}.ss-field-hint{color:var(--text-secondary);display:block;font-size:11px;margin-top:4px}.ss-ctc-banner{align-items:center;background:var(--ss-bg-2);border:1px solid var(--ss-border);border-radius:10px;display:flex;gap:0;margin-bottom:24px;overflow-x:auto;padding:16px 24px}.ss-ctc-banner-item{display:flex;flex-direction:column;gap:3px;padding:0 20px}.ss-ctc-banner-item:first-child{padding-left:0}.ss-ctc-banner-item span{color:var(--ss-text-4);font-size:11px;letter-spacing:.5px;text-transform:uppercase}.ss-ctc-banner-item strong{color:var(--ss-text-1);font-size:15px;font-weight:600}.ss-ctc-banner-sep{background:var(--ss-border);flex-shrink:0;height:36px;width:1px}.ss-comp-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:1200px){.ss-comp-grid{grid-template-columns:1fr}}@media (max-width:768px){.ss-root{padding:12px!important}.ss-page-hdr{margin-bottom:16px;padding-bottom:14px}.ss-content-hdr,.ss-page-hdr{align-items:flex-start;flex-direction:column;gap:8px}.ss-hdr-actions{flex-wrap:wrap;width:100%}.ss-table-wrap,.ss-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.ss-tabs{flex-wrap:nowrap}.ss-form-row{grid-template-columns:1fr}.ss-tc-metrics{grid-template-columns:1fr 1fr}.ss-modal-hdr{flex-wrap:wrap;gap:8px;padding:14px 16px}}@media (max-width:480px){.ss-page-title{font-size:18px}.ss-content-title{font-size:14px}.ss-tc-metrics{grid-template-columns:1fr}.ss-comp-table td,.ss-comp-table th{padding:6px}}.ss-comp-section{background:var(--ss-bg-card);border:1px solid var(--ss-border);border-radius:10px;padding:16px 20px}.ss-comp-section-title{border-radius:6px;display:inline-block;font-size:12px;font-weight:700;letter-spacing:.7px;margin-bottom:14px;padding:6px 10px;text-transform:uppercase}.ss-earn-title{background:#4ade801a;color:var(--ss-green)}.ss-ded-title{background:#f871711a;color:var(--ss-red)}.ss-empr-title{background:#fbbf241a;color:var(--ss-amber)}.ss-comp-table{border-collapse:collapse;font-size:12px;width:100%}.ss-comp-table th{border-bottom:1px solid var(--ss-border);color:var(--ss-text-4);font-size:10px;letter-spacing:.5px;padding:6px 8px;text-align:left;text-transform:uppercase}.ss-comp-table td{border-bottom:1px solid #ffffff08;color:var(--ss-text-2);padding:8px;vertical-align:middle}.ss-comp-table tr:hover td{background:#ffffff05}.ss-comp-name{color:var(--ss-text-1);font-size:12px;font-weight:500}.ss-comp-payslip{color:var(--ss-text-4);font-size:10px;margin-top:1px}.ss-td-value{font-feature-settings:"tnum";color:var(--ss-text-1);font-variant-numeric:tabular-nums;font-weight:500}.ss-td-red{color:var(--ss-red)!important}.ss-subtotal-row td{background:#ffffff08;border-top:1px solid var(--ss-border)}.ss-net-row td strong{font-size:14px}.ss-bool-chip{border-radius:100px;font-size:10px;padding:2px 7px}.ss-chip-yes{background:#4ade801f;color:var(--ss-green)}.ss-chip-no{background:#ffffff0d;color:var(--ss-text-4)}.ss-ctc-breakup{display:flex;flex-direction:column;gap:10px}.ss-ctc-row{align-items:center;display:flex;gap:8px}.ss-ctc-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.ss-ctc-row-label{color:var(--ss-text-2);flex-shrink:0;font-size:12px;width:140px}.ss-ctc-bar-wrap{background:#ffffff0f;border-radius:100px;flex:1 1;height:6px;overflow:hidden}.ss-ctc-bar{border-radius:100px;height:100%;transition:width .4s ease}.ss-ctc-row-pct{color:var(--ss-text-4);font-size:11px;text-align:right;width:34px}.ss-ctc-row-val{font-feature-settings:"tnum";color:var(--ss-text-1);font-size:12px;font-variant-numeric:tabular-nums;font-weight:500;text-align:right;width:80px}.ss-ctc-total-row{align-items:center;border-top:1px solid var(--ss-border);color:var(--ss-text-3);display:flex;font-size:13px;justify-content:space-between;margin-top:4px;padding:10px 0 0}.ss-ctc-total-row strong{font-size:15px}.ss-table-wrap{background:var(--ss-bg-card);border:1px solid var(--ss-border);border-radius:10px;overflow:hidden}.ss-table{border-collapse:collapse;width:100%}.ss-table thead tr{background:#ffffff08}.ss-table th{border-bottom:1px solid var(--ss-border);color:var(--ss-text-4);font-size:11px;font-weight:600;letter-spacing:.5px;padding:12px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.ss-table td{border-bottom:1px solid #ffffff08;color:var(--ss-text-2);font-size:13px;padding:13px 14px;vertical-align:middle}.ss-table tr:last-child td{border-bottom:none}.ss-table tr:hover td{background:#ffffff05}.ss-td-dim{color:var(--ss-text-4);font-size:12px}.ss-td-accent{font-feature-settings:"tnum";color:var(--ss-blue);font-variant-numeric:tabular-nums;font-weight:600}.ss-emp-cell{align-items:center;display:flex;gap:10px}.ss-emp-avatar{align-items:center;color:#fff;display:flex;font-size:12px;font-weight:700;justify-content:center}.ss-emp-avatar,.ss-emp-avatar-img{border-radius:50%;flex-shrink:0;height:34px;width:34px}.ss-emp-avatar-img{object-fit:cover}.ss-emp-name{color:var(--ss-text-1);font-size:13px;font-weight:500;margin-bottom:1px}.ss-emp-code{color:var(--ss-text-4);font-size:11px}.ss-template-chip{background:var(--ss-blue-dim);border-radius:100px;color:var(--ss-blue);font-size:11px;font-weight:500;padding:3px 10px;white-space:nowrap}.ss-row-actions{align-items:center;display:flex;gap:4px}.ss-hike-chip{background:#4ade801f;color:var(--ss-green)}.ss-hike-chip,.ss-new-chip{border-radius:100px;font-size:11px;font-weight:600;padding:3px 8px}.ss-new-chip{background:#a78bfa1f;color:var(--ss-purple)}.ss-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#000000a6;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.ss-modal{background:#111827;border:1px solid #ffffff1a;border-radius:14px;display:flex;flex-direction:column;max-height:90vh;max-width:100%;overflow:hidden;width:440px}.ss-modal-hdr{align-items:center;border-bottom:1px solid var(--ss-border);display:flex;justify-content:space-between;padding:18px 22px}.ss-modal-title{color:var(--ss-text-1);font-size:15px;font-weight:600}.ss-modal-close{background:none;border:none;border-radius:4px;color:var(--ss-text-4);cursor:pointer;font-size:16px;line-height:1;padding:4px}.ss-modal-close:hover{background:var(--ss-bg-card);color:var(--ss-text-1)}.ss-modal-body{display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding:20px 22px}.ss-modal-footer{border-top:1px solid var(--ss-border);display:flex;gap:10px;justify-content:flex-end;padding:16px 22px}.ss-form-field{display:flex;flex-direction:column;gap:5px}.ss-form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.ss-label{color:var(--ss-text-3);font-size:12px;font-weight:500}.ss-input{background:var(--ss-bg-2);border:1px solid var(--ss-border);border-radius:7px;box-sizing:border-box;color:var(--ss-text-1);font-size:13px;outline:none;padding:9px 12px;transition:border .15s;width:100%}.ss-input:focus{border-color:var(--ss-blue)}.ss-input--error{border-color:#ef4444!important}.ss-field-error{color:#ef4444;display:block;font-size:11px;margin-top:2px}.input-error,.v3-inp--error{border-color:#ef4444!important}.input-error{outline-color:#ef4444!important}.ss-textarea{background:var(--ss-bg-2);border:1px solid var(--ss-border);border-radius:7px;box-sizing:border-box;color:var(--ss-text-1);font-family:inherit;font-size:13px;outline:none;padding:9px 12px;resize:vertical;transition:border .15s;width:100%}.ss-textarea:focus{border-color:var(--ss-blue)}.ss-toggle-wrap{align-items:center;color:var(--ss-text-2);cursor:pointer;display:flex;font-size:13px;gap:10px}.ss-toggle{background:#ffffff1a;border-radius:100px;cursor:pointer;height:22px;position:relative;transition:background .2s;width:40px}.ss-toggle--on{background:var(--ss-blue)}.ss-toggle-thumb{background:#fff;border-radius:50%;height:16px;left:3px;position:absolute;top:3px;transition:transform .2s;width:16px}.ss-toggle--on .ss-toggle-thumb{transform:translateX(18px)}.ss-revision-info{align-items:center;background:var(--ss-bg-2);border-radius:7px;color:var(--ss-text-3);display:flex;font-size:13px;justify-content:space-between;padding:10px 14px}.ss-category-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.ss-pill{align-items:center;background:var(--ss-bg-2);border:1px solid #ffffff1a;border-radius:20px;color:var(--ss-text-2);cursor:pointer;display:inline-flex;font-size:12.5px;font-weight:500;gap:6px;padding:6px 14px;transition:all .2s}.ss-pill:hover{border-color:var(--ss-blue);color:var(--ss-text-1)}.ss-pill--active{background:var(--ss-blue);border-color:var(--ss-blue);color:#fff}.ss-pill-count{background:#ffffff1f;border-radius:10px;font-size:11px;font-weight:600;padding:1px 6px}.ss-pill--active .ss-pill-count{background:#ffffff40}.ss-badge-cat-worker{background:#fef3c7;border:1px solid #f59e0b;border-radius:10px;color:#92400e}.ss-badge-cat-staff,.ss-badge-cat-worker{font-size:11px;font-weight:600;padding:2px 8px}.ss-badge-cat-staff{background:#dbeafe;border:1px solid #3b82f6;border-radius:10px;color:#1e40af}.ss-badge-cat-exempted{background:#ede9fe;border:1px solid #8b5cf6;border-radius:10px;color:#5b21b6;font-size:11px;font-weight:600;padding:2px 8px}.ss-category-banner{color:var(--ss-text-1);font-size:13px;line-height:1.5}:root:not([data-theme=dark]) .ss-root,:root:not([data-theme=dark]) .ss-tab-content{--ss-bg:#f8fafc;--ss-bg-2:#f1f5f9;--ss-bg-card:rgba(0,0,0,.025);--ss-border:#e2e8f0;--ss-text-1:#1e293b;--ss-text-2:#334155;--ss-text-3:#64748b;--ss-text-4:#94a3b8;--ss-blue-dim:#0ea5e914;--ss-green-dim:#4ade8014;--ss-amber-dim:#fbbf2414;--ss-red-dim:#f8717114}:root:not([data-theme=dark]) .ss-btn-ghost:hover{background:#0000000a}:root:not([data-theme=dark]) .ss-icon-btn:hover{background:#0000000f}:root:not([data-theme=dark]) .ss-template-card:hover{background:#00000008}:root:not([data-theme=dark]) .ss-template-card--add{border-color:#00000026}:root:not([data-theme=dark]) .ss-comp-table td{border-bottom-color:#0000000d}:root:not([data-theme=dark]) .ss-comp-table tr:hover td{background:#00000005}:root:not([data-theme=dark]) .ss-subtotal-row td{background:#00000008}:root:not([data-theme=dark]) .ss-chip-no{background:#0000000d}:root:not([data-theme=dark]) .ss-ctc-bar-wrap{background:#0000000f}:root:not([data-theme=dark]) .ss-table thead tr{background:#00000005}:root:not([data-theme=dark]) .ss-table td{border-bottom-color:#0000000d}:root:not([data-theme=dark]) .ss-table tr:hover td{background:#00000005}:root:not([data-theme=dark]) .ss-modal{background:#fff;border-color:#0000001f}:root:not([data-theme=dark]) .ss-toggle{background:#0000001a}:root:not([data-theme=dark]) .ss-pill{border-color:#0000001a}:root:not([data-theme=dark]) .ss-pill-count{background:#00000014}.um-pin-icon{color:#00c9a7;color:var(--color-accent,#00c9a7);flex-shrink:0}.v3-page-title{color:var(--text-primary);font-size:var(--text-md);font-weight:700}.v3-page-sep{color:var(--text-tertiary);font-size:var(--text-sm);margin:0 4px}.v3-page-sub{color:var(--text-secondary);font-size:var(--text-sm)}.um-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(3,1fr);padding:18px 0 8px}@media (max-width:1000px){.um-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.um-grid{grid-template-columns:1fr}}.um-card{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:var(--radius-xl);box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s,border-color .2s}.um-card:hover{border-color:#00c9a7;border-color:var(--color-accent,#00c9a7);box-shadow:0 4px 18px #00000017}.um-card-header{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-default,#e2e8f0);gap:8px;justify-content:space-between;padding:14px 16px 10px}.um-card-header,.um-card-title{align-items:center;display:flex}.um-card-title{color:var(--text-primary);font-size:var(--text-sm);font-weight:700;gap:7px;min-width:0}.um-card-title span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.um-card-pin{color:var(--color-red-dark);flex-shrink:0}.um-card-body{display:flex;flex:1 1;flex-direction:column;gap:1px;padding:10px 16px}.um-row{align-items:baseline;background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:var(--radius-lg);display:flex;gap:8px;margin-bottom:5px;padding:7px 10px}.um-row:last-child{margin-bottom:0}.um-lbl{color:#94a3b8;color:var(--text-tertiary,#94a3b8);flex-shrink:0;font-size:var(--text-sm);min-width:58px}.um-val{color:#64748b;color:var(--text-secondary,#64748b);flex:1 1;font-size:var(--text-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.um-val-bold{color:var(--text-primary);font-weight:700}.um-val-accent{color:#00c9a7;color:var(--color-accent,#00c9a7);font-weight:700}.um-card-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-default,#e2e8f0);display:flex;gap:8px;padding:10px 16px 14px}.um-act-btn{align-items:center;background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:600;gap:5px;padding:5px 12px;transition:all .15s}.um-act-btn:hover{background:#00c9a7;background:var(--color-accent,#00c9a7);border-color:#00c9a7;border-color:var(--color-accent,#00c9a7);color:var(--text-primary)}.um-act-del:hover{background:var(--color-red-50);border-color:var(--color-red-light);color:var(--color-red-dark)}.um-empty,.um-loading{color:var(--text-tertiary);font-size:var(--text-sm);padding:48px 24px;text-align:center}.cs-root{color:#1e293b;color:var(--text-primary,#1e293b);font-family:inherit;margin:0 auto;max-width:1100px;padding:24px;position:relative}.cs-upload-overlay{align-items:center;background:#ffffffbf;border-radius:inherit;display:flex;inset:0;justify-content:center;position:absolute;z-index:2}.cs-toast{animation:cs-fadein .2s ease;border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;letter-spacing:.01em;padding:10px 18px;pointer-events:none;position:fixed;right:22px;top:18px;z-index:9999}.cs-toast.success{background:var(--color-success);color:var(--text-inverse)}.cs-toast.error{background:var(--color-red);color:var(--text-inverse)}@keyframes cs-fadein{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.cs-loading{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-base);height:240px}.cs-loading,.cs-no-access{align-items:center;display:flex;justify-content:center}.cs-no-access{flex-direction:column;gap:10px;height:320px}.cs-no-access-icon{font-size:40px}.cs-no-access-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-lg);font-weight:600}.cs-no-access-sub{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm)}.cs-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:20px}.cs-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.01em}.cs-subtitle{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-xs);letter-spacing:.03em;margin-top:4px}.cs-header-actions{display:flex;flex-shrink:0;gap:8px}.cs-btn{align-items:center;border:1px solid #0000;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:500;gap:5px;padding:7px 14px;transition:opacity .15s,background .15s}.cs-btn:disabled{cursor:not-allowed;opacity:.5}.cs-btn.primary{background:#6366f1;background:var(--primary-color,#6366f1);color:var(--text-inverse)}.cs-btn.primary:hover:not(:disabled){opacity:.88}.cs-btn.danger{background:#0000;border-color:#e2e8f0;border-color:var(--border-color,#e2e8f0);color:#64748b;color:var(--text-secondary,#64748b)}.cs-btn.danger:hover:not(:disabled){background:#fef2f2;border-color:#fca5a5;color:var(--color-red)}.cs-btn.accent{background:#6366f1;background:var(--primary-color,#6366f1);color:var(--text-inverse)}.cs-btn.sm{font-size:var(--text-xs);padding:5px 10px}.cs-preview-bar{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);box-shadow:0 1px 4px #0000000a;gap:16px;margin-bottom:18px;padding:14px 18px}.cs-preview-bar,.cs-preview-logo{align-items:center;border-radius:var(--radius-xl);display:flex}.cs-preview-logo{border:1.5px solid;cursor:pointer;flex-shrink:0;font-size:var(--text-2xl);font-weight:700;height:56px;justify-content:center;overflow:hidden;width:56px}.cs-preview-logo img{height:100%;object-fit:cover;width:100%}.cs-preview-info{flex:1 1;min-width:0}.cs-preview-name{font-size:var(--text-md);font-weight:700;line-height:1.2}.cs-preview-tagline{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);margin-top:2px}.cs-preview-address{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-sm);margin-top:4px}.cs-preview-meta{display:flex;flex-direction:column;gap:3px;text-align:right}.cs-preview-gstin{color:#64748b;color:var(--text-secondary,#64748b);font-family:var(--font-mono);font-size:var(--text-sm)}.cs-preview-email,.cs-preview-phone{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-sm)}.cs-tabs{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);display:flex;gap:4px;margin-bottom:22px;overflow-x:auto}.cs-tab{background:#0000;border:none;border-bottom:2px solid #0000;border-radius:var(--radius-md) var(--radius-md) 0 0;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;font-size:var(--text-sm);font-weight:500;padding:9px 16px;transition:color .15s,background .15s;white-space:nowrap}.cs-tab:hover:not(.active){background:#f1f5f9;background:var(--hover-bg,#f1f5f9);color:#1e293b;color:var(--text-primary,#1e293b)}.cs-tab.active{font-weight:600}.cs-card{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);margin-bottom:16px;padding:18px 20px}.cs-card .ss-searchable.cs-input{background:#0000;border:none;padding:0}.cs-card .ss-searchable.cs-input .ss-searchable__trigger{background:#fff;background:var(--card-bg,#fff);border-color:#e2e8f0;border-color:var(--border-color,#e2e8f0);border-radius:var(--radius-lg);padding:8px 10px}.cs-card-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);font-weight:600;letter-spacing:.01em;margin-bottom:16px}.cs-tab-grid-2{grid-gap:18px;align-items:start;display:grid;gap:18px;grid-template-columns:1fr 1fr}.cs-col{display:flex;flex-direction:column;gap:0}.cs-grid-2{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.cs-field-group{margin-bottom:14px}.cs-field-group:last-child{margin-bottom:0}.cs-label{color:#64748b;color:var(--text-secondary,#64748b);display:block;font-weight:600;letter-spacing:.06em;margin-bottom:5px;text-transform:uppercase}.cs-hint,.cs-label{font-size:var(--text-sm)}.cs-hint{color:#94a3b8;color:var(--text-tertiary,#94a3b8);margin-top:4px}.cs-input{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);box-sizing:border-box;color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);outline:none;padding:8px 10px;transition:border-color .15s;width:100%}.cs-input:focus{border-color:#6366f1;border-color:var(--primary-color,#6366f1);box-shadow:0 0 0 3px #6366f11a}.cs-input.readonly{background:#f1f5f9;background:var(--hover-bg,#f1f5f9);color:#64748b;color:var(--text-secondary,#64748b);cursor:not-allowed}.cs-input.mono{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.04em}.cs-logo-upload-row{align-items:flex-start;display:flex;gap:16px}.cs-logo-box{align-items:center;border:1.5px dashed;border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;height:96px;justify-content:center;overflow:hidden;transition:opacity .15s;width:96px}.cs-logo-box:hover{opacity:.8}.cs-logo-box img{height:100%;object-fit:cover;width:100%}.cs-logo-initial{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-3xl);font-weight:700}.cs-logo-hint{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-2xs);margin-top:4px}.cs-logo-controls{display:flex;flex-direction:column;gap:8px;padding-top:4px}.cs-logo-spec{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs);line-height:1.5}.cs-signature-box{align-items:center;border:1.5px dashed;border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-shrink:0;height:72px;justify-content:center;overflow:hidden;transition:opacity .15s;width:160px}.cs-signature-box:hover{opacity:.8}.cs-address-preview{align-items:flex-start;background:#f1f5f9;background:var(--hover-bg,#f1f5f9);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);display:flex;gap:10px;margin-top:16px;padding:12px 14px}.cs-address-pin{flex-shrink:0;font-size:var(--text-lg);line-height:1}.cs-address-line1{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);font-weight:500;line-height:1.4}.cs-address-line2{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-xs);margin-top:3px}.cs-branding-layout{gap:18px}.cs-branding-layout,.cs-hbg-card{display:flex;flex-direction:column}.cs-hbg-card{gap:0}.cs-hbg-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:18px}.cs-hbg-reset-btn{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:600;padding:5px 12px;transition:all .15s}.cs-hbg-reset-btn:hover{background:var(--surface-tertiary);color:var(--text-primary)}.cs-hbg-body{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 1fr}.cs-hbg-presets{display:flex;flex-wrap:wrap;gap:8px}.cs-hbg-swatch{align-items:center;border:2px solid #0000;border-radius:var(--radius-md);box-shadow:0 1px 4px #0000001a;cursor:pointer;display:flex;flex-direction:column;gap:2px;height:34px;justify-content:center;outline:none;padding:0;position:relative;transition:transform .15s,border-color .15s,box-shadow .15s;width:52px}.cs-hbg-swatch:hover:not(:disabled){box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.cs-hbg-swatch.active{border-color:#00e5c0;border-color:var(--color-primary,#00e5c0);box-shadow:0 0 0 3px #00e5c040}.cs-hbg-swatch:disabled{cursor:default}.cs-hbg-swatch-label{font-family:var(--font-sans);font-size:9px;font-weight:600;line-height:1;text-shadow:0 1px 2px #00000026}.cs-hbg-swatch-check{font-size:11px;font-weight:700;line-height:1}.cs-hbg-preview,.cs-hbg-toolbar-preview{display:flex;flex-direction:column}.cs-hbg-toolbar-preview{border-radius:var(--radius-xl);justify-content:center;min-height:90px;padding:12px 16px;transition:background .2s}.cs-hbg-mock-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.cs-hbg-mock-chip{border-radius:20px;font-family:var(--font-sans);font-size:11px;font-weight:600;padding:4px 10px;transition:background .2s,color .2s;white-space:nowrap}.cs-hbg-mock-icon{align-items:center;border-radius:50%;display:flex;font-size:13px;height:28px;justify-content:center;transition:background .2s,color .2s;width:28px}.cs-hbg-contrast-badge{border-radius:20px;font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.04em;margin-top:10px;padding:3px 10px;text-transform:uppercase;transition:background .2s,color .2s;width:fit-content}@media (max-width:700px){.cs-hbg-body{grid-template-columns:1fr}}.cs-presets{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.cs-preset-swatch{border-radius:50%;cursor:pointer;height:28px;outline:none;padding:0;transition:transform .15s,box-shadow .15s;width:28px}.cs-preset-swatch:hover{transform:scale(1.15)}.cs-color-row{align-items:center;display:flex;gap:10px}.cs-color-swatch{border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);cursor:pointer;flex-shrink:0;height:38px;padding:0;width:38px}.cs-color-preview-box{border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);margin-top:16px;overflow:hidden}.cs-color-preview-header{border-bottom:1px solid;padding:10px 14px 8px}.cs-color-samples{background:#fff;background:var(--card-bg,#fff);display:flex;flex-wrap:wrap;gap:8px;padding:12px 14px}.cs-color-sample{border-radius:20px;font-size:var(--text-sm);font-weight:500;padding:5px 12px}.cs-sidebar-preview{background:var(--color-gray-900);border-radius:var(--radius-xl);font-size:var(--text-xs);margin-top:16px;padding:14px}.cs-sidebar-preview-header{align-items:center;display:flex;gap:10px;margin-bottom:12px}.cs-sidebar-preview-logo{align-items:center;background:#ffffff14;border:1px solid;border-radius:var(--radius-lg);color:var(--text-inverse);display:flex;flex-shrink:0;font-size:var(--text-base);font-weight:700;height:36px;justify-content:center;overflow:hidden;width:36px}.cs-sidebar-preview-logo img{height:100%;object-fit:cover;width:100%}.cs-sidebar-preview-company{color:var(--text-inverse);font-size:var(--text-sm);font-weight:600}.cs-sidebar-preview-app{font-size:var(--text-2xs);font-weight:500;letter-spacing:.04em}.cs-sidebar-location{align-items:center;border:1px solid;border-radius:var(--radius-lg);display:flex;font-size:var(--text-sm);font-weight:500;gap:6px;padding:6px 10px;width:fit-content}.cs-sidebar-location-preview{background:var(--color-gray-900);border-radius:var(--radius-xl);margin-top:8px;padding:12px 14px}.cs-footer-section{margin-bottom:18px}.cs-footer-section:last-child{margin-bottom:0}.cs-footer-preview{border-radius:var(--radius-lg);font-size:var(--text-sm);overflow:hidden}.cs-footer-preview.app-footer{align-items:center;background:var(--color-gray-900);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:10px 14px}.cs-footer-brand{align-items:center;display:flex;font-size:var(--text-xs);font-weight:600;gap:6px}.cs-footer-logo{border-radius:var(--radius-sm);height:18px;object-fit:cover;width:18px}.cs-footer-text{color:#ffffff73;flex:1 1;text-align:center}.cs-footer-copy{color:#ffffff4d;white-space:nowrap}.cs-footer-preview.print-footer{background:var(--surface-primary);border:1px dashed #e2e8f0;border:1px dashed var(--border-color,#e2e8f0);padding:12px 14px;text-align:center}.cs-print-name{font-size:var(--text-sm);font-weight:600;letter-spacing:.02em;margin-bottom:4px}.cs-print-address{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);margin-bottom:3px}.cs-print-footer{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs)}.cs-sticky-footer{align-items:center;background:#fff;background:var(--card-bg,#fff);border-radius:0 0 var(--radius-xl) var(--radius-xl);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color,#e2e8f0);bottom:0;box-shadow:0 -4px 16px #0000000f;display:flex;gap:10px;justify-content:flex-end;left:0;margin-top:28px;padding:12px 24px;position:sticky;right:0;z-index:100}.cs-unsaved-label{align-items:center;color:#64748b;color:var(--text-secondary,#64748b);display:flex;font-size:var(--text-xs);gap:6px;margin-right:auto}.cs-pulse{animation:cs-pulse 1.4s infinite;color:var(--color-orange);font-size:var(--text-lg);line-height:1}@keyframes cs-pulse{0%,to{opacity:1}50%{opacity:.3}}@media (max-width:820px){.cs-root{padding:14px}.cs-grid-2,.cs-tab-grid-2{grid-template-columns:1fr}.cs-preview-bar{flex-wrap:wrap}.cs-preview-meta{text-align:left}}@media (max-width:480px){.cs-root{padding:8px}.cs-header{align-items:flex-start;flex-direction:column;gap:8px}.cs-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.cs-card{padding:12px}.cs-cp-summary-grid{grid-template-columns:1fr}.cs-ui-size-row{flex-wrap:wrap}.cs-toggle-row{flex-direction:column;gap:8px}}.cs-cp-root{display:flex;flex-direction:column;gap:20px}.cs-toggle-row{align-items:flex-start;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-color,#f1f5f9);display:flex;gap:12px;justify-content:space-between;padding:10px 0}.cs-toggle-row:last-child{border-bottom:none}.cs-toggle-label{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);font-weight:500;line-height:1.4}.cs-toggle-btn{align-items:center;background:#cbd5e1;background:var(--border-color,#cbd5e1);border:none;border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-shrink:0;height:22px;padding:0 3px;position:relative;transition:background .2s;width:40px}.cs-toggle-btn.on{background:#00e5c0;background:var(--accent-color,#00e5c0)}.cs-toggle-btn:disabled{cursor:default;opacity:.5}.cs-toggle-knob{background:var(--surface-primary);border-radius:50%;box-shadow:0 1px 3px #0003;display:block;height:16px;transform:translateX(0);transition:transform .2s;width:16px}.cs-toggle-btn.on .cs-toggle-knob{transform:translateX(18px)}.cs-cp-reminder-box{background:#00e5c012;background:rgba(var(--accent-rgb,0 229 192)/.07);border:1px solid #00e5c040;border:1px solid rgba(var(--accent-rgb,0 229 192)/.25);border-radius:var(--radius-lg);margin-top:12px;padding:14px}.cs-cp-summary{margin-top:4px}.cs-cp-summary-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}.cs-cp-sum-item{align-items:center;background:#f8fafc;background:var(--sidebar-bg,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-md);display:flex;font-size:var(--text-xs);gap:8px;justify-content:space-between;padding:8px 10px}.cs-cp-sum-item span{color:#64748b;color:var(--text-secondary,#64748b);white-space:nowrap}.cs-cp-sum-item strong{color:#1e293b;color:var(--text-primary,#1e293b);font-weight:600;text-align:right}.cs-ui-size-row{display:flex;flex-wrap:wrap;gap:6px}.cs-ui-size-btn{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-md);color:#1e293b;color:var(--text-primary,#1e293b);cursor:pointer;font-size:var(--text-xs);font-weight:500;padding:6px 16px;transition:all .15s}.cs-ui-size-btn:hover:not(:disabled){border-color:#00e5c0;border-color:var(--ui-primary,#00e5c0)}.cs-ui-size-btn.active{border-color:#0000;font-weight:600}.cs-ui-size-btn:disabled{cursor:default;opacity:.5}.cs-ui-color-row{align-items:center;display:flex;gap:8px}.cs-ui-color-picker{background:none;border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-md);cursor:pointer;height:32px;padding:2px;width:36px}.cs-ui-color-picker::-webkit-color-swatch-wrapper{padding:0}.cs-ui-color-picker::-webkit-color-swatch{border:none;border-radius:var(--radius-sm)}.cs-ui-color-swatch{border:1px solid #0000001a;border-radius:var(--radius-md);flex-shrink:0;height:32px;width:32px}.cs-ui-color-preview{border-radius:var(--radius-lg);display:flex;gap:4px;margin-top:14px;overflow:hidden}.cs-ui-color-preview>div{flex:1 1;font-size:var(--text-sm);font-weight:600;letter-spacing:.03em;padding:10px 8px;text-align:center}.cs-ui-font-preview{background:#f8fafc;background:var(--sidebar-bg,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);color:#1e293b;color:var(--text-primary,#1e293b);line-height:1.6;margin-top:14px;padding:14px}.sidebar{--sb-accent:var(--color-teal);--sb-accent-dim:var(--color-teal-50);background:var(--surface-primary);border-right:1px solid var(--border-default);box-shadow:2px 0 12px #0000000a;display:flex;flex-direction:column;height:100vh;left:0;overflow:visible;position:fixed;top:0;transition:width .25s ease;width:var(--sidebar-width-expanded);z-index:var(--z-modal)}.sidebar.mini{overflow:visible;width:var(--sidebar-width-collapsed)}.sb-top{border-bottom:1px solid var(--border-default);flex-shrink:0;padding:12px 10px}.sb-brand{align-items:center;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:9px;margin-bottom:9px;padding:2px;transition:background .15s}.sb-brand:hover{background:var(--surface-tertiary)}.sb-logo{align-items:center;background:linear-gradient(135deg,var(--sb-accent),var(--color-primary));color:var(--text-primary);display:flex;font-size:var(--text-md);font-weight:800;justify-content:center}.sb-logo,.sb-logo-img{border-radius:var(--radius-lg);box-shadow:0 0 14px #00d4aa40;flex-shrink:0;height:36px;width:36px}.sb-logo-img{background:var(--surface-primary);border:1px solid var(--border-default);object-fit:contain;padding:2px}.sb-info{overflow:hidden;white-space:nowrap}.sb-name{color:var(--text-primary);font-weight:700}.sb-name,.sb-ver{font-size:var(--text-sm)}.sb-ver{align-items:center;color:var(--sb-accent);display:flex;flex-wrap:wrap;font-weight:600;gap:5px}.sb-live-badge{align-items:center;background:#dc2626;border-radius:999px;color:#fff;display:inline-flex;font-size:9px;font-weight:700;gap:3px;letter-spacing:.08em;line-height:1;padding:1px 5px 1px 3px;-webkit-user-select:none;user-select:none}.sb-live-dot{animation:sb-live-pulse 1.4s ease-in-out infinite;background:#fff;border-radius:50%;flex-shrink:0;height:5px;width:5px}@keyframes sb-live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}.sb-chip{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--text-sm);gap:7px;margin-bottom:4px;overflow:visible;padding:5px 9px;transition:border-color .2s;white-space:nowrap}.sb-chip:hover{border-color:#00d4aa40}.sb-dot{background:var(--sb-accent);border-radius:50%;flex-shrink:0;height:7px;width:7px}.sb-cal{align-items:center;display:flex;flex-shrink:0;font-size:var(--text-sm)}.sb-chip-lbl{overflow:hidden;text-overflow:ellipsis}.sidebar.mini .sb-bdg,.sidebar.mini .sb-chip-lbl,.sidebar.mini .sb-info,.sidebar.mini .sb-lbl{display:none}.sidebar.mini .sb-foot,.sidebar.mini .sb-top{overflow:visible}.sidebar.mini .sb-chip{justify-content:center;padding:7px}.sb-tooltip{animation:sb-tt-in .12s ease;background:var(--color-gray-800);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;color:var(--text-inverse);font-size:var(--text-sm);font-weight:600;padding:5px 10px;pointer-events:none;position:fixed;transform:translateY(-50%);white-space:nowrap;z-index:99999}.sb-tooltip:before{border:5px solid #0000;border-right:5px solid var(--color-gray-800);content:"";left:-4px;position:absolute;top:50%;transform:translateY(-50%)}@keyframes sb-tt-in{0%{opacity:0;transform:translateY(-50%) translateX(-4px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}.sb-nav{flex:1 1;overflow-x:visible;overflow-y:auto;padding:6px 7px}.sb-nav::-webkit-scrollbar{width:3px}.sb-nav::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-sm)}.sb-sec{color:var(--text-tertiary);font-size:var(--text-2xs);font-weight:700;letter-spacing:1.3px;overflow:hidden;padding:9px 8px 3px;text-transform:uppercase;white-space:nowrap}.sidebar.mini .sb-sec{height:20px;opacity:0}.sb-item{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:500;gap:9px;margin-bottom:1px;overflow:visible;padding:7px 9px;position:relative;text-align:left;transition:all .15s;white-space:nowrap;width:100%}.sb-item:hover{background:var(--surface-tertiary);border-color:var(--border-default);color:var(--text-primary)}.sb-item.active{background:linear-gradient(90deg,var(--color-teal-50),color-mix(in srgb,var(--color-teal-50) 40%,#0000));border-color:color-mix(in srgb,var(--sb-accent) 18%,#0000);color:var(--sb-accent);font-weight:600}.sb-item.active:before{background:var(--sb-accent);border-radius:0 3px 3px 0;content:"";height:17px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:3px}.sb-icon{align-items:center;display:flex;flex-shrink:0;font-size:var(--text-base);justify-content:center;width:17px}.sb-lbl{flex:1 1;overflow:hidden;text-overflow:ellipsis}.sb-bdg{background:var(--color-red);border-radius:var(--radius-3xl);color:var(--text-inverse);flex-shrink:0;font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:700;padding:1px 5px}.sb-expandable{margin-bottom:1px}.sb-parent{position:relative}.sb-chevron{align-items:center;color:var(--text-tertiary);display:flex;flex-shrink:0;margin-left:auto;transition:transform .15s}.sb-children{margin-top:1px;padding-left:12px}.sb-child{border-left:2px solid var(--border-default);border-radius:0 var(--radius-lg) var(--radius-lg) 0;font-size:11.5px;margin-left:12px;padding:6px 9px}.sb-child.active,.sb-child:hover{border-left-color:var(--sb-accent)}.sidebar.mini .sb-children{padding-left:0}.sidebar.mini .sb-child{border-left:none;border-radius:var(--radius-lg);margin-left:0}.sidebar.mini .sb-chevron{display:none}.sb-foot{border-top:1px solid var(--border-default);padding:7px 9px}.sb-logout-btn{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:600;gap:10px;padding:9px 12px;transition:background .2s,color .2s,border-color .2s;width:100%}.sb-logout-btn:hover{background:#fee2e2;background:var(--color-red-subtle,#fee2e2);border-color:#dc2626;border-color:var(--color-red,#dc2626);color:#dc2626;color:var(--color-red,#dc2626)}.sidebar.mini .sb-logout-btn .sb-lbl{display:none}.sidebar.mini .sb-logout-btn{justify-content:center;padding:9px}.sb-toggle{align-items:center;background:var(--sb-accent);border:none;border-radius:50%;box-shadow:0 0 10px #00d4aa50;color:var(--text-primary);cursor:pointer;display:flex;font-size:var(--text-2xs);font-weight:700;height:20px;justify-content:center;position:absolute;right:-10px;top:50%;transform:translateY(-50%);transition:all .2s;width:20px;z-index:20}.sb-toggle:hover{background:var(--color-teal-light);transform:translateY(-50%) scale(1.1)}.sidebar-backdrop{display:none}@media (max-width:768px){.sidebar{box-shadow:none;z-index:calc(var(--z-modal) + 1)}.sidebar,.sidebar.mini{transform:translateX(-100%);width:var(--sidebar-width-expanded)}.sidebar.mini.mobile-open,.sidebar.mobile-open{box-shadow:4px 0 24px #0000002e;transform:translateX(0)}.sidebar.mobile-open .sb-bdg,.sidebar.mobile-open .sb-chevron,.sidebar.mobile-open .sb-chip-lbl,.sidebar.mobile-open .sb-info,.sidebar.mobile-open .sb-lbl{display:flex}.sidebar.mobile-open .sb-sec{height:auto;opacity:1}.sidebar.mobile-open .sb-children{padding-left:12px}.sidebar.mobile-open .sb-child{border-left:2px solid var(--border-default);border-radius:0 var(--radius-lg) var(--radius-lg) 0;margin-left:12px}.sidebar.mobile-open .sb-logout-btn .sb-lbl{display:inline}.sidebar.mobile-open .sb-logout-btn{justify-content:flex-start;padding:9px 12px}.sidebar.mobile-open .sb-chip{justify-content:flex-start;padding:5px 9px}.sb-toggle{display:none}.sidebar-backdrop{animation:sb-backdrop-in .2s ease;background:#0006;display:block;inset:0;position:fixed;z-index:var(--z-modal)}@keyframes sb-backdrop-in{0%{opacity:0}to{opacity:1}}}.hm-kpi-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.hm-kpi{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;padding:8px 10px;position:relative;transition:transform .2s ease}.hm-kpi:hover{transform:translateY(-2px)}.hm-kpi-accent{border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;height:2px;left:0;position:absolute;right:0;top:0}.hm-kpi-accent.teal{background:linear-gradient(90deg,var(--color-green),#0000)}.hm-kpi-accent.blue{background:linear-gradient(90deg,var(--color-blue),#0000)}.hm-kpi-accent.amber{background:linear-gradient(90deg,var(--color-orange),#0000)}.hm-kpi-accent.purple{background:linear-gradient(90deg,var(--color-purple),#0000)}.hm-kpi-glow{border-radius:50%;filter:blur(14px);height:60px;opacity:.07;position:absolute;right:-10px;top:-10px;width:60px}.hm-kpi-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:4px}.hm-kpi-icon{align-items:center;border-radius:var(--radius-lg);display:flex;height:28px;justify-content:center;width:28px}.hm-kpi-icon svg{stroke-width:1.75;height:14px;width:14px}.hm-kpi-icon.teal{background:var(--color-green-50);color:var(--color-green)}.hm-kpi-icon.blue{background:var(--color-blue-50);color:var(--color-blue)}.hm-kpi-icon.amber{background:var(--color-orange-50);color:var(--color-orange)}.hm-kpi-icon.purple{background:var(--color-purple-50);color:var(--color-purple)}.hm-kpi-badge{border-radius:var(--radius-3xl);font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:700;padding:2px 8px}.hm-kpi-badge.teal{background:var(--color-green-50);color:var(--color-green)}.hm-kpi-badge.blue{background:var(--color-blue-50);color:var(--color-blue)}.hm-kpi-badge.amber{background:var(--color-orange-50);color:var(--color-orange)}.hm-kpi-badge.purple{background:var(--color-purple-50);color:var(--color-purple)}.hm-kpi-label{color:var(--text-tertiary);font-size:9px;font-weight:700;letter-spacing:.6px;margin-bottom:2px;text-transform:uppercase}.hm-kpi-value{color:var(--text-primary);font-family:var(--font-mono);font-size:20px;font-weight:700;line-height:1}.hm-kpi-sub{color:var(--text-tertiary);font-size:var(--text-sm);margin-top:3px}.hm-kpi-bar{background:var(--border-default);height:3px;margin-top:8px;overflow:hidden}.hm-kpi-bar,.hm-kpi-fill{border-radius:var(--radius-sm)}.hm-kpi-fill{height:100%;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.hm-kpi-fill.teal{background:linear-gradient(90deg,var(--color-green),var(--color-green))}.hm-kpi-fill.blue{background:linear-gradient(90deg,var(--color-blue),var(--color-blue))}.hm-kpi-fill.amber{background:linear-gradient(90deg,var(--color-orange),var(--color-orange))}.hm-kpi-fill.purple{background:linear-gradient(90deg,var(--color-purple),var(--color-purple))}.hm-grid3{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr}.hm-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-2xl);overflow:hidden}.hm-card-header{border-bottom:1px solid var(--border-default);justify-content:space-between;padding:12px 16px}.hm-card-header,.hm-card-title{align-items:center;display:flex}.hm-card-title{color:var(--text-primary);font-size:var(--text-sm);font-weight:600;gap:8px}.hm-card-icon{align-items:center;border-radius:var(--radius-lg);display:flex;height:26px;justify-content:center;width:26px}.hm-card-icon svg{stroke-width:1.75;height:14px;width:14px}.hm-card-body{padding:14px 16px}.hm-card-link{background:none;border:none;color:var(--color-primary);cursor:pointer;font-family:inherit;font-size:var(--text-sm);font-weight:600;padding:0}.hm-card-link:hover{opacity:.7}.hm-wa-top{align-items:center;display:flex;gap:18px;margin-bottom:14px}.hm-wa-donut-wrap{flex-shrink:0;height:100px;position:relative;width:100px}.hm-wa-donut-wrap svg{transform:rotate(-90deg)}.hm-wa-donut-center{align-items:center;display:flex;flex-direction:column;inset:0;justify-content:center;position:absolute}.hm-wa-donut-pct{color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-xl);font-weight:700;line-height:1}.hm-wa-donut-label{color:var(--text-tertiary);font-size:var(--text-2xs);margin-top:1px}.hm-wa-legend{display:flex;flex-direction:column;gap:8px}.hm-wa-legend-item{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--text-xs);gap:6px;white-space:nowrap}.hm-chart-legend{display:flex;gap:12px;margin-bottom:10px}.hm-chart-legend-item{align-items:center;color:var(--text-tertiary);display:flex;font-size:var(--text-2xs);gap:5px}.hm-chart-legend-dot{border-radius:var(--radius-sm);height:8px;width:8px}.hm-bar-wrap{align-items:flex-end;display:flex;gap:6px;height:90px}.hm-bar-col{align-items:center;flex:1 1;gap:3px}.hm-bar-col,.hm-bar-stack{display:flex;flex-direction:column}.hm-bar-stack{flex:1 1;gap:1px;justify-content:flex-end;width:100%}.hm-bar{border-radius:var(--radius-sm) var(--radius-sm) 0 0;min-height:2px;transition:height .7s ease;width:100%}.hm-bar-label{color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--text-2xs)}.hm-bar-group{align-items:flex-end;display:flex;flex:1 1;gap:2px;width:100%}.hm-bar-g{border-radius:3px 3px 0 0;flex:1 1;min-height:2px;transition:height .7s ease}.hm-donut-wrapper{height:90px;margin:0 auto 10px;position:relative;width:90px}.hm-donut-wrapper svg{transform:rotate(-90deg)}.hm-donut-center{align-items:center;display:flex;flex-direction:column;inset:0;justify-content:center;position:absolute}.hm-donut-pct{color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700}.hm-donut-label{color:var(--text-tertiary);font-size:var(--text-2xs)}.hm-dept-list{display:flex;flex-direction:column;gap:6px}.hm-dept-row{align-items:center;display:flex;font-size:var(--text-sm);gap:6px}.hm-dept-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.hm-dept-name{color:var(--text-secondary);flex:1 1}.hm-dept-count{color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--text-sm)}.hm-dept-bar{background:var(--border-default);height:3px;overflow:hidden;width:44px}.hm-dept-bar,.hm-dept-fill{border-radius:var(--radius-sm)}.hm-dept-fill{height:100%;transition:width 1s ease}.hm-feed{display:flex;flex-direction:column;max-height:230px;overflow-y:auto}.hm-feed::-webkit-scrollbar{width:3px}.hm-feed::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:2px}.hm-feed-item{align-items:flex-start;border-bottom:1px solid var(--border-light);display:flex;gap:8px;padding:8px 0}.hm-feed-item:last-child{border-bottom:none}.hm-feed-avatar{align-items:center;border-radius:var(--radius-lg);display:flex;flex-shrink:0;font-size:var(--text-2xs);font-weight:700;height:30px;justify-content:center;width:30px}.hm-feed-body{flex:1 1;min-width:0}.hm-feed-name{color:var(--text-primary);font-size:var(--text-xs);font-weight:600}.hm-feed-action{margin-top:1px}.hm-feed-action,.hm-feed-time{color:var(--text-tertiary);font-size:var(--text-2xs)}.hm-feed-badge,.hm-feed-time{font-family:var(--font-mono)}.hm-feed-badge{border-radius:var(--radius-3xl);flex-shrink:0;font-size:var(--text-2xs);font-weight:700;margin-top:2px;padding:2px 7px}.hm-punch-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.hm-punch-btn{align-items:center;background:#0000;border:1px solid;border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:4px;padding:12px 8px;transition:all .2s ease}.hm-punch-btn:hover:not(:disabled){transform:translateY(-2px)}.hm-punch-btn:disabled{cursor:not-allowed;opacity:.4;transform:none}.hm-punch-btn svg{stroke-width:1.75;height:20px;width:20px}.hm-punch-btn .hm-punch-label{font-size:var(--text-sm);font-weight:700}.hm-punch-btn .hm-punch-time{font-family:var(--font-mono);font-size:var(--text-2xs)}.hm-punch-btn.in{border-color:#10b9814d;color:var(--color-green)}.hm-punch-btn.in:hover:not(:disabled){background:var(--color-green-50)}.hm-punch-btn.out{border-color:#ef44444d;color:var(--color-red)}.hm-punch-btn.out:hover:not(:disabled){background:var(--color-red-50)}.hm-punch-btn.lout{border-color:#f59e0b4d;color:var(--color-orange)}.hm-punch-btn.lout:hover:not(:disabled){background:var(--color-orange-50)}.hm-punch-btn.lin{border-color:#0ea5e94d;color:var(--color-blue)}.hm-punch-btn.lin:hover:not(:disabled){background:var(--color-blue-50)}.hm-punch-btn.otin{border-color:#a855f74d;color:var(--color-purple)}.hm-punch-btn.otin:hover:not(:disabled){background:var(--color-purple-50)}.hm-punch-btn.otout{border-color:#6366f14d;color:var(--color-indigo)}.hm-punch-btn.otout:hover:not(:disabled){background:#6366f114}.hm-punch-status{border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:600;margin-top:10px;padding:8px 12px;text-align:center;transition:all .3s ease}.hm-qa-list{display:flex;flex-direction:column;gap:4px}.hm-qa-item{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;display:flex;font-family:inherit;gap:10px;padding:9px 12px;text-align:left;transition:all .15s ease;width:100%}.hm-qa-item:hover{background:var(--color-primary-50);border-color:var(--color-primary);transform:translateX(3px)}.hm-qa-icon{align-items:center;border-radius:var(--radius-lg);display:flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.hm-qa-icon svg{stroke-width:1.75;height:14px;width:14px}.hm-qa-text{flex:1 1;min-width:0}.hm-qa-name{color:var(--text-primary);font-size:var(--text-xs);font-weight:600}.hm-qa-desc{font-size:var(--text-2xs);margin-top:1px}.hm-qa-arrow,.hm-qa-desc{color:var(--text-tertiary)}.hm-qa-arrow{font-size:var(--text-sm);transition:transform .15s ease}.hm-qa-item:hover .hm-qa-arrow{color:var(--color-primary);transform:translateX(3px)}.hm-leave-list{gap:10px}.hm-leave-list,.hm-leave-row{display:flex;flex-direction:column}.hm-leave-row{gap:3px}.hm-leave-header{align-items:center;display:flex;justify-content:space-between}.hm-leave-name{color:var(--text-secondary);font-size:var(--text-sm);font-weight:600}.hm-leave-count{color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--text-2xs)}.hm-leave-bar{background:var(--border-default);height:4px;overflow:hidden}.hm-leave-bar,.hm-leave-fill{border-radius:var(--radius-sm)}.hm-leave-fill{height:100%;transition:width 1.1s ease}.hm-leave-stats{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr;margin-top:14px}.hm-leave-stat{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;font-size:var(--text-sm);justify-content:space-between;padding:7px 10px}.hm-leave-stat-label{color:var(--text-tertiary)}.hm-leave-stat-value{font-family:var(--font-mono);font-weight:700}@keyframes hm-fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.hm-animated{animation:hm-fadeUp .3s ease both}.hm-animated:nth-child(2){animation-delay:.05s}.hm-animated:nth-child(3){animation-delay:.1s}.hm-animated:nth-child(4){animation-delay:.15s}@media (max-width:1200px){.hm-kpi-row{grid-template-columns:repeat(2,1fr)}.hm-grid3{grid-template-columns:1fr}}@media (max-width:768px){.hm-att-grid,.hm-kpi-row{grid-template-columns:1fr 1fr}}.hm-ms-section-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:11px;font-weight:700;letter-spacing:.5px;margin:8px 0 4px;text-transform:uppercase}.hm-ms-list{display:flex;flex-direction:column;gap:6px}.hm-ms-item{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-default,#f1f5f9);display:flex;gap:10px;padding:6px 0}.hm-ms-item:last-child{border-bottom:none}.hm-ms-avatar{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:32px;justify-content:center;width:32px}.hm-ms-body{flex:1 1;min-width:0}.hm-ms-name{color:#1e293b;color:var(--text-primary,#1e293b);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hm-ms-dept{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:11px}.hm-ms-right{flex-shrink:0;text-align:right}.hm-ms-date{color:#64748b;color:var(--text-secondary,#64748b);font-size:11px;font-weight:600}.hm-ms-val{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:10px}.hm-holiday-list{display:flex;flex-direction:column;gap:6px}.hm-holiday-item{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-default,#f1f5f9);display:flex;gap:12px;padding:8px 0}.hm-holiday-item:last-child{border-bottom:none}.hm-holiday-date-box{align-items:center;background:#ecfdf5;background:var(--color-green-50,#ecfdf5);border-radius:8px;display:flex;flex-direction:column;min-width:44px;padding:4px 8px}.hm-holiday-day{color:#10b981;color:var(--color-green,#10b981);font-size:10px;font-weight:700;text-transform:uppercase}.hm-holiday-date{color:#64748b;color:var(--text-secondary,#64748b);font-size:11px;font-weight:600}.hm-holiday-name{color:#1e293b;color:var(--text-primary,#1e293b);flex:1 1;font-size:12px;font-weight:600}.hm-holiday-badge{background:#e6f7ff;border-radius:6px;color:#1890ff;font-size:10px;font-weight:600;padding:2px 8px;white-space:nowrap}.hm-att-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);padding:4px 0}.hm-att-stat{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-radius:10px;flex-direction:column;gap:4px;padding:12px 8px}.hm-att-stat,.hm-att-stat-icon{align-items:center;display:flex}.hm-att-stat-icon{border-radius:8px;height:32px;justify-content:center;width:32px}.hm-att-stat-val{color:#1e293b;color:var(--text-primary,#1e293b);font-size:18px;font-weight:700}.hm-att-stat-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:10px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.hm-payroll-wrap{display:flex;flex-direction:column;gap:12px}.hm-payroll-status{align-items:center;display:flex;gap:10px}.hm-payroll-badge{border-radius:6px;font-size:11px;font-weight:700;padding:3px 10px;text-transform:uppercase}.hm-payroll-badge.draft{background:#fff7e6;color:#fa8c16}.hm-payroll-badge.processing{background:#e6f7ff;color:#1890ff}.hm-payroll-badge.approved{background:#f6ffed;color:#52c41a}.hm-payroll-badge.paid{background:#f6ffed;color:#10b981}.hm-payroll-badge.cancelled{background:#fff1f0;color:#f5222d}.hm-payroll-period{color:#64748b;color:var(--text-secondary,#64748b);font-size:12px;font-weight:600}.hm-payroll-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.hm-payroll-item{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-radius:8px;padding:10px}.hm-payroll-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:10px;font-weight:600;letter-spacing:.3px;margin-bottom:2px;text-transform:uppercase}.hm-payroll-val{color:#1e293b;color:var(--text-primary,#1e293b);font-size:14px;font-weight:700}.hm-notif-list{display:flex;flex-direction:column;gap:4px;max-height:260px;overflow-y:auto}.hm-notif-item{align-items:flex-start;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-default,#f1f5f9);display:flex;gap:10px;padding:8px 0}.hm-notif-item:last-child{border-bottom:none}.hm-notif-item.unread{background:#eff6ff;background:var(--color-blue-50,#eff6ff);border-radius:6px;padding:8px 6px}.hm-notif-dot{background:#cbd5e1;background:var(--border-default,#cbd5e1);border-radius:50%;flex-shrink:0;height:6px;margin-top:5px;width:6px}.hm-notif-item.unread .hm-notif-dot{background:#3b82f6;background:var(--color-blue,#3b82f6)}.hm-notif-body{flex:1 1;min-width:0}.hm-notif-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:12px;font-weight:600}.hm-notif-msg{font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hm-notif-msg,.hm-notif-time{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.hm-notif-time{font-size:10px;margin-top:2px}@media (max-width:1200px){.hm-kpi-row{grid-template-columns:repeat(2,1fr)}.hm-grid3{grid-template-columns:1fr 1fr}}@media (max-width:768px){.hm-kpi-row{grid-template-columns:1fr 1fr}.hm-grid3,.hm-punch-grid{grid-template-columns:1fr}}@media (max-width:480px){.hm-kpi-row{grid-template-columns:1fr}}.msd-wrap{display:inline-flex;flex:1 1;min-width:0;position:relative}.msd-wrap--disabled{opacity:.55;pointer-events:none}.msd-trigger{align-items:center;background:#fff;background:var(--input-bg,#fff);border:1px solid #ccc;border:1px solid var(--border-color,#ccc);border-radius:6px;border-radius:var(--radius-sm,6px);color:#333;color:var(--text-primary,#333);cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-size:var(--text-sm,13px);gap:6px;justify-content:space-between;line-height:1.45;min-height:32px;outline:none;padding:6px 10px;text-align:left;transition:border-color .2s;width:100%}.msd-trigger:focus,.msd-wrap--open .msd-trigger{border-color:#2563eb;border-color:var(--primary,#2563eb);box-shadow:none}.msd-value{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msd-chevron,.msd-placeholder{color:#999;color:var(--text-tertiary,#999)}.msd-chevron{flex-shrink:0;transition:transform .2s}.msd-chevron--up{transform:rotate(180deg)}.msd-dropdown{animation:msdDropIn .12s ease-out;background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:6px;border-radius:var(--radius-sm,6px);box-shadow:none;left:0;margin-top:4px;min-width:180px;overflow:hidden;position:absolute;right:0;top:100%;z-index:9999}.msd-dropdown--up{bottom:100%;margin-bottom:4px;margin-top:0;top:auto}@keyframes msdDropIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.msd-search-wrap{align-items:center;border-bottom:1px solid #eee;border-bottom:1px solid var(--border-color,#eee);display:flex;padding:6px 8px;position:relative}.msd-search-icon{font-size:12px;left:14px;pointer-events:none;position:absolute}.msd-search{background:#f8f8f8;background:var(--surface-secondary,#f8f8f8);border:1px solid #ddd;border:1px solid var(--border-color,#ddd);border-radius:6px;border-radius:var(--radius-sm,6px);color:#333;color:var(--text-primary,#333);font-family:inherit;font-size:13px;font-size:var(--text-sm,13px);outline:none;padding:5px 24px 5px 28px;width:100%}.msd-search:focus{border-color:#2563eb;border-color:var(--primary,#2563eb)}.msd-search::placeholder{color:#aaa;color:var(--text-tertiary,#aaa)}.msd-clear{background:none;border:none;color:#999;color:var(--text-tertiary,#999);cursor:pointer;font-size:16px;line-height:1;padding:0 2px;position:absolute;right:14px}.msd-clear:hover{color:#333;color:var(--text-primary,#333)}.msd-list{max-height:220px;overflow-y:auto;padding:4px 0}.msd-list::-webkit-scrollbar{width:5px}.msd-list::-webkit-scrollbar-thumb{background:#ccc;background:var(--border-color,#ccc);border-radius:3px}.msd-item{align-items:center;color:#333;color:var(--text-primary,#333);cursor:pointer;display:flex;font-size:13px;font-size:var(--text-sm,13px);gap:8px;line-height:1.4;padding:6px 12px;transition:background .1s;-webkit-user-select:none;user-select:none}.msd-item--highlighted{background:#f0f4ff;background:var(--surface-secondary,#f0f4ff)}.msd-item--selected{color:#2563eb;color:var(--primary,#2563eb);font-weight:600}.msd-item:active{background:#2563eb1a}.msd-checkbox{accent-color:#2563eb;accent-color:var(--primary,#2563eb);cursor:pointer;flex-shrink:0;height:15px;margin:0;width:15px}.msd-item-label{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msd-empty{color:#999;color:var(--text-tertiary,#999);font-size:13px;font-size:var(--text-sm,13px);padding:16px 12px;text-align:center}.msd-wrap.filter-select{appearance:none;-webkit-appearance:unset;background:#0000;background-image:none;height:auto;padding:0}.msd-wrap.filter-select,.msd-wrap.filter-select:focus,.msd-wrap.filter-select:hover{border:none;box-shadow:none}.msd-wrap.filter-select .msd-trigger{background:#fff;background:var(--surface-primary,#fff);border:1px solid #ccc;border:1px solid var(--border-default,#ccc);border-radius:6px;border-radius:var(--radius-md,6px);font-size:13px;font-size:var(--text-sm,13px);height:36px}.msd-wrap.filter-select .msd-trigger:focus,.msd-wrap.filter-select.msd-wrap--open .msd-trigger{border-color:#2563eb;border-color:var(--color-primary,#2563eb);box-shadow:none}.msd-wrap.filter-select .msd-trigger:hover:not(:focus){border-color:#94a3b8;border-color:var(--border-strong,#94a3b8)}.msd-wrap.v3-inp .msd-trigger{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);color:var(--text-primary);font-size:var(--text-sm);padding:var(--space-2) var(--space-3)}.msd-wrap.v3-inp .msd-trigger:focus,.msd-wrap.v3-inp.msd-wrap--open .msd-trigger{border-color:var(--color-teal);box-shadow:none}.sap-view{display:flex;flex-direction:column;gap:4px}.sap-view-row{align-items:baseline;display:flex;font-size:13px;gap:8px}.sap-view-lbl{color:#6b7280;font-size:12px;min-width:110px}.sap-view-val{color:#111827;font-weight:500}.sap-view-val--hi{color:#4f46e5;font-weight:700}.sap-root{display:flex;flex-direction:column;gap:0}.sap-ctc-wrap{align-items:center;display:flex;flex:1 1;gap:6px;min-width:0}.sap-ctc-prefix{color:#6b7280;flex-shrink:0;font-size:15px;font-weight:600}.sap-ctc-input{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#111827;flex:1 1;font-size:14px;min-width:0;padding:7px 10px;transition:border-color .15s}.sap-ctc-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f;outline:none}.sap-ctc-badge{background:#eef2ff;border-radius:12px;color:#6366f1;flex-shrink:0;font-size:12px;font-weight:600;padding:3px 8px;white-space:nowrap}.sap-statutory-row{align-items:center;display:flex;flex-wrap:wrap;gap:20px;padding:2px 0}.sap-chk-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:13px;gap:6px;-webkit-user-select:none;user-select:none}.sap-chk-label input[type=checkbox]{accent-color:#6366f1;cursor:pointer;height:15px;width:15px}.sap-chk-badge{border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.5px;padding:2px 6px}.sap-chk-badge--pf{background:#dbeafe;color:#1d4ed8}.sap-chk-badge--esi{background:#dcfce7;color:#15803d}.sap-chk-badge--pt{background:#fef3c7;color:#92400e}.sap-hint-bar{align-items:center;background:#fefce8;border:1px solid #fde68a;border-radius:6px;color:#92400e;display:flex;font-size:12.5px;gap:8px;margin:4px 0 2px;padding:7px 12px}.sap-hint-bar svg{color:#d97706;flex-shrink:0}.sap-hint-apply{background:#d97706;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11.5px;font-weight:600;margin-left:auto;padding:3px 10px;transition:background .15s;white-space:nowrap}.sap-hint-apply:hover{background:#b45309}.sap-breakdown{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;margin:8px 0 4px;overflow:hidden}.sap-breakdown-title{align-items:center;background:#f3f4f6;border-bottom:1px solid #e5e7eb;color:#374151;display:flex;font-size:12.5px;font-weight:600;gap:6px;padding:9px 14px 8px}.sap-breakdown-title svg{color:#6366f1}.sap-tmpl-chip{background:#eef2ff;border-radius:10px;color:#4f46e5;font-size:11px;font-weight:600;margin-left:auto;padding:2px 8px}.sap-group{border-bottom:1px solid #e5e7eb}.sap-group-hdr{display:flex;font-size:11px;font-weight:700;justify-content:space-between;letter-spacing:.6px;padding:6px 14px 5px;text-transform:uppercase}.sap-group-hdr--earn{background:#f0fdf4;color:#047857}.sap-group-hdr--deduct{background:#fef2f2;color:#b91c1c}.sap-row{grid-gap:4px;border-bottom:1px dashed #f3f4f6;display:grid;font-size:13px;gap:4px;grid-template-columns:1fr 80px 90px;padding:5px 14px;transition:background .1s}.sap-row:last-child{border-bottom:none}.sap-row:hover{background:#f0f9ff}.sap-row--deduct:hover{background:#fff5f5}.sap-row-name{color:#374151;font-weight:500}.sap-row-mo{font-feature-settings:"tnum";color:#111827;font-variant-numeric:tabular-nums;font-weight:600;text-align:right}.sap-row--deduct .sap-row-mo{color:#dc2626}.sap-row-yr{font-feature-settings:"tnum";color:#9ca3af;font-size:11px;font-variant-numeric:tabular-nums;text-align:right}.sap-net-strip{background:#fff;border-top:2px solid #e5e7eb;display:flex;gap:0}.sap-net-item{align-items:center;border-right:1px solid #e5e7eb;display:flex;flex:1 1;flex-direction:column;padding:10px 8px 9px}.sap-net-item:last-child{border-right:none}.sap-net-item--primary{background:linear-gradient(135deg,#eef2ff,#f5f3ff)}.sap-net-lbl{color:#6b7280;font-size:10px;font-weight:600;letter-spacing:.5px;margin-bottom:3px;text-transform:uppercase}.sap-net-val{font-feature-settings:"tnum";color:#1e1b4b;font-size:14px;font-variant-numeric:tabular-nums;font-weight:700}.sap-net-item--primary .sap-net-val{color:#4f46e5;font-size:16px}.sap-empty-hint{background:#f9fafb;border:1px dashed #e5e7eb;border-radius:8px;color:#9ca3af;font-size:12.5px;margin:6px 0 4px;padding:12px 16px;text-align:center}.sap-manual-toggle{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:5px;padding:8px 0 4px;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;transition:color .15s}.sap-manual-toggle:hover{color:#374151}.sap-manual-section{animation:sap-slide-down .15s ease-out;background:#fafafa;border:1px solid #e5e7eb;border-radius:8px;margin-top:2px;padding:8px 12px 4px}@keyframes sap-slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.profile-overlay{animation:profileFadeIn .2s ease-out;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a73;display:flex;inset:0;justify-content:flex-end;position:fixed;z-index:1000}@keyframes profileFadeIn{0%{opacity:0}to{opacity:1}}@keyframes profileSlideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.profile-modal{animation:profileSlideIn .28s cubic-bezier(.16,1,.3,1);background:#f8fafc;background:var(--surface-primary,#f8fafc);box-shadow:-12px 0 40px #00000026;display:flex;flex-direction:column;height:100vh;max-width:95vw;width:460px}.profile-hero{align-items:flex-end;display:flex;flex-shrink:0;justify-content:center;min-height:140px;padding:20px 24px;position:relative}.profile-hero-content{align-items:center;display:flex;flex-direction:column;transform:translateY(44px);z-index:2}.profile-close{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border:none;border-radius:var(--radius-lg);color:var(--text-inverse);cursor:pointer;padding:6px;position:absolute;right:16px;top:16px;transition:all .15s;z-index:3}.profile-close:hover{background:#ffffff59}.profile-avatar-wrapper{position:relative}.profile-avatar-upload-wrap{border-radius:50%;cursor:pointer;display:inline-block;position:relative}.profile-avatar-camera-overlay{align-items:center;background:#00000061;border-radius:50%;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .18s ease}.profile-avatar-upload-wrap:hover .profile-avatar-camera-overlay{opacity:1}.profile-avatar-spinner{animation:spin .7s linear infinite;border:2px solid #fff6;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.profile-avatar{align-items:center;background:#ffffff40;color:#fff;display:flex;font-size:2rem;font-weight:800;justify-content:center;letter-spacing:.04em;-webkit-user-select:none;user-select:none}.profile-avatar,.profile-avatar-img{border:3px solid #ffffffb3;border-radius:50%;box-shadow:0 4px 20px #0003;height:88px;width:88px}.profile-avatar-img{display:block;object-fit:cover}.profile-avatar-photo2{border:2px solid var(--surface-primary);border-radius:50%;bottom:0;box-shadow:0 2px 6px #00000040;height:30px;object-fit:cover;position:absolute;right:-4px;width:30px}.profile-identity{background:#fff;background:var(--surface-primary,#fff);padding:50px 24px 16px;text-align:center}.profile-name{color:#0f172a;color:var(--text-primary,#0f172a);font-size:1.25rem;font-weight:700;margin:0 0 2px}.profile-subtitle{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:.82rem;font-weight:500;margin:0 0 12px}.profile-badges{align-items:center;display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.profile-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:.7rem;font-weight:600;gap:4px;letter-spacing:.02em;padding:3px 10px}.profile-badge.active{background:var(--color-success-bg);color:var(--color-green-700)}.profile-badge.inactive{background:var(--color-red-50);color:var(--color-red-dark)}.profile-badge.code{background:var(--color-accent-50);color:var(--color-accent-dark);font-family:JetBrains Mono,monospace;font-family:var(--font-mono,"JetBrains Mono",monospace);font-size:.68rem;letter-spacing:.04em}.profile-badge.category{background:var(--color-blue-50);color:var(--color-blue-dark)}.profile-stats{background:#fff;background:var(--surface-primary,#fff);display:flex;gap:8px;padding:0 16px 12px}.profile-stat{align-items:center;background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border-radius:var(--radius-xl);display:flex;flex:1 1;flex-direction:column;gap:2px;padding:10px 6px;transition:transform .15s}.profile-stat:hover{transform:translateY(-1px)}.profile-stat-icon{color:#94a3b8;color:var(--text-tertiary,#94a3b8);display:flex}.profile-stat-value{color:#0f172a;color:var(--text-primary,#0f172a);font-size:.82rem;font-weight:700}.profile-stat.accent .profile-stat-value{color:var(--color-accent)}.profile-stat-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:.65rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase}.profile-scroll{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);flex:1 1;min-height:0;overflow-y:auto;padding:8px 16px 16px}.profile-section{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:12px;border-radius:var(--radius-xl,12px);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow-sm,0 1px 3px #00000014)}.profile-section+.profile-section{margin-top:10px}.profile-section-header{align-items:center;background:#f8fafc;background:var(--surface-tertiary,#f8fafc);border:none;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-light,#f1f5f9);color:#475569;color:var(--text-secondary,#475569);cursor:pointer;display:flex;font-family:inherit;font-size:inherit;gap:8px;padding:12px 16px;transition:background .12s;width:100%}.profile-section-header:hover{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9)}.profile-section-icon{color:#4f46e5;color:var(--color-indigo,#4f46e5);display:flex}.profile-section-title{flex:1 1;font-size:.78rem;font-weight:700;letter-spacing:.05em;text-align:left;text-transform:uppercase}.profile-section-body{overflow:visible;padding:4px 16px 16px}.profile-grid{grid-gap:8px 16px;display:grid;gap:8px 16px;grid-template-columns:1fr 1fr}.profile-cell{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-light,#f1f5f9);min-width:0;padding:7px 0}.profile-cell.full{grid-column:1/-1}.profile-cell-label{align-items:center;display:flex;font-size:.7rem;font-weight:500;gap:4px;letter-spacing:.04em;margin-bottom:2px;text-transform:uppercase}.cell-icon,.profile-cell-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.cell-icon{display:inline-flex}.profile-cell-value{color:#0f172a;color:var(--text-primary,#0f172a);font-size:.82rem;font-weight:600;word-break:break-word}.profile-cell-value.mono{color:#4f46e5;color:var(--color-indigo,#4f46e5);font-family:JetBrains Mono,monospace;font-family:var(--font-mono,"JetBrains Mono",monospace);font-size:.78rem;letter-spacing:.03em}.profile-cell-value.accent{color:var(--color-teal-dark);font-weight:700}.profile-address-row{align-items:flex-start;color:#64748b;color:var(--text-secondary,#64748b);display:flex;font-size:.78rem;gap:6px;line-height:1.5;padding:8px 0 0}.addr-icon{color:#94a3b8;color:var(--text-tertiary,#94a3b8);flex-shrink:0;margin-top:2px}.profile-footer{background:#fff;background:var(--surface-primary,#fff);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-light,#e2e8f0);display:flex;flex-shrink:0;gap:10px;padding:14px 16px 18px}.profile-btn{align-items:center;border:none;border-radius:var(--radius-xl);cursor:pointer;display:inline-flex;flex:1 1;font-family:var(--font-sans);font-size:.82rem;font-weight:600;gap:6px;height:40px;justify-content:center;transition:all .15s}.profile-btn-edit{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:var(--text-inverse)}.profile-btn-edit:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed);box-shadow:0 4px 14px #6366f159;transform:translateY(-1px)}.profile-btn-remove{background:#fff5f5;border:1px solid var(--color-red-light);color:var(--color-red)}.profile-btn-remove:hover{background:var(--color-red-50);border-color:var(--color-red-light);transform:translateY(-1px)}@media (max-width:480px){.profile-modal{width:100vw}.profile-grid{grid-template-columns:1fr}.profile-stats{padding:0 12px 12px}}.emp-form-page{margin:0 auto;max-width:1400px;padding:20px 24px}.emp-form-header{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;gap:16px;margin-bottom:20px;padding-bottom:16px}.emp-form-header h2{color:#1a1a2e;color:var(--text-primary,#1a1a2e);font-size:var(--text-2xl);font-weight:700;margin:0}.emp-form-header-center{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:2px}.emp-form-emp-code{color:#888;color:var(--text-secondary,#888);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.5px}.emp-form-header-actions,.emp-role-toggle-header{align-items:center;display:flex;gap:8px}.emp-role-toggle-box{background:#fff;background:var(--card-bg,#fff);border:1px solid #d9dde5;border:1px solid var(--border-color,#d9dde5);border-radius:14px;margin-left:auto;padding:8px 14px}.emp-form-body{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.emp-form-col{display:flex;flex-direction:column}.emp-form-section{background:#fff;background:var(--card-bg,#fff);border:1.5px solid #d0d5dd;border:1.5px solid var(--border-color,#d0d5dd);border-radius:var(--radius-lg);margin-bottom:16px;padding:14px 18px 10px}.emp-form-section legend{color:#2563eb;color:var(--primary,#2563eb);font-size:var(--text-sm);font-weight:700;letter-spacing:.5px;padding:0 8px;text-transform:uppercase}.emp-role-toggle-corner{background:#fff;background:var(--card-bg,#fff);border-radius:12px;padding:2px 10px;position:absolute;right:16px;top:-12px;z-index:1}.emp-form-row,.emp-role-toggle-corner{align-items:center;display:flex;gap:8px}.emp-form-row{margin-bottom:8px}.emp-form-row>label:first-child{color:#555;color:var(--text-secondary,#555);font-size:var(--text-sm);font-weight:500;min-width:135px;text-align:right;width:135px}.emp-form-row input[type=date],.emp-form-row input[type=email],.emp-form-row input[type=number],.emp-form-row input[type=tel],.emp-form-row input[type=text],.emp-form-row select,.emp-form-row textarea{background:#fff;background:var(--input-bg,#fff);border:1px solid #ccc;border:1px solid var(--border-color,#ccc);border-radius:var(--radius-sm);color:#333;color:var(--text-primary,#333);flex:1 1;font-size:var(--text-sm);padding:6px 10px;transition:border-color .2s}.emp-form-row input:focus,.emp-form-row select:focus,.emp-form-row textarea:focus{border-color:#2563eb;border-color:var(--primary,#2563eb);box-shadow:none;outline:none}.emp-form-row textarea{resize:vertical}.emp-readonly{background:var(--surface-secondary)!important;color:var(--text-tertiary)!important;cursor:not-allowed;font-style:italic}.emp-ro-value{align-items:center;background:#f8f9fa;background:var(--surface-secondary,#f8f9fa);border:1px solid #0000;border-radius:var(--radius-sm);color:#333;color:var(--text-primary,#333);display:flex;flex:1 1;font-size:var(--text-sm);font-weight:500;min-height:32px;padding:6px 10px}.emp-help-text{color:#888;color:var(--text-secondary,#888);font-size:var(--text-sm);font-style:italic;margin:-4px 0 6px 143px}.emp-pf-esi-notice{align-items:flex-start;border-left:3px solid;border-radius:var(--radius-md);display:flex;font-size:var(--text-xs);gap:8px;line-height:1.5;margin:6px 0 4px;padding:8px 12px}.emp-pf-esi-notice.info{background:var(--color-primary-50);border-color:var(--color-primary-light);color:var(--color-primary-dark)}.emp-pf-esi-notice.warning{background:var(--color-orange-50);border-color:var(--color-orange);color:var(--color-orange)}.emp-pf-esi-notice.overdue{background:#fef2f2;border-color:var(--color-red);color:var(--color-red-dark);font-weight:500}.emp-pf-esi-icon{flex-shrink:0;font-size:var(--text-base);line-height:1.4}.emp-age-badge{background:var(--color-blue-50);border-radius:var(--radius-md);color:var(--color-blue-dark);display:inline-block;font-size:var(--text-xs);font-weight:600;margin:-4px 0 6px;padding:3px 10px}.emp-field-error{color:var(--color-red);display:block;font-size:var(--text-sm);font-weight:500;margin-top:2px}.emp-form-row .req{color:var(--color-red-dark);font-weight:700}.emp-radio-group{align-items:center;display:flex;gap:20px}.emp-radio-group label{font-weight:500;gap:5px;min-width:auto;text-align:left;width:auto}.emp-checkbox,.emp-radio-group label{align-items:center;cursor:pointer;display:flex;font-size:var(--text-sm)}.emp-checkbox{gap:6px;min-width:auto!important;text-align:left!important;width:auto!important}.emp-official-section{padding-bottom:14px!important;position:relative}.emp-official-section>.emp-form-row{max-width:calc(100% - 132px)}.emp-official-section .emp-form-official-top{display:block;margin-bottom:0}.emp-official-section .emp-form-official-fields{max-width:calc(100% - 132px)}.emp-official-section .emp-form-photos{position:absolute;right:18px;top:14px}.emp-official-top-row{align-items:flex-start;display:flex;gap:20px;margin-bottom:8px}.emp-official-top-row .emp-form-photos{flex-shrink:0;order:-1}.emp-official-contact{flex:1 1}.emp-official-divider{border:none;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);margin:10px 0}.emp-official-grid{grid-gap:0 16px;display:grid;gap:0 16px;grid-template-columns:1fr 1fr}.emp-yesno-group{display:flex;gap:0}.emp-yesno-btn{align-items:center;border:1px solid #d1d5db;cursor:pointer;display:inline-flex;font-size:10px;font-weight:700;gap:2px;justify-content:center;letter-spacing:.3px;line-height:1;min-height:20px;min-width:36px;padding:2px 6px;transition:background .13s,color .13s,border-color .13s;-webkit-user-select:none;user-select:none}.emp-yesno-btn input[type=radio]{display:none}.emp-yesno-yes{border-radius:5px 0 0 5px;border-right:none}.emp-yesno-no,.emp-yesno-yes{background:#f3f4f6;color:#9ca3af}.emp-yesno-no{border-radius:0 5px 5px 0}.emp-yesno-yes.active{background:#16a34a;border-color:#16a34a;color:#fff}.emp-yesno-no.active{background:#dc2626;border-color:#dc2626;color:#fff}.emp-yesno-ro{align-items:center;border-radius:4px;display:inline-flex;font-size:10px;font-weight:700;gap:2px;letter-spacing:.3px;padding:2px 6px}.emp-yesno-ro-yes{background:#dcfce7;color:#15803d}.emp-yesno-ro-no{background:#fee2e2;color:#b91c1c}.emp-form-official-top{display:flex;gap:16px;margin-bottom:8px}.emp-form-official-fields{flex:1 1}.emp-form-photos{display:flex;flex-shrink:0;gap:10px}.emp-photo-box{text-align:center;width:100px}.emp-photo-label{color:#555;color:var(--text-secondary,#555);display:block;font-size:var(--text-sm);font-weight:700;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.emp-photo-preview{background:#f9f9f9;border:2px solid #ccc;border:2px solid var(--border-color,#ccc);border-radius:var(--radius-md);height:110px;overflow:hidden;position:relative;width:100px}.emp-photo-preview img{height:100%;object-fit:cover;width:100%}.emp-photo-remove{align-items:center;background:#e53935d9;border:none;border-radius:50%;color:var(--text-inverse);cursor:pointer;display:flex;height:22px;justify-content:center;position:absolute;right:3px;top:3px;transition:background .2s;width:22px}.emp-photo-remove:hover{background:var(--color-red-dark)}.emp-photo-upload{align-items:center;background:#fafafa;background:var(--input-bg,#fafafa);border:2px dashed #ccc;border:2px dashed var(--border-color,#ccc);border-radius:var(--radius-md);color:#888;color:var(--text-secondary,#888);cursor:pointer;display:flex;flex-direction:column;font-size:var(--text-sm);gap:4px;height:110px;justify-content:center;transition:border-color .2s,color .2s;width:100px}.emp-photo-upload:hover{border-color:#2563eb;border-color:var(--primary,#2563eb);color:#2563eb;color:var(--primary,#2563eb)}.emp-photo-placeholder{border-style:solid;color:#aaa;color:var(--text-secondary,#aaa);cursor:default;font-size:var(--text-sm)}.emp-photo-placeholder:hover{border-color:#ccc;border-color:var(--border-color,#ccc);color:#aaa;color:var(--text-secondary,#aaa)}.emp-photo-actions{align-items:center;display:flex;flex-direction:column;gap:6px}.emp-photo-webcam-btn{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:4px 10px;transition:background .15s}.emp-photo-webcam-btn:hover{background:#e5e7eb;color:#2563eb}.emp-form-footer{border-top:1.5px solid #ddd;border-top:1.5px solid var(--border-color,#ddd);display:flex;gap:12px;padding:16px 0}.emp-toggle-wrapper{align-items:center;display:flex;gap:10px}.emp-toggle-switch{border:none;border-radius:12px;cursor:pointer;flex-shrink:0;height:24px;padding:0;position:relative;transition:background-color .25s;width:44px}.emp-toggle-switch.emp-toggle-on{background-color:#22c55e}.emp-toggle-switch.emp-toggle-off{background-color:#d1d5db}.emp-toggle-switch:disabled{cursor:not-allowed;opacity:.6}.emp-toggle-slider{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;height:20px;left:2px;position:absolute;top:2px;transition:transform .25s;width:20px}.emp-toggle-on .emp-toggle-slider{transform:translateX(20px)}.emp-toggle-off .emp-toggle-slider{transform:translateX(0)}.emp-toggle-label{font-size:var(--text-sm);font-weight:600}.emp-toggle-label-on{color:#16a34a}.emp-toggle-label-off{color:#6b7280}.emp-idproof-tabs{display:flex;gap:0;margin-bottom:8px}.emp-idproof-tab{align-items:center;background:#f8f9fa;background:var(--surface-secondary,#f8f9fa);border:1px solid #ccc;border:1px solid var(--border-color,#ccc);color:#666;color:var(--text-secondary,#666);cursor:pointer;display:flex;font-size:var(--text-xs);font-weight:600;gap:5px;padding:5px 12px;transition:all .2s}.emp-idproof-tab:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm);border-right:none}.emp-idproof-tab:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.emp-idproof-tab.active{background:#2563eb;background:var(--primary,#2563eb);border-color:#2563eb;border-color:var(--primary,#2563eb);color:#fff}.emp-idproof-upload-area{margin-bottom:6px}.emp-idproof-preview{align-items:center;background:#f8f9fa;background:var(--surface-secondary,#f8f9fa);border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:var(--radius-sm);display:flex;gap:8px;margin-top:6px;padding:6px 8px}.emp-idproof-filename{color:#333;color:var(--text-primary,#333);font-size:var(--text-sm);font-weight:500}.btn-sm{padding:4px 10px}@media (max-width:960px){.emp-form-body{grid-template-columns:1fr}.emp-form-official-top{flex-direction:column}.emp-form-photos{justify-content:center}.emp-form-header{flex-wrap:wrap}.emp-role-toggle-box{margin-left:0}.emp-form-header h2{order:-1;text-align:left;width:100%}.emp-official-section .emp-form-photos{position:static}.emp-official-section .emp-form-official-fields,.emp-official-section>.emp-form-row{max-width:100%}}@media (max-width:480px){.emp-form-section{padding:12px}.emp-form-row{flex-direction:column;gap:4px}.emp-form-row label{min-width:auto;width:auto}.emp-form-header{gap:8px;padding:12px 16px}.emp-form-header h2{font-size:var(--text-base)}.emp-form-photos{gap:8px}}.cqm-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.cqm-modal{background:#fff;background:var(--surface,#fff);border-radius:10px;box-shadow:0 8px 32px #0000002e;max-height:85vh;max-width:94vw;overflow-y:auto;width:480px}.cqm-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;padding:14px 20px}.cqm-header h3{color:#1e293b;color:var(--text-primary,#1e293b);font-size:15px;font-weight:600;margin:0}.cqm-close{background:none;border:none;border-radius:4px;color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;padding:4px}.cqm-close:hover{color:#ef4444;color:var(--danger,#ef4444)}.cqm-body{gap:10px;padding:16px 20px}.cqm-body,.cqm-row{display:flex;flex-direction:column}.cqm-row{gap:3px}.cqm-row label{color:#64748b;color:var(--text-secondary,#64748b);font-size:12px;font-weight:500}.cqm-row label .req{color:#ef4444;color:var(--danger,#ef4444)}.cqm-row input{background:#fff;background:var(--input-bg,#fff);border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:6px;color:#333;color:var(--text-primary,#333);font-size:13px;padding:7px 10px;transition:border-color .2s}.cqm-row input:focus{border-color:#2563eb;border-color:var(--primary,#2563eb);box-shadow:0 0 0 2px #2563eb1f;outline:none}.cqm-row-pair{display:flex;gap:12px}.cqm-row-pair .cqm-row{flex:1 1}.cqm-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;gap:8px;justify-content:flex-end;padding:12px 20px}.cqm-btn-cancel,.cqm-btn-save{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:7px 18px;transition:background .2s}.cqm-btn-cancel{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);color:#475569;color:var(--text-secondary,#475569)}.cqm-btn-cancel:hover{background:#e2e8f0}.cqm-btn-save{background:#2563eb;background:var(--primary,#2563eb);color:#fff}.cqm-btn-save:hover{background:#1d4ed8}.cqm-btn-cancel:disabled,.cqm-btn-save:disabled{cursor:not-allowed;opacity:.6}.emp-dropdown-with-actions{align-items:center;display:flex;flex:1 1;gap:4px}.emp-dropdown-with-actions select{flex:1 1}.emp-dropdown-action-btn{align-items:center;background:none;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:5px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:5px 7px;transition:all .15s}.emp-dropdown-action-btn:hover{background:#2563eb0f;border-color:#2563eb;border-color:var(--primary,#2563eb);color:#2563eb;color:var(--primary,#2563eb)}.emp-dropdown-action-btn.add-btn:hover{background:#16a34a0f;border-color:#16a34a;border-color:var(--success,#16a34a);color:#16a34a;color:var(--success,#16a34a)}.employee-page{animation:fadeInUp .3s ease-out}.search-bar{margin-bottom:var(--space-5);max-width:320px;position:relative}.search-bar input{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);height:36px;outline:none;padding:0 var(--space-3) 0 36px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.search-bar input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.search-bar .search-icon,.search-bar input::placeholder{color:var(--text-tertiary)}.search-bar .search-icon{align-items:center;display:flex;left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-bar .search-icon svg{stroke-width:1.75;height:16px;width:16px}.employee-code-badge{background:var(--color-primary-50);border-radius:var(--radius-sm);color:var(--color-primary-dark);font-family:monospace;font-family:var(--font-mono,monospace);font-weight:600;letter-spacing:.02em}.department-badge,.employee-code-badge{display:inline-block;font-size:var(--text-xs);padding:2px 8px}.department-badge{background:var(--color-blue-50);border-radius:var(--radius-full);color:var(--color-blue-dark);font-weight:500}.standard-login-badge{align-items:center;background:var(--color-orange-50);border-radius:var(--radius-sm);color:var(--color-orange);display:inline-flex;font-size:var(--text-sm);font-weight:500;gap:4px;margin-left:var(--space-2);padding:2px 6px}.employee-name-cell{align-items:center;display:flex;gap:var(--space-2-5)}.employee-avatar-small{align-items:center;background:var(--color-primary);color:var(--text-inverse);display:flex;font-size:11px;font-weight:600;justify-content:center;letter-spacing:.02em}.employee-avatar-img-small,.employee-avatar-small{border-radius:var(--radius-full);flex-shrink:0;height:30px;width:30px}.employee-avatar-img-small{border:1px solid #e5e7eb;border:1px solid var(--border-default,#e5e7eb);object-fit:cover}.employee-name{color:var(--text-primary);font-weight:500}.status-badge{font-weight:500;gap:4px}.pagination-container{align-items:center;border-top:1px solid var(--border-light);display:flex;justify-content:space-between;margin-top:var(--space-5);padding-top:var(--space-4)}.pagination-info{color:var(--text-tertiary);font-size:var(--text-sm)}.pagination-controls{align-items:center;display:flex;gap:var(--space-1)}.pagination-btn{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:500;gap:4px;height:32px;justify-content:center;padding:0 var(--space-3);transition:all var(--transition-fast);white-space:nowrap}.pagination-btn:hover:not(:disabled){background:var(--surface-tertiary);border-color:var(--border-strong);color:var(--text-primary)}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.pagination-pages{display:flex;gap:2px}.pagination-page{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.pagination-page:hover:not(:disabled):not(.active){background:var(--surface-tertiary);border-color:var(--border-strong)}.pagination-page.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--text-inverse)}.pagination-page:disabled{cursor:not-allowed;opacity:.4}@media (max-width:768px){.search-bar{max-width:100%}.pagination-container{align-items:stretch;flex-direction:column;gap:var(--space-3)}.pagination-controls{flex-wrap:wrap;justify-content:center}.pagination-info{text-align:center}.pagination-pages{flex-wrap:wrap;justify-content:center}.employee-header{align-items:flex-start;flex-direction:column;gap:8px}.employee-toolbar{align-items:stretch;flex-direction:column;gap:8px}.employee-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:480px){.employee-container{padding:var(--space-2)}.employee-header h2{font-size:var(--text-lg)}.employee-avatar-small{font-size:10px;height:24px;width:24px}}.v3-page .v3-tbl{table-layout:fixed;width:100%}.v3-page .v3-tbl td,.v3-page .v3-tbl th{overflow:hidden;padding:8px 6px;text-overflow:ellipsis;white-space:nowrap}.v3-page .v3-tbl td:first-child,.v3-page .v3-tbl th:first-child{width:18%}.v3-page .v3-tbl td:nth-child(2),.v3-page .v3-tbl th:nth-child(2){width:8%}.v3-page .v3-tbl td:nth-child(3),.v3-page .v3-tbl th:nth-child(3){width:7%}.v3-page .v3-tbl td:nth-child(4),.v3-page .v3-tbl th:nth-child(4){width:9%}.v3-page .v3-tbl td:nth-child(5),.v3-page .v3-tbl th:nth-child(5){width:10%}.v3-page .v3-tbl td:nth-child(6),.v3-page .v3-tbl th:nth-child(6){width:8%}.v3-page .v3-tbl td:nth-child(7),.v3-page .v3-tbl th:nth-child(7){width:6%}.v3-page .v3-tbl td:nth-child(8),.v3-page .v3-tbl th:nth-child(8){width:10%}.v3-page .v3-tbl td:nth-child(9),.v3-page .v3-tbl th:nth-child(9){width:7%}.v3-page .v3-tbl td:nth-child(10),.v3-page .v3-tbl th:nth-child(10){width:8%}.v3-page .v3-tbl td:nth-child(11),.v3-page .v3-tbl th:nth-child(11){width:9%}.v3-page .v3-tbl td:first-child{overflow:visible;white-space:normal}.v3-page .v3-emp-cell{gap:6px}.v3-page .v3-emp-name{font-size:12px;line-height:1.2}.v3-page .v3-emp-code{font-size:10px}.v3-page .v3-tbl .v3-badge{font-size:10px;max-width:100%;overflow:hidden;padding:2px 8px;text-overflow:ellipsis}.v3-page .v3-act{gap:2px}.v3-page .v3-act button{font-size:12px;padding:4px 6px}.attendance-page{animation:fadeInUp .3s ease-out}.attendance-page .v3-tbl{table-layout:auto}.attendance-page .v3-tbl td,.attendance-page .v3-tbl th{overflow:visible;white-space:nowrap;width:auto}.att-topbar{background:#fff;background:var(--toolbar-bg,#fff);border:1px solid color-mix(in srgb,#fff 80%,#000 20%);border:1px solid color-mix(in srgb,var(--toolbar-bg,#fff) 80%,#000 20%);border-radius:var(--radius-xl);color:var(--text-primary);color:var(--toolbar-text,var(--text-primary));justify-content:space-between;padding:8px 14px;transition:background .25s ease,color .25s ease,border-color .25s ease}.att-topbar,.att-topbar-left{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.att-topbar-left .ss-searchable{flex:0 1 auto}.att-topbar-right{align-items:center;display:flex;flex-wrap:wrap;gap:4px}.att-live-corner{align-items:center;background:#dc2626;border-radius:999px;bottom:24px;box-shadow:0 2px 12px #dc262673;color:#fff;cursor:default;display:inline-flex;font-size:11px;font-weight:700;gap:6px;letter-spacing:.1em;padding:6px 12px 6px 8px;position:fixed;right:24px;-webkit-user-select:none;user-select:none;z-index:1200}.att-live-dot{animation:att-live-pulse 1.4s ease-in-out infinite;background:#fff;border-radius:50%;flex-shrink:0;height:8px;width:8px}@keyframes att-live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.65)}}.att-date-input{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border:1px solid #ffffff40;border-radius:var(--radius-xl);color:var(--text-primary);color:var(--toolbar-text,var(--text-primary));cursor:pointer;font-family:var(--font-sans);font-size:12px;font-weight:600;height:32px;outline:none;padding:0 10px;transition:background .2s,border-color .2s}.att-date-input:focus{background:#ffffff40;border-color:#ffffff80}.att-dept-select{flex:0 1 auto;max-width:170px;min-width:130px}.att-filter-mode{flex:0 0 auto;max-width:130px;min-width:110px}.att-status-select{flex:0 1 auto;max-width:140px;min-width:110px}.att-dept-select .ss-searchable__trigger,.att-filter-mode .ss-searchable__trigger,.att-month-select .ss-searchable__trigger,.att-status-select .ss-searchable__trigger,.att-year-select .ss-searchable__trigger{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border:1px solid #ffffff40;border-radius:var(--radius-xl);color:var(--text-primary);color:var(--toolbar-text,var(--text-primary));font-family:var(--font-sans);font-size:12px;font-weight:600;height:32px;transition:background .2s,border-color .2s}.att-month-select{flex:0 0 auto;max-width:130px;min-width:100px}.att-year-select{flex:0 0 auto;max-width:90px;min-width:70px}.att-btn{align-items:center;border:none;border-radius:var(--radius-xl);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:12px;font-weight:700;gap:5px;height:32px;padding:0 12px;transition:all .15s;white-space:nowrap}.att-btn-green{background:var(--surface-primary);border:1px solid #0596694d;color:var(--color-green-600)}.att-btn-green:hover{background:var(--color-green-50)}.att-btn-outline{background:#ffffffd9;border:1px solid #ffffff80;color:var(--text-primary)}.att-btn-outline:hover{background:var(--surface-primary)}.att-icon-btn{align-items:center;background:#ffffffd9;border:1px solid #ffffff80;border-radius:50%;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;display:inline-flex;flex-shrink:0;height:32px;justify-content:center;position:relative;transition:all .15s;width:32px}.att-icon-btn:hover{background:#fff;border-color:#00c9a766;box-shadow:0 2px 8px #00c9a726;color:#00c9a7;color:var(--color-teal,#00c9a7)}.att-icon-btn:disabled{cursor:not-allowed;opacity:.4}.att-icon-btn-green{background:#ecfdf5;background:var(--color-green-50,#ecfdf5);border-color:#0596694d;color:#059669;color:var(--color-green,#059669)}.att-icon-btn-green:hover{background:#d1fae5;box-shadow:0 2px 8px #05966933}.att-icon-btn-active{background:#00c9a7;background:var(--color-teal,#00c9a7);border-color:#00c9a7;border-color:var(--color-teal,#00c9a7);color:#fff}.att-icon-btn-active:hover{background:#00b899;border-color:#00b899;color:#fff}.att-icon-btn-primary{background:#00897b;background:var(--color-primary,#00897b);border-color:#00897b;border-color:var(--color-primary,#00897b);border-radius:16px;color:#fff;font-size:12px;font-weight:600;gap:5px;padding:0 12px;width:auto}.att-icon-btn-primary:after{content:"Load"}.att-icon-btn-primary:hover{background:#00796b;border-color:#00796b;box-shadow:0 2px 8px #00897b4d;color:#fff}.att-emp-cell{align-items:center;display:flex;gap:10px}.att-avatar{align-items:center;color:var(--text-inverse);display:flex;font-size:var(--text-sm);font-weight:700;justify-content:center;text-transform:uppercase}.att-avatar,.att-avatar-img{border-radius:50%;flex-shrink:0;height:32px;width:32px}.att-avatar-img{object-fit:cover}.att-emp-name{color:var(--text-primary);font-size:var(--text-sm);font-weight:600;white-space:nowrap}.att-change-select{appearance:none;-webkit-appearance:none;background:var(--surface-primary);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='m1 1 4 4 4-4' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:none;color:var(--text-primary);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:500;height:32px;min-width:110px;outline:none;padding:0 28px 0 10px;transition:border-color .15s}.att-change-select:focus{border-color:var(--color-teal);box-shadow:none;outline:none}.att-change-select:disabled{cursor:not-allowed;opacity:.5}.status-badge{border-radius:var(--radius-sm);display:inline-block;font-size:var(--text-xs);padding:2px 8px;text-transform:capitalize}.status-badge.green{background:var(--color-green-50);color:var(--color-green)}.status-badge.red{background:var(--color-red-50);color:var(--color-red)}.status-badge.orange{background:var(--color-orange-50);color:var(--color-orange)}.status-badge.blue{background:var(--color-blue-50);color:var(--color-blue)}.status-badge.purple{background:#7c3aed14;color:var(--color-accent)}.edited-badge{background:var(--color-orange-50);border-radius:var(--radius-sm);color:var(--color-orange);font-size:var(--text-xs);font-weight:500;margin-left:var(--space-2);padding:1px 6px}.success-message{background:var(--color-green-50);border:1px solid var(--color-green);border-radius:var(--radius-md);color:var(--color-green);font-size:var(--text-sm);font-weight:500;padding:var(--space-3) var(--space-4)}.attendance-modal{max-width:720px;width:95vw}.attendance-modal .form-section h4{align-items:center;border-bottom:1px solid var(--border-default);color:var(--text-primary);display:flex;font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-3);padding-bottom:var(--space-2)}.attendance-modal .form-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(2,1fr)}.attendance-modal .form-group.full-width{grid-column:1/-1}.import-textarea{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:Courier New,monospace;font-family:var(--font-mono,"Courier New",monospace);font-size:var(--text-sm);min-height:200px;padding:var(--space-3);resize:vertical;width:100%}.import-textarea::placeholder{color:var(--text-tertiary)}.help-text{font-size:var(--text-xs);line-height:1.5;margin-bottom:var(--space-3)}@media (max-width:768px){.att-topbar{align-items:stretch;flex-direction:column}.att-topbar-left,.att-topbar-right{flex-wrap:wrap;justify-content:center}.attendance-modal .form-grid{grid-template-columns:1fr}.att-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.att-search{width:100%}.att-emp-modal-wide{max-width:98vw}.att-cal-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.att-day-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.att-topbar{gap:6px;padding:8px}.att-topbar-left,.att-topbar-right{gap:6px}.attendance-modal{width:95vw}}.att-row-click{cursor:pointer;transition:background .12s}.att-row-click:hover{background:#ecfdf5!important;background:var(--color-green-50,#ecfdf5)!important}.att-row-selected{background:#eff6ff!important}.att-row-selected:hover{background:#dbeafe!important}.att-row-check{accent-color:#2563eb;accent-color:var(--color-primary,#2563eb);cursor:pointer;height:15px;width:15px}.att-bulk-bar{align-items:center;background:#eff6ff;border-bottom:1px solid #bfdbfe;border-radius:8px 8px 0 0;display:flex;gap:10px;padding:8px 16px}.att-bulk-count{color:#1d4ed8;flex-shrink:0;font-size:13px;font-weight:600;white-space:nowrap}.att-status-pill{border-radius:12px;font-family:var(--font-mono);font-size:12px;padding:2px 10px}.att-status-pill,.att-status-pill-lg{display:inline-block;font-weight:700;letter-spacing:.3px}.att-status-pill-lg{border-radius:16px;font-size:14px;padding:4px 16px}.att-count-badge{align-items:center;border-radius:8px;display:inline-flex;font-family:var(--font-mono);font-size:12px;font-weight:700;height:24px;justify-content:center;min-width:28px;padding:0 6px}.att-legend{align-items:center;display:flex;gap:4px}.att-legend-item{border-radius:8px;display:inline-block;font-size:11px;padding:2px 8px}.att-legend-item,.att-th-status{font-family:var(--font-mono);font-weight:700}.att-th-status{font-size:13px}.sort-th{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sort-th:hover{background:color-mix(in srgb,#f3f4f6 80%,#0d9488 20%);background:color-mix(in srgb,var(--table-header-bg,#f3f4f6) 80%,var(--color-teal,#0d9488) 20%)}.att-emp-modal{border-radius:16px;border-radius:var(--radius-xl,16px);max-height:90vh;max-width:560px;overflow-y:auto;width:95vw}.att-emp-modal-wide{max-width:820px}.att-modal-header{align-items:center;background:linear-gradient(135deg,#ecfdf5,#f0fdf9);background:linear-gradient(135deg,var(--color-green-50,#ecfdf5) 0,#f0fdf9 100%);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-default,#e5e7eb);border-radius:16px 16px 0 0;border-radius:var(--radius-xl,16px) var(--radius-xl,16px) 0 0;display:flex;justify-content:space-between;padding:16px 20px}.att-modal-emp-info{align-items:center;display:flex;gap:12px}.att-modal-avatar{align-items:center;color:#fff;display:flex;font-size:14px;font-weight:700;justify-content:center}.att-modal-avatar,.att-modal-avatar-img{border-radius:50%;flex-shrink:0;height:44px;width:44px}.att-modal-avatar-img{border:2px solid #05966933;object-fit:cover}.att-modal-emp-name{color:#111827;color:var(--text-primary,#111827);font-size:16px;font-weight:700}.att-modal-emp-meta{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;font-size:12px;font-weight:500;gap:6px;margin-top:2px}.att-day-detail{padding:20px}.att-day-date{align-items:center;color:#111827;color:var(--text-primary,#111827);display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:16px}.att-day-status-row{align-items:center;display:flex;gap:16px;margin-bottom:20px}.att-day-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:16px}.att-day-card{background:#f9fafb;background:var(--surface-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-default,#e5e7eb);border-radius:10px;padding:10px 12px;text-align:center}.att-day-card-label{color:#9ca3af;color:var(--text-tertiary,#9ca3af);font-size:11px;font-weight:600;letter-spacing:.3px;margin-bottom:4px;text-transform:uppercase}.att-day-card-value{color:#111827;color:var(--text-primary,#111827);font-family:monospace;font-family:var(--font-mono,monospace);font-size:14px;font-weight:700}.att-day-remarks{background:#f9fafb;background:var(--surface-secondary,#f9fafb);border-radius:8px;color:#6b7280;color:var(--text-secondary,#6b7280);font-size:13px;margin-bottom:16px;padding:8px 12px}.att-day-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-default,#e5e7eb);display:flex;gap:8px;padding-top:12px}.att-month-detail{padding:20px}.att-month-title{align-items:center;color:#111827;color:var(--text-primary,#111827);display:flex;font-size:15px;font-weight:700;gap:8px;margin-bottom:12px}.att-month-totals{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.att-total-chip{align-items:center;border-radius:12px;display:inline-flex;font-family:monospace;font-family:var(--font-mono,monospace);font-size:12px;font-weight:700;gap:4px;padding:4px 12px}.att-cal-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(auto-fill,minmax(76px,1fr))}.att-cal-cell{align-items:center;border:1px solid #e5e7eb;border-radius:8px;display:flex;flex-direction:column;justify-content:center;min-height:64px;padding:6px 4px;text-align:center;transition:transform .1s,box-shadow .1s}.att-cal-cell-has{cursor:pointer}.att-cal-cell-has:hover{box-shadow:0 2px 8px #0000001a;transform:scale(1.05)}.att-cal-cell-future{cursor:default!important;opacity:.38;pointer-events:none}.att-cal-day{color:#111827;color:var(--text-primary,#111827);font-size:14px;font-weight:700}.att-cal-dayname{color:#9ca3af;color:var(--text-tertiary,#9ca3af);font-size:10px;font-weight:500;margin-top:2px}.att-cal-code{font-size:13px;font-weight:800;letter-spacing:.5px;margin-top:2px}.att-cal-code,.att-cal-time{font-family:monospace;font-family:var(--font-mono,monospace)}.att-cal-time{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:9px;font-weight:500;margin-top:1px}.att-spinner{animation:att-spin .6s linear infinite;border:3px solid #e5e7eb;border-top-color:#0d9488;border:3px solid var(--border-default,#e5e7eb);border-radius:50%;border-top-color:var(--color-teal,#0d9488);display:inline-block;height:24px;margin-bottom:8px;width:24px}@keyframes att-spin{to{transform:rotate(1turn)}}.att-dev-badge{border-radius:6px;display:inline-block;font-family:monospace;font-family:var(--font-mono,monospace);font-size:10px;font-weight:700;letter-spacing:.2px;margin-left:4px;padding:1px 5px;vertical-align:middle;white-space:nowrap}.att-dev-late{background:#fff7ed;border:1px solid #ea580c33;color:#ea580c}.att-dev-early{background:#fef2f2;border:1px solid #dc262633;color:#dc2626}.att-shift-ref{color:#94a3b8;color:var(--text-disabled,#94a3b8);font-size:9px;font-weight:500;letter-spacing:0;margin-left:4px;text-transform:none}.report-page{animation:fadeInUp .3s ease-out;max-width:var(--content-max-width);padding:var(--space-6)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.rp-header-bar{justify-content:space-between;margin-bottom:var(--space-5)}.rp-header-bar,.rp-header-left{align-items:center;display:flex}.rp-header-left{gap:var(--space-3)}.rp-back-btn{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all var(--transition-fast);width:36px}.rp-back-btn:hover{background:var(--surface-secondary);border-color:var(--border-strong);color:var(--text-primary)}.rp-header-icon{align-items:center;background:var(--color-primary-50);border-radius:var(--radius-lg);color:var(--color-primary);display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.rp-header-text{align-items:baseline;display:flex;gap:var(--space-2)}.rp-header-text h2{color:var(--text-primary);font-size:var(--text-xl);font-weight:700;margin:0}.rp-breadcrumb{color:var(--text-tertiary);font-size:var(--text-sm);font-weight:400}.rp-cards-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(3,1fr);margin-bottom:var(--space-5)}.rp-report-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5);transition:box-shadow var(--transition-base),transform var(--transition-fast),border-color var(--transition-base)}.rp-report-card:hover{border-color:var(--border-strong);box-shadow:0 8px 24px #00000012;transform:translateY(-2px)}.rp-rc-top{gap:var(--space-3)}.rp-rc-icon,.rp-rc-top{align-items:center;display:flex}.rp-rc-icon{border-radius:var(--radius-lg);flex-shrink:0;height:44px;justify-content:center;width:44px}.rp-rc-info{min-width:0}.rp-rc-title{color:var(--text-primary);font-size:var(--text-base);font-weight:700;line-height:1.3}.rp-rc-subtitle{color:var(--text-tertiary);font-size:var(--text-xs);margin-top:2px}.rp-rc-actions{align-items:center;display:flex;gap:var(--space-3)}.rp-rc-view-btn{background:#0000;border:1.5px solid var(--color-green);border-radius:var(--radius-md);color:var(--color-green);cursor:pointer;flex:1 1;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;height:36px;transition:all var(--transition-fast)}.rp-rc-view-btn:hover{background:var(--color-green-50)}.rp-rc-dl-btn{align-items:center;background:#0000;border:1.5px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all var(--transition-fast);width:36px}.rp-rc-dl-btn:hover{background:var(--surface-secondary);border-color:var(--border-strong);color:var(--text-secondary)}.rp-trends-row{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:1fr 1fr}.rp-trend-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);display:flex;flex-direction:column;min-height:220px;padding:var(--space-5)}.rp-trend-header{align-items:center;display:flex;gap:var(--space-3);margin-bottom:var(--space-5)}.rp-trend-icon{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.rp-trend-icon-blue{background:var(--color-primary-50);color:var(--color-primary)}.rp-trend-icon-amber{background:#fffbeb;color:#f59e0b}.rp-trend-title{color:var(--text-primary);font-size:var(--text-base);font-weight:700}.rp-trend-body{display:flex;flex:1 1;flex-direction:column;justify-content:flex-end}.rp-trend-bars{gap:var(--space-4);min-height:100px;padding:0 var(--space-2)}.rp-trend-bar-col,.rp-trend-bars{align-items:flex-end;display:flex;flex:1 1}.rp-trend-bar-col{height:100%;justify-content:center}.rp-trend-bar{border-radius:var(--radius-md) var(--radius-md) 0 0;max-width:40px;transition:height .6s cubic-bezier(.4,0,.2,1);width:100%}.rp-trend-months{border-top:1px solid var(--border-light);display:flex;justify-content:space-around;margin-top:var(--space-2);padding-top:var(--space-3)}.rp-trend-months span{color:var(--text-tertiary);font-size:var(--text-xs);font-weight:500}@media (max-width:1024px){.rp-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.rp-cards-grid,.rp-trends-row{grid-template-columns:1fr}.rp-header-text{flex-direction:column;gap:0}}.report-page-header{border-bottom:1px solid var(--border-default);justify-content:space-between;margin-bottom:var(--space-6);padding-bottom:var(--space-5)}.report-page-header,.rph-left{align-items:center;display:flex;gap:var(--space-4)}.rph-icon{align-items:center;background:#eff6ff;background:var(--color-primary-50,#eff6ff);border-radius:var(--radius-xl);color:var(--color-primary);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.report-page-header h2{color:var(--text-primary);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.3px;margin:0 0 2px}.header-subtitle{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.rph-badges{display:flex;flex-wrap:wrap;gap:var(--space-2)}.rph-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-xs);font-weight:600;gap:4px;letter-spacing:.2px;padding:5px 12px}.rph-badge-blue{background:#eff6ff;background:var(--color-primary-50,#eff6ff);border:1px solid var(--color-primary-200);color:var(--color-primary)}.rph-badge-purple{background:var(--color-accent-50);border:1px solid var(--color-accent-50);color:var(--color-accent-dark)}.report-seg-ctrl{background:var(--surface-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-xl);display:inline-flex;gap:3px;margin-bottom:var(--space-6);padding:4px}.seg-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:500;gap:7px;padding:8px 18px;transition:all var(--transition-fast);white-space:nowrap}.seg-btn:hover:not(.active){background:#ffffffa6;color:var(--text-primary)}.seg-btn.active{background:var(--surface-primary);box-shadow:0 1px 4px #0000001a,0 0 0 1px #0000000a;color:var(--color-primary);font-weight:600}.seg-count{align-items:center;background:#eff6ff;background:var(--color-primary-50,#eff6ff);border-radius:var(--radius-full);color:var(--color-primary);display:inline-flex;font-size:var(--text-sm);font-weight:700;height:20px;justify-content:center;line-height:1;min-width:20px;padding:0 5px}.seg-btn.active .seg-count{background:var(--color-primary);color:#fff}.alert{align-items:center;border-radius:var(--radius-lg);display:flex;font-size:var(--text-sm);font-weight:500;gap:var(--space-3);justify-content:space-between;margin-bottom:var(--space-5);padding:var(--space-3) var(--space-4)}.alert-error{background:var(--color-red-50);border:1px solid var(--color-red-light);color:var(--color-red-dark)}.alert-close{background:none;border:none;color:inherit;cursor:pointer;display:flex;flex-shrink:0;opacity:.7;padding:2px}.alert-close:hover{opacity:1}.rp-filter-panel{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-bottom:var(--space-5);overflow:hidden}.rfp-header{align-items:center;background:var(--surface-secondary);border-bottom:1px solid var(--border-default);color:var(--text-secondary);display:flex;font-size:var(--text-xs);font-weight:700;gap:7px;letter-spacing:.7px;padding:var(--space-3) var(--space-5);text-transform:uppercase}.rfp-fields{align-items:flex-end;display:flex;flex-wrap:wrap;gap:var(--space-4);padding:var(--space-5)}.rfp-fields .filter-group{flex:1 1;min-width:150px}.rfp-fields .filter-action{align-items:flex-end;display:flex;flex:0 0 auto;gap:var(--space-2)}.filter-group label{color:var(--text-secondary);display:block;font-size:var(--text-xs);font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.filter-input,.filter-select{appearance:none;-webkit-appearance:none;background:var(--surface-primary);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);height:38px;padding:0 var(--space-3);padding-right:30px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.filter-input{background-image:none;padding-right:var(--space-3)}.filter-input:focus,.filter-select:focus{border-color:var(--color-primary);box-shadow:none;outline:none}.filter-input:hover,.filter-select:hover{border-color:var(--border-strong)}.filter-hint{color:var(--text-tertiary);font-weight:400;letter-spacing:0;text-transform:none}.btn,.filter-hint{font-size:var(--text-sm)}.btn{align-items:center;border:1px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-weight:600;gap:6px;height:38px;padding:0 var(--space-4);text-decoration:none;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.55;pointer-events:none}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:var(--text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.btn-secondary{background:var(--surface-primary);border-color:var(--border-default);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--surface-secondary);border-color:var(--border-strong)}.btn-sm{height:34px;padding:0 var(--space-3)}.btn-dl,.btn-sm{font-size:var(--text-xs)}.btn-dl{align-items:center;border:1.5px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-weight:600;gap:5px;padding:6px 14px;transition:all var(--transition-fast);white-space:nowrap}.btn-dl:disabled{cursor:not-allowed;opacity:.5}.btn-dl-xl{background:var(--color-green-50);border-color:var(--color-green-100);color:var(--color-green-700)}.btn-dl-xl:hover:not(:disabled){background:var(--color-green-100);border-color:var(--color-green-100)}.btn-dl-pdf{color:var(--color-red-dark)}.btn-dl-pdf,.btn-dl-pdf:hover:not(:disabled){background:var(--color-red-50);border-color:var(--color-red-light)}.rp-section-hdr{align-items:baseline;display:flex;gap:var(--space-3);margin-bottom:var(--space-5)}.rp-section-hdr h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;margin:0}.rp-section-hdr p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.rp-dl-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(272px,1fr))}.rp-dl-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);display:flex;flex-direction:column;overflow:hidden;transition:box-shadow var(--transition-base),transform var(--transition-fast),border-color var(--transition-base)}.rp-dl-card:hover{border-color:var(--border-strong);box-shadow:0 8px 24px #00000017;transform:translateY(-2px)}.rpdlc-selected{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-100)}.rpdlc-check{align-items:center;cursor:pointer;display:flex}.rpdlc-check input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;height:18px;margin:0;width:18px}.rpdlc-check input[type=checkbox]:disabled{cursor:not-allowed;opacity:.4}.rp-docs-header{flex-wrap:wrap;gap:var(--space-3);justify-content:space-between}.rp-docs-header,.rp-select-all{align-items:center;display:flex}.rp-select-all{color:var(--text-secondary);cursor:pointer;font-size:var(--text-sm);font-weight:600;gap:var(--space-2);-webkit-user-select:none;user-select:none}.rp-select-all input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;height:16px;margin:0;width:16px}.btn-dl-email{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:600;gap:var(--space-2);padding:8px 18px;transition:background .2s}.btn-dl-email:hover:not(:disabled){background:var(--color-primary-hover)}.btn-dl-email:disabled{cursor:not-allowed;opacity:.5}.rpdlc-head{background:var(--surface-secondary);border-bottom:1px solid var(--border-light);gap:var(--space-3);padding:var(--space-4) var(--space-5)}.rpdlc-head,.rpdlc-icon{align-items:center;display:flex}.rpdlc-icon{border-radius:var(--radius-lg);flex-shrink:0;height:44px;justify-content:center;width:44px}.icon-blue{background:var(--color-primary-100);color:var(--color-primary)}.icon-teal{background:var(--color-teal-50);color:var(--color-teal-dark)}.icon-amber{background:var(--color-orange-50);color:var(--color-orange)}.icon-purple{background:var(--color-accent-50);color:var(--color-accent)}.icon-indigo{background:var(--color-indigo-50);color:var(--color-indigo)}.icon-rose{background:var(--color-pink-50);color:var(--color-pink)}.icon-green{background:var(--color-success-bg);color:var(--color-success)}.icon-emerald{background:#ecfdf5;color:#059669}.icon-dark{background:#f1f5f9;color:#334155}.rpdlc-meta{flex:1 1;min-width:0}.rpdlc-title{color:var(--text-primary);font-size:var(--text-base);font-weight:700;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rpdlc-fmts{display:flex;gap:4px}.fmt-badge{align-items:center;border-radius:var(--radius-sm);display:inline-flex;font-size:var(--text-2xs);font-weight:800;gap:3px;letter-spacing:.4px;padding:1px 7px}.fmt-xl{background:var(--color-green-100);color:var(--color-green-700)}.fmt-pdf{background:var(--color-red-50);color:var(--color-red-dark)}.rpdlc-body{flex:1 1;padding:var(--space-4) var(--space-5)}.rpdlc-desc{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.6;margin:0}.rpdlc-footer{border-top:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:8px;padding:var(--space-3) var(--space-5) var(--space-4)}.rp-stats-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-3)}.rp-stat-card{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;gap:10px;padding:8px 10px;transition:box-shadow var(--transition-fast)}.rp-stat-card:hover{box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm,0 1px 3px #0000000f)}.rsc-icon{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.rp-stat-blue .rsc-icon{background:var(--color-primary-100);color:var(--color-primary)}.rp-stat-green .rsc-icon{background:var(--color-green-100);color:var(--color-green-600)}.rp-stat-red .rsc-icon{background:var(--color-red-50);color:var(--color-red-dark)}.rp-stat-amber .rsc-icon{background:var(--color-orange-50);color:var(--color-orange)}.rsc-data{min-width:0}.rsc-val{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;line-height:1.1}.rsc-lbl{color:var(--text-secondary);font-size:9px;font-weight:500;letter-spacing:.5px;margin-top:1px;text-transform:uppercase}.rp-table-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden}.rptc-header{align-items:center;background:var(--surface-secondary);border-bottom:1px solid var(--border-default);display:flex;gap:var(--space-4);justify-content:space-between;padding:var(--space-4) var(--space-5)}.rptc-header h3{color:var(--text-primary);font-size:var(--text-md);font-weight:700;margin:0}.report-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.report-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.report-table thead tr{background:var(--surface-secondary);border-bottom:2px solid var(--border-default)}.report-table th{color:var(--text-secondary);font-size:var(--text-sm);font-weight:700;letter-spacing:.5px;text-align:left;text-transform:uppercase}.report-table td,.report-table th{padding:10px 14px;white-space:nowrap}.report-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle}.report-table tbody tr:hover{background:var(--surface-secondary)}.report-table tbody tr:last-child td{border-bottom:none}.status-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-sm);font-weight:600;letter-spacing:.2px;padding:3px 9px}.status-badge.active{background:var(--color-green-100);color:var(--color-green-700)}.status-badge.inactive{background:var(--color-red-50);color:var(--color-red-dark)}.status-badge.warning{background:var(--color-orange-50);color:var(--color-orange)}.status-badge.leave{background:var(--color-accent-50);color:var(--color-accent-dark)}.status-badge.holiday{background:var(--color-blue-50);color:var(--color-blue-dark)}.report-empty-state{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;gap:var(--space-3);justify-content:center;padding:64px var(--space-6);text-align:center}.report-empty-state h4{color:var(--text-secondary);font-size:var(--text-md);font-weight:600;margin:0}.report-empty-state p{color:var(--text-tertiary);font-size:var(--text-sm);margin:0;max-width:380px}.rp-emp-selector{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-bottom:var(--space-5);overflow:hidden}.rpes-header{align-items:center;background:var(--surface-secondary);border-bottom:1px solid var(--border-default);color:var(--text-secondary);display:flex;font-size:var(--text-xs);font-weight:700;gap:7px;letter-spacing:.7px;padding:var(--space-3) var(--space-5);text-transform:uppercase}.rpes-body{align-items:flex-end;display:flex;flex-wrap:wrap;gap:var(--space-5);padding:var(--space-5)}.rpes-field{flex:1 1;max-width:400px;min-width:260px}.rpes-info{align-items:center;color:var(--text-tertiary);display:flex;flex:1 1;font-size:var(--text-sm);gap:var(--space-2);padding-bottom:8px}@media (max-width:1024px){.rp-stats-row{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.report-page{padding:var(--space-4)}.report-page-header{align-items:flex-start;flex-direction:column}.report-seg-ctrl{display:flex;flex-wrap:wrap;width:100%}.seg-btn{flex:1 1;justify-content:center;padding:8px 12px}.rfp-fields{flex-direction:column}.rfp-fields .filter-group{min-width:0;min-width:auto}.rp-stats-row{grid-template-columns:repeat(2,1fr)}.rp-dl-grid{grid-template-columns:1fr}}@media (max-width:480px){.rp-stats-row{grid-template-columns:1fr 1fr}.rph-badges{display:none}}.rp-tpl-section{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-top:24px;padding:16px 20px 20px}.rp-tpl-header{justify-content:space-between;margin-bottom:14px}.rp-tpl-header,.rp-tpl-title{align-items:center;display:flex}.rp-tpl-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:14px;font-weight:700;gap:8px}.rp-tpl-badge{background:#eef2ff;border-radius:10px;color:#6366f1;font-size:11px;font-weight:600;padding:2px 10px}.rp-tpl-manage-btn{background:#4d9fff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 16px;transition:background .15s}.rp-tpl-manage-btn:hover{background:#2563eb}.rp-tpl-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.rp-tpl-card{align-items:center;border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:10px 8px;position:relative;transition:box-shadow .15s,border-color .15s}.rp-tpl-card.configured{background:#f0fdf4;border-color:#a7f3d0}.rp-tpl-card.empty{background:#fff;background:var(--surface-primary,#fff)}.rp-tpl-card:hover{box-shadow:0 2px 8px #00000014}.rp-tpl-dot{align-items:center;border:1px solid #e2e8f0;border-radius:6px;display:flex;height:28px;justify-content:center;width:48px}.rp-tpl-label{color:#475569;color:var(--text-secondary,#475569);font-size:10px;font-weight:600;line-height:1.3;text-align:center}.rp-tpl-check{color:#10b981;font-size:10px;font-weight:800;position:absolute;right:7px;top:5px}.st-kpis{grid-gap:14px;grid-gap:var(--space-3-5,14px);gap:14px;gap:var(--space-3-5,14px);margin-bottom:16px;margin-bottom:var(--space-4,16px)}.st-kpi{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:12px;border-radius:var(--radius-xl,12px);padding:16px 16px 12px;padding:var(--space-4,16px) var(--space-4,16px) var(--space-3,12px)}.st-kpi:hover{box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md,0 4px 12px #00000014)}.st-kpi-accent{border-radius:12px 12px 0 0;border-radius:var(--radius-xl,12px) var(--radius-xl,12px) 0 0}.st-kpi-icon{border-radius:8px;border-radius:var(--radius-lg,8px);margin-bottom:8px;margin-bottom:var(--space-2,8px)}.st-kpi-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.st-kpi-value{color:#1e293b;color:var(--text-primary,#1e293b);font-family:JetBrains Mono,monospace;font-family:var(--font-mono,"JetBrains Mono",monospace)}.st-search-bar{margin-bottom:12px;margin-bottom:var(--space-3,12px)}.st-search-wrap{align-items:center;background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:8px;border-radius:var(--radius-lg,8px);display:flex;gap:8px;max-width:320px;padding:8px 12px}.st-search-wrap input{background:#0000;border:none;color:#334155;color:var(--text-primary,#334155);flex:1 1;font-size:13px}.st-search-icon{color:#94a3b8;color:var(--text-tertiary,#94a3b8);flex-shrink:0}.st-table-wrap{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:12px;border-radius:var(--radius-xl,12px);overflow-x:auto}.st-table{border-collapse:collapse;font-size:13px;width:100%}.st-table th{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-default,#e2e8f0);color:#475569;color:var(--text-secondary,#475569);font-size:11px;font-weight:600;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.st-table td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-subtle,#f1f5f9);color:#334155;color:var(--text-primary,#334155);padding:12px 14px}.st-table tr:hover{background:#f8fafc;background:var(--surface-secondary,#f8fafc)}.st-table tr:last-child td{border-bottom:none}.st-name-cell{min-width:180px}.st-name-row{align-items:center;display:flex;gap:6px}.st-star-icon{color:#d97706;flex-shrink:0}.st-name{font-weight:600}.st-desc{color:#94a3b8;color:var(--text-tertiary,#94a3b8);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.st-count-badge{align-items:center;background:#4d9fff1a;border-radius:50%;color:#4d9fff;display:inline-flex;font-weight:700;height:28px;justify-content:center;width:28px}.st-breakdown,.st-count-badge{font-family:monospace;font-family:var(--font-mono,monospace);font-size:12px}.st-breakdown{color:#475569;color:var(--text-secondary,#475569);font-weight:600}.st-default-badge{background:#fef3c7;border-radius:10px;color:#d97706;font-size:11px;font-weight:600;padding:2px 10px}.st-status-active{color:#059669;font-size:12px;font-weight:600}.st-status-inactive{color:#94a3b8;font-size:12px;font-weight:600}.st-actions{display:flex;gap:4px}.st-actions button{background:none;border:none;border-radius:4px;color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;padding:4px;transition:.15s}.st-actions button:hover{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);color:#334155;color:var(--text-primary,#334155)}.st-actions button.danger:hover{background:#fef2f2;color:#dc2626}.st-footer{font-size:12px;padding:12px 0}.st-empty,.st-footer{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.st-empty{padding:48px 20px;text-align:center}.st-empty p:first-child{font-size:15px;margin-bottom:4px}.st-empty p:last-child{font-size:13px}.st-form-section{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-subtle,#f1f5f9);color:#475569;color:var(--text-secondary,#475569);display:flex;font-size:13px;font-weight:700;justify-content:space-between;margin-top:8px;padding:10px 0 6px}.st-form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-top:10px}.st-toggle-row{display:flex;flex-wrap:wrap;gap:20px;margin-top:10px}.st-add-comp-btn{align-items:center;background:#4d9fff14;border:none;border-radius:4px;color:#4d9fff;cursor:pointer;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:4px 10px;transition:.15s}.st-add-comp-btn:hover{background:#4d9fff29}.st-comp-table-wrap{border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:8px;margin-top:10px;overflow-x:auto}.st-comp-table{border-collapse:collapse;font-size:12px;width:100%}.st-comp-table th{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-default,#e2e8f0);color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:10px;font-weight:600;letter-spacing:.5px;padding:8px 10px;text-align:left;text-transform:uppercase}.st-comp-table td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-subtle,#f1f5f9);padding:6px 8px}.st-comp-table tr:last-child td{border-bottom:none}.st-comp-select{min-width:200px}.st-na{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:12px}.st-remove-btn{background:none;border:none;border-radius:4px;color:#dc2626;cursor:pointer;padding:4px;transition:.15s}.st-remove-btn:hover{background:#fef2f2}.st-comp-empty{border:1px dashed #e2e8f0;border:1px dashed var(--border-default,#e2e8f0);color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:13px;margin-top:10px;padding:24px 16px;text-align:center}.st-comp-empty,.st-comp-summary{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-radius:8px}.st-comp-summary{color:#475569;color:var(--text-secondary,#475569);display:flex;font-size:12px;gap:20px;margin-top:8px;padding:10px 14px}.st-comp-summary strong{color:#1e293b;color:var(--text-primary,#1e293b);font-family:monospace;font-family:var(--font-mono,monospace)}@media (max-width:768px){.st-kpis{grid-template-columns:repeat(2,1fr)}.st-form-grid{grid-template-columns:1fr}.st-header,.st-toolbar{align-items:flex-start;flex-direction:column;gap:8px}.st-table-wrap,.st-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.st-tabs{flex-wrap:nowrap}.st-comp-summary{flex-wrap:wrap;gap:10px}}@media (max-width:480px){.st-kpis{grid-template-columns:1fr}}.st-section-divider{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-default,#e2e8f0);display:flex;flex-direction:column;gap:4px;margin:28px 0 16px;padding-bottom:10px}.st-section-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:14px;font-weight:700}.st-section-sub{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:12px}.st-pdf-reports-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:32px}.st-pdf-card{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:10px;overflow:hidden;padding:14px 14px 12px;position:relative;transition:transform .2s,box-shadow .2s}.st-pdf-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.st-pdf-card-accent{border-radius:10px 10px 0 0;height:3px;left:0;position:absolute;right:0;top:0}.st-pdf-card-header{align-items:flex-start;display:flex;gap:10px;margin-bottom:8px}.st-pdf-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:16px;height:36px;justify-content:center;width:36px}.st-pdf-title-wrap{display:flex;flex-direction:column;gap:4px}.st-pdf-label{color:#1e293b;color:var(--text-primary,#1e293b);font-size:13px;font-weight:700;line-height:1.3}.st-pdf-tags{display:flex;flex-wrap:wrap;gap:4px}.st-pdf-tag{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border-radius:10px;color:#475569;color:var(--text-secondary,#475569);font-size:10px;font-weight:600;padding:1px 6px}.st-pdf-desc{color:#64748b;color:var(--text-secondary,#64748b);font-size:11.5px;line-height:1.6;margin:0 0 10px}.st-pdf-formats{display:flex;flex-wrap:wrap;gap:6px}.st-pdf-fmt-badge{border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.02em;padding:2px 8px}@media (max-width:768px){.st-pdf-reports-grid{grid-template-columns:1fr}}.st-cat-badge{border-radius:4px;display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.02em;padding:2px 8px;white-space:nowrap}.st-cat-default{background:#f1f5f9;color:#475569}.st-cat-worker{background:#fef3c7;color:#92400e}.st-cat-staff{background:#dbeafe;color:#1e40af}.st-cat-exempted-staff{background:#f0fdf4;color:#166534}.st-category-info{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;color:#0c4a6e;font-size:12.5px;margin-bottom:12px;padding:10px 14px}.st-category-info p{margin:0}.st-model-hint{color:#64748b;font-style:italic;margin-top:3px}.field-error,.st-model-hint{display:block;font-size:11px}.field-error{color:#dc2626;color:var(--color-red-dark,#dc2626);line-height:1.3;margin-top:2px}.emp-form-row:has(.field-error) input,.emp-form-row:has(.field-error) textarea{border-color:#dc2626;border-color:var(--color-red-dark,#dc2626)}.company-cards-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));padding:4px 0}.company-cards-empty{color:var(--text-secondary);font-size:var(--text-base);padding:48px 16px;text-align:center}.company-card{background:var(--surface-primary);background:var(--card-bg,var(--surface-primary));border:1px solid var(--border-color,var(--border-default));border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:0;transition:box-shadow .2s,transform .15s}.company-card:hover{box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.company-card-header{align-items:center;display:flex;gap:14px;padding:20px 20px 14px}.company-card-icon{align-items:center;background:linear-gradient(135deg,var(--color-indigo),var(--color-indigo-light));border-radius:var(--radius-xl);color:var(--text-inverse);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.company-card-title{display:flex;flex-direction:column;gap:4px;min-width:0}.company-card-title h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.company-card-body{flex:1 1;padding:0 20px 14px}.company-card-info{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--text-sm);gap:8px;padding:6px 0}.company-card-info svg{flex-shrink:0;opacity:.5}.company-card-label{font-weight:500;min-width:56px}.company-card-value{color:var(--text-primary);font-weight:600}.company-card-stats{display:flex;gap:12px;margin-top:12px}.company-stat{background:var(--color-primary-50);background:var(--hover-bg,var(--color-primary-50));border-radius:var(--radius-xl);flex:1 1;padding:10px 12px;text-align:center}.company-stat-num{color:var(--text-primary);display:block;font-size:var(--text-2xl);font-weight:800;line-height:1.2}.company-stat-label{color:var(--text-secondary);display:block;font-size:var(--text-sm);font-weight:500;letter-spacing:.5px;margin-top:2px;text-transform:uppercase}.company-card-footer{align-items:center;background:#f9fafb;background:var(--hover-bg,#f9fafb);border-top:1px solid var(--border-color,var(--border-default));display:flex;justify-content:space-between;padding:12px 20px}.company-card-settings{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-indigo);color:var(--primary,var(--color-indigo));cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:600;gap:6px;padding:4px 8px;transition:background .15s}.company-card-settings:hover{background:#6366f114}.company-card-toggle{background:none;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-lg);padding:4px 8px;transition:background .15s}.company-card-toggle:hover{background:#0000000d}.btn-danger{align-items:center;border:1px solid var(--color-red-dark);border-radius:var(--radius-md);color:var(--text-inverse);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:600;gap:6px;padding:6px 14px;transition:background .15s}.btn-danger,.btn-danger:hover:not(:disabled){background:var(--color-red-dark)}.btn-danger:disabled{cursor:not-allowed;opacity:.45}.st-kpis{grid-gap:var(--space-3-5);display:grid;gap:var(--space-3-5);grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-4)}.st-kpi{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;overflow:hidden;padding:var(--space-4) var(--space-4) var(--space-3);position:relative;transition:transform .2s,box-shadow .2s}.st-kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.st-kpi-accent{border-radius:var(--radius-xl) var(--radius-xl) 0 0;height:3px;left:0;position:absolute;right:0;top:0}.st-kpi-icon{align-items:center;border-radius:var(--radius-lg);display:flex;font-size:16px;height:36px;justify-content:center;margin-bottom:var(--space-2);width:36px}.st-kpi-label{color:var(--text-tertiary);font-size:10px;font-weight:700;letter-spacing:.8px;margin-bottom:2px;text-transform:uppercase}.st-kpi-value{color:var(--text-primary);font-family:var(--font-mono);font-size:24px;font-weight:800;line-height:1}.st-tabs{border-bottom:1px solid var(--border-default);display:flex;gap:0;margin-bottom:var(--space-4)}.st-tab{align-items:center;background:#0000;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;gap:6px;padding:var(--space-2) var(--space-4);position:relative;transition:color var(--transition-fast);white-space:nowrap}.st-tab:hover{color:var(--text-primary)}.st-tab.active{color:var(--color-teal)}.st-tab.active:after{background:var(--color-teal);border-radius:2px 2px 0 0;bottom:-1px;content:"";height:2px;left:0;position:absolute;right:0}.st-tab-count{background:var(--surface-tertiary);border-radius:10px;color:var(--text-secondary);font-family:var(--font-mono);font-size:10px;font-weight:700;padding:1px 6px}.st-tab.active .st-tab-count{background:#00c9a71f;color:var(--color-teal)}.st-search-bar{align-items:center;display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.st-search-wrap{flex:1 1;max-width:340px;position:relative}.st-search-icon{color:var(--text-tertiary);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.st-search-wrap input{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-sizing:border-box;color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;padding:7px 12px 7px 34px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.st-search-wrap input:focus{border-color:var(--color-teal);box-shadow:0 0 0 3px #00c9a71a}.st-grid{grid-gap:var(--space-3-5);display:grid;gap:var(--space-3-5);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));margin-bottom:var(--space-4)}.st-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;overflow:hidden;position:relative;transition:transform .2s,box-shadow .2s,border-color .2s}.st-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.st-card.selected{border-color:var(--color-teal);box-shadow:0 0 0 2px #00c9a726,var(--shadow-md)}.st-card-head{gap:var(--space-2-5);margin-bottom:var(--space-3);padding:var(--space-4) var(--space-4) 0}.st-card-head,.st-card-icon{align-items:center;display:flex}.st-card-icon{border-radius:var(--radius-lg);flex-shrink:0;font-size:14px;height:34px;justify-content:center;width:34px}.st-card-title{flex:1 1;min-width:0}.st-card-title h4{color:var(--text-primary);font-size:var(--text-sm);font-weight:700;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.st-card-title span{color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500}.st-card-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.st-card:hover .st-card-actions{opacity:1}.st-card-actions button{align-items:center;background:none;border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;display:flex;height:26px;justify-content:center;transition:all var(--transition-fast);width:26px}.st-card-actions button:hover{background:var(--surface-tertiary);color:var(--text-primary)}.st-card-actions button.danger:hover{background:var(--color-red-50);border-color:var(--color-red-light);color:var(--color-red-dark)}.st-card-body{padding:0 var(--space-4) var(--space-3)}.st-card-body .v3-stat{margin-bottom:4px}.st-card-badge{border-radius:10px;display:inline-block;font-size:10px;font-weight:700;letter-spacing:.02em;padding:2px 8px}.st-card-accent{height:3px}.st-footer{font-size:var(--text-xs);font-weight:500;justify-content:space-between;padding:var(--space-3) 0}.st-empty,.st-footer{align-items:center;color:var(--text-tertiary);display:flex}.st-empty{flex-direction:column;grid-column:1/-1;justify-content:center;padding:var(--space-6) var(--space-4)}.st-empty p{font-size:var(--text-sm);margin:4px 0 0}.st-empty p:last-child{font-size:var(--text-xs)}@media (max-width:900px){.st-kpis{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.st-kpis{grid-template-columns:1fr 1fr}.st-grid{grid-template-columns:1fr}.st-tabs{overflow-x:auto}}@media (max-width:480px){.st-kpis{grid-template-columns:1fr}.salary-type-header{align-items:flex-start;flex-direction:column;gap:8px}}.payslip-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#00000080;display:flex;inset:0;justify-content:center;padding:var(--space-4);position:fixed;z-index:1000}.payslip-modal{animation:slideUp .25s ease-out;background:var(--surface-primary);border-radius:var(--radius-lg);box-shadow:0 20px 60px #00000040;max-height:90vh;max-width:720px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.payslip-header{align-items:flex-start;background:linear-gradient(135deg,#eef2ff 0,var(--surface-primary) 100%);background:linear-gradient(135deg,var(--color-primary-50,#eef2ff) 0,var(--surface-primary) 100%);border-bottom:2px solid #6366f1;border-bottom:2px solid var(--color-primary-500,#6366f1);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;justify-content:space-between;padding:var(--space-5) var(--space-6)}.payslip-company{color:var(--text-primary);font-size:18px;font-size:var(--text-lg,18px);font-weight:700;margin:0 0 var(--space-1) 0}.payslip-period{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--text-sm);gap:var(--space-2);margin:0}.payslip-format-badge{background:#e0e7ff;background:var(--color-primary-100,#e0e7ff);border-radius:999px;color:#4338ca;color:var(--color-primary-700,#4338ca);display:inline-block;font-size:10px;font-weight:600;letter-spacing:.04em;padding:1px 7px;text-transform:uppercase}.payslip-close-btn{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;padding:var(--space-1);transition:all var(--transition-fast)}.payslip-close-btn:hover{background:#f3f4f6;background:var(--color-gray-100,#f3f4f6);color:var(--text-primary)}.payslip-employee-info{grid-gap:var(--space-2) var(--space-6);background:#f9fafb;background:var(--color-gray-50,#f9fafb);border-bottom:1px solid var(--border-default);display:grid;gap:var(--space-2) var(--space-6);grid-template-columns:1fr 1fr;padding:var(--space-4) var(--space-6)}.payslip-info-row{display:flex;flex-direction:column;gap:2px}.info-label{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.info-value{color:var(--text-primary);font-size:var(--text-sm);font-weight:500}.payslip-table-wrapper{padding:var(--space-4) var(--space-6)}.payslip-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.payslip-table th{border-bottom:2px solid var(--border-default);color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.04em;text-align:left;text-transform:uppercase}.payslip-table td,.payslip-table th{padding:var(--space-2) var(--space-3)}.payslip-table td{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);color:var(--text-primary)}.payslip-table .amount-col{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;min-width:90px;text-align:right}.payslip-totals-row td{border-bottom:none;border-top:2px solid var(--border-default);padding-top:var(--space-3)}.payslip-net-pay{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);background:linear-gradient(135deg,var(--color-primary-500,#6366f1) 0,var(--color-primary-600,#4f46e5) 100%);border-radius:var(--radius-md);color:var(--surface-primary);display:flex;font-size:16px;font-size:var(--text-base,16px);font-weight:600;justify-content:space-between;margin:0 var(--space-6);padding:var(--space-4)}.net-pay-amount{font-size:20px;font-size:var(--text-xl,20px);font-weight:700}.payslip-actions{border-top:1px solid var(--border-default);display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-4) var(--space-6)}.payslip-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:var(--space-3);justify-content:center;min-height:200px;padding:48px;padding:var(--space-8,48px)}.payslip-salary-structure{border-bottom:1px solid var(--border-default);padding:var(--space-3) var(--space-6)}.payslip-salary-structure .info-value{color:#4f46e5;color:var(--color-primary-600,#4f46e5);font-weight:600}@media (max-width:640px){.payslip-modal{max-width:100%}.payslip-employee-info{grid-template-columns:1fr}.payslip-actions,.payslip-header,.payslip-table-wrapper{padding-left:var(--space-4);padding-right:var(--space-4)}.payslip-net-pay{margin:0 var(--space-4)}}.salary-report-container{animation:fadeInUp .3s ease-out;padding:var(--space-6);position:relative}.sr-branch-loading{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#ffffffd1;border-radius:10px;display:flex;flex-direction:column;gap:14px;inset:0;justify-content:center;pointer-events:all;position:absolute;z-index:50}.sr-branch-spinner{animation:sr-spin .7s linear infinite;border:3px solid #e5e7eb;border-top-color:#0ea5e9;border:3px solid var(--ss-border,#e5e7eb);border-radius:50%;border-top-color:var(--ss-blue,#0ea5e9);height:36px;width:36px}.sr-branch-loading-text{color:#374151;color:var(--ss-text-2,#374151);font-size:13px;font-weight:500}.sr-tab-switcher{background:#f3f4f6;background:var(--ss-bg,#f3f4f6);border:1px solid #e5e7eb;border:1px solid var(--ss-border,#e5e7eb);border-radius:8px;display:flex;gap:2px;padding:3px}.sr-tab-btn{background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--ss-text-3,#6b7280);cursor:pointer;font-size:13px;font-weight:500;padding:6px 18px;transition:all .15s;white-space:nowrap}.sr-tab-btn:hover{background:#0000000a;color:#111827;color:var(--ss-text-1,#111827)}.sr-tab-btn--on{background:#fff;background:var(--ss-bg-card,#fff);box-shadow:0 1px 3px #0000001a;color:#0ea5e9;color:var(--ss-blue,#0ea5e9);font-weight:600}.salary-report-header{align-items:center;border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;margin-bottom:var(--space-6);padding-bottom:var(--space-4)}.salary-report-header h2{color:var(--text-primary);font-size:var(--text-xl);font-weight:600;margin:0 0 var(--space-1) 0}.reports-title-bar{margin-bottom:var(--space-4)}.reports-title-bar h3{color:var(--text-secondary);font-size:var(--text-sm);font-weight:600;letter-spacing:.04em;text-transform:uppercase}.salary-report-container .report-filters{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-bottom:var(--space-5);padding:var(--space-5)}.salary-report-container .filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-4)}.salary-report-container .filter-row:last-child{margin-bottom:0}.salary-report-container .filter-group{flex:1 1;min-width:130px}.salary-report-container .filter-group input,.salary-report-container .filter-group select{width:100%}.report-types-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:var(--space-5)}.report-type-card{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.report-type-card:hover{background:var(--color-primary-50);border-color:var(--color-primary-200)}.report-type-card label{color:var(--text-primary);cursor:pointer;font-size:var(--text-sm);font-weight:500;-webkit-user-select:none;user-select:none}.salary-report-actions{border-top:1px solid var(--border-default);display:flex;gap:var(--space-3);padding-top:var(--space-4)}@media (max-width:768px){.salary-report-container{padding:var(--space-4)}.salary-report-container .filter-row{flex-direction:column}.report-types-grid{grid-template-columns:1fr 1fr}}@media (max-width:480px){.report-types-grid{grid-template-columns:1fr}}.export-format-section{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-bottom:var(--space-4);padding:var(--space-4) var(--space-5)}.export-format-title{color:var(--text-secondary);font-size:var(--text-sm);font-weight:600;letter-spacing:.04em;margin:0 0 var(--space-3) 0;text-transform:uppercase}.export-format-options{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-3)}.export-format-card{align-items:center;background:#f9fafb;background:var(--color-gray-50,#f9fafb);border:2px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:500;gap:var(--space-2);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.export-format-card:has(input:checked){background:#eef2ff;background:var(--color-primary-50,#eef2ff);border-color:#6366f1;border-color:var(--color-primary-500,#6366f1);color:#4338ca;color:var(--color-primary-700,#4338ca)}.export-format-card input[type=checkbox]{accent-color:#6366f1;accent-color:var(--color-primary-500,#6366f1);cursor:pointer;flex-shrink:0;height:16px;width:16px}.export-format-note{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:11px;font-style:italic;margin:var(--space-2) 0 0 0}.sr-tab-bar{background:#f3f4f6;background:var(--color-gray-100,#f3f4f6);border-radius:var(--radius-md);display:flex;gap:var(--space-1);padding:3px}.sr-tab{border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;font-size:var(--text-sm);font-weight:500;gap:var(--space-2);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.sr-tab:hover{color:var(--text-primary)}.sr-tab-active{background:var(--surface-primary);box-shadow:0 1px 3px #00000014;color:#4f46e5;color:var(--color-primary-600,#4f46e5)}.sr-analytics{animation:fadeInUp .2s ease-out}.sr-filter-bar{align-items:center;display:flex;gap:var(--space-3);margin-bottom:var(--space-5)}.sr-filter-bar .filter-select{max-width:180px}.sr-loading-icon{color:#6366f1;color:var(--color-primary-500,#6366f1)}.sr-kpi-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-3)}.sr-kpi-card{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;gap:10px;padding:8px 10px;transition:box-shadow var(--transition-fast)}.sr-kpi-card:hover{box-shadow:0 4px 12px #0000000f}.sr-kpi-icon{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.sr-kpi-gross .sr-kpi-icon{background:#dbeafe;color:#2563eb}.sr-kpi-net .sr-kpi-icon{background:#d1fae5;color:var(--color-green-600)}.sr-kpi-avg .sr-kpi-icon{background:#fef3c7;color:#d97706}.sr-kpi-emp .sr-kpi-icon{background:#ede9fe;color:#7c3aed}.sr-kpi-content{display:flex;flex-direction:column}.sr-kpi-label{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.sr-kpi-value{color:var(--text-primary);font-size:16px;font-weight:700}.sr-charts-row{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:1.2fr .8fr;margin-bottom:var(--space-5)}.sr-chart-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5)}.sr-chart-title{color:var(--text-primary);font-size:var(--text-sm);font-weight:600;margin:0 0 var(--space-4) 0}.sr-empty{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:var(--text-sm);padding:var(--space-6) 0;text-align:center}.sr-bar-chart{align-items:flex-end;display:flex;gap:var(--space-3);height:200px;padding-bottom:var(--space-2)}.sr-bar-group{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100%}.sr-bar-wrapper{align-items:flex-end;display:flex;flex:1 1;gap:4px;justify-content:center;width:100%}.sr-bar{border-radius:4px 4px 0 0;min-height:4px;transition:height .4s ease;width:18px}.sr-bar-gross{background:#818cf8;background:var(--color-primary-400,#818cf8)}.sr-bar-net{background:var(--color-green)}.sr-bar-label{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:var(--text-2xs);margin-top:var(--space-1);white-space:nowrap}.sr-chart-legend{display:flex;gap:var(--space-4);justify-content:center;margin-top:var(--space-3)}.sr-legend-item{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--text-xs);gap:var(--space-1)}.sr-legend-dot{border-radius:50%;display:inline-block;height:10px;width:10px}.sr-legend-gross{background:#818cf8;background:var(--color-primary-400,#818cf8)}.sr-legend-net{background:var(--color-green)}.sr-dept-chart{flex-direction:column}.sr-dept-chart,.sr-dept-row{display:flex;gap:var(--space-3)}.sr-dept-row{align-items:center}.sr-dept-name{color:var(--text-primary);flex-shrink:0;font-size:var(--text-sm);font-weight:500;min-width:100px;text-align:right}.sr-dept-bar-track{background:#f3f4f6;background:var(--color-gray-100,#f3f4f6);border-radius:var(--radius-sm);flex:1 1;height:22px;overflow:hidden}.sr-dept-bar-fill{background:linear-gradient(90deg,#818cf8,#6366f1);background:linear-gradient(90deg,var(--color-primary-400,#818cf8) 0,var(--color-primary-500,#6366f1) 100%);border-radius:var(--radius-sm);height:100%;min-width:4px;transition:width .5s ease}.sr-dept-amount{font-feature-settings:"tnum";color:var(--text-secondary);font-size:var(--text-xs);font-variant-numeric:tabular-nums;font-weight:600;min-width:60px}.sr-payslips-section{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5)}.sr-payslips-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:space-between;margin-bottom:var(--space-4)}.sr-search-box{align-items:center;background:#f9fafb;background:var(--color-gray-50,#f9fafb);border:1px solid var(--border-default);border-radius:var(--radius-md);display:flex;gap:var(--space-2);max-width:260px;padding:var(--space-2) var(--space-3)}.sr-search-box input{background:#0000;border:none;color:var(--text-primary);font-size:var(--text-sm);outline:none;width:100%}.sr-search-box svg{color:#9ca3af;color:var(--text-muted,#9ca3af);flex-shrink:0}.sr-payslip-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.sr-payslip-card{background:#f9fafb;background:var(--color-gray-50,#f9fafb);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-4);transition:all var(--transition-fast)}.sr-payslip-card:hover{border-color:#c7d2fe;border-color:var(--color-primary-200,#c7d2fe);box-shadow:0 2px 8px #0000000a}.sr-payslip-card-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--space-3)}.sr-payslip-emp{display:flex;flex-direction:column}.sr-emp-name{color:var(--text-primary);font-size:var(--text-sm);font-weight:600}.sr-emp-meta{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:var(--text-xs)}.sr-month-tag{background:#eef2ff;background:var(--color-primary-50,#eef2ff);border-radius:var(--radius-sm);color:#4f46e5;color:var(--color-primary-600,#4f46e5);font-size:var(--text-sm);font-weight:600;padding:2px 8px;text-transform:uppercase}.sr-payslip-amounts{display:flex;gap:var(--space-4);margin-bottom:var(--space-3)}.sr-payslip-amounts>div{display:flex;flex-direction:column}.sr-amount-label{color:#9ca3af;color:var(--text-muted,#9ca3af);text-transform:uppercase}.sr-amount-label,.sr-amount-value{font-size:var(--text-sm);font-weight:600}.sr-amount-value{font-feature-settings:"tnum";color:var(--text-primary);font-variant-numeric:tabular-nums}.sr-amount-net{color:var(--color-green-600)}.sr-view-btn{align-items:center;background:#0000;border:1px solid #c7d2fe;border:1px solid var(--color-primary-200,#c7d2fe);border-radius:var(--radius-md);color:#4f46e5;color:var(--color-primary-600,#4f46e5);cursor:pointer;display:flex;flex:1 1;font-size:var(--text-sm);font-weight:500;gap:var(--space-2);justify-content:center;padding:var(--space-2);transition:all var(--transition-fast)}.sr-view-btn:hover{background:#eef2ff;background:var(--color-primary-50,#eef2ff);border-color:#818cf8;border-color:var(--color-primary-400,#818cf8)}.sr-download-btn,.sr-payslip-actions{display:flex;gap:var(--space-2)}.sr-download-btn{align-items:center;background:#0000;border:1px solid var(--color-green-100);border-radius:var(--radius-md);color:var(--color-green-600);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:500;justify-content:center;padding:var(--space-2);transition:all var(--transition-fast)}.sr-download-btn:hover{background:var(--color-green-50);border-color:var(--color-green)}.sr-download-btn:disabled{cursor:not-allowed;opacity:.5}.sr-email-btn{align-items:center;background:#0000;border:1px solid var(--color-indigo-light);border-radius:var(--radius-md);color:var(--color-indigo);cursor:pointer;display:flex;flex:1 1;font-size:var(--text-sm);font-weight:500;gap:var(--space-2);justify-content:center;padding:var(--space-2);transition:all var(--transition-fast)}.sr-email-btn:hover{background:var(--color-indigo-50);border-color:var(--color-indigo-light)}.sr-email-btn:disabled{cursor:not-allowed;opacity:.5}.sr-email-btn.sr-email-sent{background:var(--color-green-50);border-color:var(--color-green-100);color:var(--color-green-600)}.sr-email-btn.sr-email-failed{background:#fef2f2;border-color:var(--color-red-light);color:var(--color-red-dark)}.sr-format-row{padding:0 0 var(--space-2) 0}.sr-format-select{background:#f9fafb;background:var(--surface-secondary,#f9fafb);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:var(--text-sm);font-weight:500;padding:var(--space-1) var(--space-2);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.sr-format-select:hover{border-color:#818cf8;border-color:var(--color-primary-400,#818cf8)}.sr-format-select:focus{border-color:#6366f1;border-color:var(--color-primary-500,#6366f1);box-shadow:0 0 0 2px #6366f126;outline:none}@media (max-width:1024px){.sr-kpi-grid{grid-template-columns:repeat(2,1fr)}.sr-charts-row{grid-template-columns:1fr}}@media (max-width:640px){.sr-kpi-grid,.sr-payslip-grid{grid-template-columns:1fr}.salary-report-header{align-items:flex-start;flex-direction:column;gap:var(--space-3)}}.sr-pagination{align-items:center;display:flex;gap:var(--space-4);justify-content:center;padding:var(--space-4) 0 var(--space-2)}.sr-page-btn{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.sr-page-btn:hover:not(:disabled){background:#eef2ff;background:var(--color-primary-50,#eef2ff);border-color:#818cf8;border-color:var(--color-primary-400,#818cf8);color:#4f46e5;color:var(--color-primary-600,#4f46e5)}.sr-page-btn:disabled{cursor:not-allowed;opacity:.4}.sr-page-info{color:var(--text-primary);font-size:var(--text-sm);font-weight:600}.sr-page-total{color:var(--text-secondary);font-weight:400}.sr-payslip-table-wrapper{border:1px solid var(--border-default);border-radius:var(--radius-md);max-height:520px;overflow-x:auto;overflow-y:auto}.sr-payslip-table{border-collapse:collapse;font-size:var(--text-xs);white-space:nowrap;width:100%}.sr-payslip-table thead tr:first-child th{background:var(--text-primary);border-right:1px solid #ffffff1f;color:var(--surface-secondary);font-size:var(--text-sm);font-weight:600;letter-spacing:.05em;padding:9px 12px;position:sticky;text-align:center;text-transform:uppercase;top:0;z-index:4}.sr-payslip-table thead tr:first-child th.sr-th-sticky{left:0;z-index:5}.sr-payslip-table thead tr:first-child th.sr-th-sticky-right{right:0;z-index:5}.sr-payslip-table thead tr:nth-child(2) th{background:var(--surface-tertiary);border-bottom:2px solid var(--border-strong);border-right:1px solid var(--border-default);color:var(--text-secondary);font-size:var(--text-2xs);font-weight:700;letter-spacing:.03em;padding:6px 10px;position:sticky;text-align:right;text-transform:uppercase;top:36px;z-index:3}.sr-th-group{border-bottom:none!important}.sr-th-group-earn{border-left:3px solid var(--color-indigo)!important}.sr-th-group-ded{border-left:3px solid var(--color-pink)!important}.sr-th-net{border-left:3px solid var(--color-green)!important}.sr-th-gross{border-left:2px solid var(--color-indigo-100)!important}.sr-th-ded{border-left:2px solid var(--color-pink-50)!important}.sr-th-center{text-align:center!important}.sr-th-sticky{left:0}.sr-th-sticky,.sr-th-sticky-right{position:sticky!important;z-index:2}.sr-th-sticky-right{right:0}.sr-th-emp{min-width:190px;text-align:left!important}.sr-table-row{border-bottom:1px solid var(--color-gray-100);transition:background .1s}.sr-table-row:hover{background:var(--color-indigo-50)}.sr-table-row:last-child{border-bottom:none}.sr-payslip-table td{border-right:1px solid var(--color-gray-100);padding:8px 10px;vertical-align:middle}.sr-td-emp.sr-th-sticky{background:#fff;background:var(--surface-primary,#fff);border-right:2px solid var(--border-default);min-width:190px}.sr-table-row:hover .sr-td-emp.sr-th-sticky{background:var(--color-indigo-50)}.sr-td-emp-inner{display:flex;flex-direction:column;gap:1px}.sr-td-empname{color:var(--text-primary);font-size:var(--text-xs);font-weight:600}.sr-td-empmeta{color:var(--text-tertiary);font-size:var(--text-sm)}.sr-td-empdesig{color:var(--text-secondary);font-size:var(--text-sm);font-style:italic}.sr-td-num{font-feature-settings:"tnum";color:var(--color-gray-700);font-variant-numeric:tabular-nums;text-align:right}.sr-td-center{text-align:center!important}.sr-td-days{align-items:center;display:flex;flex-direction:column;gap:1px}.sr-td-lop{color:var(--color-red);font-size:var(--text-2xs);font-weight:700}.sr-td-gross{border-left:2px solid var(--color-indigo-100)!important;color:var(--color-indigo);font-weight:700}.sr-td-ded{border-left:2px solid var(--color-pink-50)!important;color:var(--color-pink);font-weight:700}.sr-td-net{border-left:3px solid var(--color-success-border)!important;color:var(--color-green-600);font-size:var(--text-sm);font-weight:700}.sr-rpt-panel{background:#fff;background:var(--ss-bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--ss-border,#e5e7eb);border-radius:10px;margin-bottom:14px;padding:14px 18px 16px}.sr-rpt-panel-title{color:#6b7280;color:var(--ss-text-3,#6b7280);font-size:11px;font-weight:700;letter-spacing:.08em;margin-bottom:10px;text-transform:uppercase}.sr-rpt-panel-fields{align-items:flex-end;display:flex;flex-wrap:wrap;gap:10px}.sr-rpt-field{display:flex;flex-direction:column;gap:4px;min-width:120px}.sr-rpt-field label{color:#6b7280;color:var(--ss-text-3,#6b7280);font-size:11px;font-weight:600}.sr-rpt-field-action{min-width:auto}.sr-export-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.sr-export-label{color:#6b7280;color:var(--ss-text-3,#6b7280);font-size:11px;font-weight:700;letter-spacing:.07em;margin-right:4px;text-transform:uppercase}.sr-fmt-card{align-items:center;background:#f9fafb;background:var(--ss-bg,#f9fafb);border:1.5px solid #e5e7eb;border:1.5px solid var(--ss-border,#e5e7eb);border-radius:8px;color:#374151;color:var(--ss-text-2,#374151);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 14px;transition:all .15s;-webkit-user-select:none;user-select:none}.sr-fmt-card input[type=checkbox]{display:none}.sr-fmt-card--on,.sr-fmt-card:hover{background:#eef2ff;border-color:#6366f1;color:#4338ca}.sr-fmt-card--on{font-weight:600}.sr-fmt-icon{font-size:15px;line-height:1}.sr-export-note{color:#9ca3af;color:var(--ss-text-4,#9ca3af);font-size:11px;margin-left:8px}.sr-rpt-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));margin-bottom:18px}.sr-rpt-card{background:#f9fafb;background:var(--ss-bg,#f9fafb);border:1.5px solid #e5e7eb;border:1.5px solid var(--ss-border,#e5e7eb);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:12px 12px 10px;position:relative;transition:all .15s;-webkit-user-select:none;user-select:none}.sr-rpt-card:hover{border-color:#6366f1;box-shadow:0 2px 8px #6366f11f}.sr-rpt-card--on{box-shadow:0 2px 10px #6366f126}.sr-rpt-card-check{align-items:center;background:#fff;border:1.5px solid #d1d5db;border:1.5px solid var(--ss-border,#d1d5db);border-radius:4px;display:flex;font-size:13px;font-weight:700;height:18px;justify-content:center;position:absolute;right:10px;top:8px;transition:all .15s;width:18px}.sr-rpt-card--on .sr-rpt-card-check{background:currentColor;border-color:currentColor;color:#fff!important}.sr-rpt-card-icon{align-items:center;border-radius:8px;display:flex;font-size:18px;height:36px;justify-content:center;width:36px}.sr-rpt-card-label{color:#111827;color:var(--ss-text-1,#111827);font-size:13px;font-weight:600;line-height:1.3}.sr-rpt-card-fmts{display:flex;flex-wrap:wrap;gap:4px;min-height:20px}.sr-rpt-fmt-tag{border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.04em;padding:2px 6px}.sr-rpt-actions{background:#fff;background:var(--ss-bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--ss-border,#e5e7eb);border-radius:10px;flex-wrap:wrap;justify-content:space-between;padding:14px 16px}.sr-rpt-actions,.sr-rpt-actions-left{align-items:center;display:flex;gap:10px}.sr-rpt-actions-right{align-items:center;display:flex;gap:8px}.sr-rpt-sel-count{color:#374151;color:var(--ss-text-2,#374151);font-size:13px;font-weight:600}@media (max-width:640px){.sr-rpt-grid{grid-template-columns:repeat(2,1fr)}.sr-rpt-actions{align-items:stretch;flex-direction:column}.sr-rpt-actions-right{justify-content:flex-end}}.sr-td-actions{align-items:center;background:#fff;background:var(--surface-primary,#fff);border-left:2px solid var(--border-default);display:flex;gap:4px;justify-content:center;min-width:100px;padding:6px 8px}.sr-table-row:hover .sr-td-actions{background:var(--color-indigo-50)}.sr-act-btn{align-items:center;background:#0000;border:1.5px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;transition:all .15s;width:28px}.sr-act-btn:disabled{cursor:not-allowed;opacity:.45}.sr-act-view{border-color:var(--color-indigo-100);color:var(--color-indigo)}.sr-act-view:hover{background:var(--color-indigo-50);border-color:var(--color-indigo-light)}.sr-act-pdf{border-color:var(--color-green-100);color:var(--color-green-600)}.sr-act-pdf:hover{background:var(--color-success-bg);border-color:var(--color-green)}.sr-act-email{border-color:var(--color-blue-200);color:var(--color-blue-dark)}.sr-act-email:hover:not(:disabled){background:var(--color-blue-50);border-color:var(--color-blue-light)}.sr-act-sent{background:var(--color-green-600)!important;border-color:var(--color-green-600)!important}.sr-act-failed,.sr-act-sent{color:var(--text-inverse)!important}.sr-act-failed{background:var(--color-red)!important;border-color:var(--color-red)!important}.mark-attendance-container{animation:fadeInUp .3s ease-out;padding:var(--space-6)}.mark-attendance-toast{align-items:center;border:1px solid;border-radius:var(--radius-md);display:flex;gap:var(--space-2);margin-bottom:var(--space-4);padding:var(--space-2-5) var(--space-3)}.mark-attendance-toast p{flex:1 1;font-size:var(--text-sm);font-weight:500;margin:0}.toast-close,.toast-icon{align-items:center;display:flex;justify-content:center}.toast-close{background:#0000;border:none;border-radius:var(--radius-sm);color:inherit;cursor:pointer;height:22px;width:22px}.toast-close:hover{background:#00000014}.mark-attendance-toast--success{background:var(--color-green-50);border-color:var(--color-green-200);color:var(--color-green-700)}.mark-attendance-toast--error{background:var(--color-red-50);border-color:var(--color-red-light);color:var(--color-red-dark)}.mark-attendance-toast--info{background:var(--color-blue-50);border-color:var(--color-primary-200);color:var(--color-blue-dark)}.mark-attendance-header{align-items:center;border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;margin-bottom:var(--space-6);padding-bottom:var(--space-4)}.mark-attendance-header h2{align-items:center;color:var(--text-primary);display:flex;font-size:var(--text-xl);font-weight:600;gap:var(--space-2);margin:0 0 var(--space-1) 0}.attendance-filters{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-bottom:var(--space-5);padding:var(--space-5)}.attendance-filters .filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:var(--space-4)}.attendance-filters .filter-group{min-width:140px}.attendance-filters .filter-group select{width:100%}.attendance-content{display:flex;flex-direction:column;gap:var(--space-5)}.calendar-panel{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.calendar-header{align-items:center;background:var(--surface-secondary);border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;padding:var(--space-4) var(--space-5)}.calendar-header h3{align-items:center;color:var(--text-primary);font-size:var(--text-md);font-weight:600;margin:0}.calendar-actions,.calendar-header h3{display:flex;gap:var(--space-2)}.calendar-grid{grid-gap:0;display:grid;gap:0;grid-template-columns:repeat(7,1fr)}.calendar-day-header{background:var(--surface-secondary);border-bottom:1px solid var(--border-default);border-right:1px solid var(--border-light);color:var(--text-secondary);font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;padding:var(--space-2-5) var(--space-3);text-align:center;text-transform:uppercase}.calendar-day-header:last-child{border-right:none}.calendar-day-header.sunday{color:var(--color-red)}.calendar-day{background:var(--surface-primary);border-bottom:1px solid var(--border-light);border-right:1px solid var(--border-light);cursor:pointer;display:flex;flex-direction:column;gap:var(--space-1);min-height:72px;padding:var(--space-3);position:relative;transition:all var(--transition-fast)}.calendar-day:nth-child(7n){border-right:none}.calendar-day:hover{background:var(--color-primary-50)}.calendar-day.empty{background:var(--surface-secondary);cursor:default}.calendar-day.today{background:var(--color-primary-50)}.calendar-day.selected{box-shadow:inset 0 0 0 2px var(--color-primary);position:relative}.calendar-day.selected[style]{box-shadow:inset 0 0 0 2px #3b82f659}.calendar-day.selected:after{background:var(--color-primary);border-radius:50%;content:"";height:6px;position:absolute;right:4px;top:4px;width:6px}.calendar-day.disabled{cursor:not-allowed;opacity:.72;-webkit-user-select:none;user-select:none}.calendar-day.disabled:hover{background:inherit!important;box-shadow:none!important}.calendar-day.future-day{background:#f8fafc!important;border-left:none!important;cursor:not-allowed;opacity:.38;pointer-events:none}.calendar-day.future-day .day-number{color:#94a3b8}.calendar-day.future-day .day-status-badge{display:none}.calendar-day.future-day:hover{background:#f8fafc!important;box-shadow:none!important}.calendar-day.sunday{background:#f3f4f6!important;cursor:not-allowed}.calendar-day.sunday:hover{background:#f3f4f6!important;box-shadow:none!important}.calendar-day.sunday .day-number{color:#9ca3af}.calendar-day.sunday .day-status-badge{background:#e5e7eb!important;color:#6b7280!important}.calendar-day.disabled.pending-leave-day{animation:pending-pulse 2s ease-in-out infinite;outline:2px dashed var(--color-orange);outline-offset:-2px}@keyframes pending-pulse{0%,to{outline-color:var(--color-orange)}50%{outline-color:var(--color-orange)}}.calendar-day.disabled.selected{background:inherit;box-shadow:none!important}.calendar-day.disabled.selected:after{display:none}.calendar-day.disabled .day-status-badge{font-weight:800;letter-spacing:.01em}.calendar-day.joining-day{outline:2px solid #2563eb;outline:2px solid var(--primary,#2563eb);outline-offset:-2px;position:relative;z-index:1}.joining-badge{background:#2563eb;background:var(--primary,#2563eb);border-radius:var(--radius-sm);color:#fff;font-size:9px;font-weight:700;line-height:16px;padding:0 4px;position:absolute;right:3px;top:1px}.calendar-day.before-joining{background:repeating-linear-gradient(-45deg,#0000,#0000 4px,#0000000a 0,#0000000a 8px)!important;color:#b0b0b0;color:var(--text-tertiary,#b0b0b0);cursor:not-allowed}.no-employee-banner{align-items:center;background:#fff7ed;border:1px solid #fed7aa;border-radius:var(--radius-md);color:#9a3412;display:flex;font-size:var(--text-sm);font-weight:500;gap:var(--space-2);margin-bottom:var(--space-3);padding:var(--space-2) var(--space-3)}.no-employee-banner svg{flex-shrink:0}.inline-edit-banner{align-items:center;background:#fef3c7;border:1px solid #fbbf24;border-bottom:1px solid var(--border-default);border-radius:0;color:#92400e;display:flex;font-size:var(--text-sm);font-weight:500;gap:var(--space-2);padding:var(--space-2) var(--space-3)}.inline-edit-banner svg{flex-shrink:0}.calendar-day.modified{animation:modifiedPulse 1.5s ease-in-out infinite;position:relative}.calendar-day.modified:after{border:2px solid #f59e0b;border-radius:var(--radius-md);content:"";inset:0;pointer-events:none;position:absolute}.modified-badge{background:#f59e0b;border-radius:var(--radius-sm);color:#fff;font-size:8px;font-weight:700;letter-spacing:.5px;line-height:14px;padding:0 3px;position:absolute;right:3px;top:1px}@keyframes modifiedPulse{0%,to{box-shadow:0 0 0 0 #f59e0b4d}50%{box-shadow:0 0 0 3px #f59e0b26}}.calendar-day.protected{cursor:not-allowed}.modified-count{color:#d97706;font-size:var(--text-sm)}.audit-modal-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.audit-modal{background:#fff;background:var(--surface-primary,#fff);border-radius:12px;border-radius:var(--radius-lg,12px);box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:80vh;width:min(90vw,860px)}.audit-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;padding:var(--space-4) var(--space-5)}.audit-modal-header h3{align-items:center;display:flex;font-size:16px;font-size:var(--text-base,16px);gap:var(--space-2);margin:0}.audit-modal-close{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;padding:4px}.audit-modal-close:hover{background:#f3f4f6;background:var(--bg-hover,#f3f4f6)}.audit-modal-body{flex:1 1;overflow-y:auto;padding:var(--space-4) var(--space-5)}.audit-empty,.audit-loading{align-items:center;color:var(--text-secondary);display:flex;gap:var(--space-2);justify-content:center;padding:var(--space-8) 0;text-align:center}.audit-table{border-collapse:collapse;font-size:13px;font-size:var(--text-sm,13px);width:100%}.audit-table thead{position:sticky;top:0;z-index:1}.audit-table th{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color,#e5e7eb);font-weight:600;text-align:left;white-space:nowrap}.audit-table td,.audit-table th{padding:var(--space-2) var(--space-3)}.audit-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);vertical-align:top}.audit-table tbody tr:hover{background:#f3f4f6;background:var(--bg-hover,#f3f4f6)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.calendar-day .day-number{color:var(--text-primary);font-size:var(--text-sm);font-weight:500}.calendar-day.sunday .day-number{color:var(--color-red)}.calendar-day .day-status{border-radius:var(--radius-sm);font-size:var(--text-2xs);font-weight:500;padding:2px 6px;text-align:center}.day-status.present{background:var(--color-green-50);color:var(--color-green-600)}.day-status.absent{background:var(--color-red-50);color:var(--color-red)}.day-status.half-day{background:var(--color-orange-50);color:var(--color-orange)}.day-status.leave{background:var(--color-accent-50);color:var(--color-accent)}.day-status.holiday{background:var(--color-blue-50);color:var(--color-blue-dark)}.calendar-legend{background:var(--surface-secondary);border-bottom:1px solid var(--border-default);display:flex;flex-wrap:wrap;gap:5px 16px;padding:8px 20px}.cal-legend-item{align-items:center;display:flex;gap:5px}.cal-legend-dot{border-radius:50%;flex-shrink:0;height:9px;width:9px}.cal-legend-label{color:var(--text-secondary);font-weight:600}.cal-legend-label,.day-status-badge{font-size:var(--text-2xs);white-space:nowrap}.day-status-badge{border-radius:var(--radius-sm);display:block;font-weight:700;margin-top:auto;max-width:100%;opacity:.92;outline:1px solid currentColor;outline-offset:-1px;overflow:hidden;padding:2px 5px;text-align:center;text-overflow:ellipsis}.status-panel{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5)}.status-panel h3{border-bottom:1px solid var(--border-default);color:var(--text-primary);font-size:var(--text-md);font-weight:600;margin-bottom:var(--space-4);padding-bottom:var(--space-3)}.status-options{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(4,1fr)}.status-group h4{color:var(--text-secondary);font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;margin-bottom:var(--space-3);text-transform:uppercase}.status-item{margin-bottom:var(--space-2-5)}.selection-info{border-top:1px solid var(--border-light);display:flex;gap:var(--space-6);margin-top:var(--space-4);padding-top:var(--space-3)}.selection-info p{color:var(--text-secondary);font-size:var(--text-sm)}.selection-info strong{color:var(--text-primary)}.selection-breakdown{border-top:1px solid var(--border-light);margin-top:var(--space-3);padding-top:var(--space-3)}.apply-to-selected-section{align-items:center;background:#eff6ff;background:var(--color-primary-50,#eff6ff);border:1.5px solid #2563eb;border:1.5px solid var(--color-primary,#2563eb);border-radius:8px;border-radius:var(--radius-md,8px);display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-4);padding:var(--space-3) var(--space-4)}.apply-to-selected-btn{align-items:center;display:inline-flex;gap:6px;white-space:nowrap}.apply-to-selected-hint{color:var(--text-secondary);font-size:var(--text-xs);line-height:1.4;margin:0}.quick-apply-section{background:#f6f8fa;background:var(--bg-subtle,#f6f8fa);border:1.5px dashed #d0d7de;border:1.5px dashed var(--border-default,#d0d7de);border-radius:8px;border-radius:var(--radius-md,8px);margin-top:var(--space-4);padding:var(--space-4)}.quick-apply-section h4{align-items:center;color:var(--text-primary);display:flex;font-size:var(--text-sm);font-weight:700;gap:6px;margin:0 0 var(--space-2) 0}.quick-apply-hint{color:var(--text-secondary);font-size:var(--text-xs);line-height:1.5;margin:0 0 var(--space-3) 0}.quick-apply-row{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-3)}.quick-apply-input{background:#fff;background:var(--bg-card,#fff);border:1.5px solid #d0d7de;border:1.5px solid var(--border-default,#d0d7de);border-radius:6px;border-radius:var(--radius-md,6px);color:var(--text-primary);font-size:var(--text-sm);font-weight:600;outline:none;padding:7px 10px;transition:border-color .15s;width:90px}.quick-apply-input:focus{border-color:#0969da;border-color:var(--accent-fg,#0969da);box-shadow:0 0 0 3px #0969da1f}.quick-apply-input:disabled{cursor:not-allowed;opacity:.5}.quick-apply-of{color:var(--text-secondary);font-size:var(--text-xs);white-space:nowrap}.quick-apply-btn{align-items:center;display:inline-flex;gap:5px;white-space:nowrap}.selection-breakdown h4{color:var(--text-secondary);font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;margin:0 0 var(--space-2) 0;text-transform:uppercase}.breakdown-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.breakdown-chip{align-items:center;border:1.5px solid;border-radius:999px;display:inline-flex;font-size:var(--text-xs);font-weight:700;padding:4px 12px;white-space:nowrap}.mark-attendance-actions{border-top:1px solid var(--border-default);display:flex;gap:var(--space-3);margin-top:var(--space-5);padding-top:var(--space-4)}.saving-overlay{align-items:center;background:#f0f4ff;background:var(--bg-subtle,#f0f4ff);border:1px solid #d0d7de;border:1px solid var(--border-default,#d0d7de);border-radius:8px;border-radius:var(--radius-md,8px);display:flex;gap:var(--space-3);justify-content:center;margin-top:var(--space-4);padding:var(--space-4)}.saving-text{color:#1f2328;color:var(--fg-default,#1f2328);font-size:.95rem}@media (max-width:900px){.status-options{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.mark-attendance-container{padding:var(--space-4)}.calendar-day{min-height:52px;padding:var(--space-2)}.status-options{grid-template-columns:1fr}.mark-attendance-header{align-items:flex-start;flex-direction:column}.attendance-filters .filter-row{flex-direction:column}}.hol-toast{animation:v3FadeUp .2s;border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:600;padding:10px 20px;position:fixed;right:20px;top:20px;z-index:9999}.hol-toast.success{background:var(--color-green-50);border:1px solid var(--color-green-100);color:var(--color-green-600)}.hol-toast.error{background:var(--color-red-50);border:1px solid var(--color-red-light);color:var(--color-red-dark)}.hol-type-badge{border-radius:var(--radius-sm);display:inline-block;font-size:var(--text-sm);font-weight:700;padding:4px 12px}.hol-type-national{background:#7c5cfc1f;color:var(--color-accent)}.hol-type-festival{background:#ff6b351f;color:var(--color-orange)}.hol-type-optional{background:#00b8941f;color:var(--color-teal-dark)}.hol-type-factory{background:#ffb5471f;color:var(--color-gold)}.hol-modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.hol-modal{animation:v3FadeUp .2s;background:#fff;background:var(--surface-primary,#fff);border-radius:var(--radius-2xl);box-shadow:0 20px 60px #0003;max-height:90vh;max-width:95vw;overflow-y:auto;width:440px}.hol-modal h3{border-bottom:1px solid var(--border-default);font-size:var(--text-lg);font-weight:700;margin:0;padding:16px 20px}.hol-modal-body{gap:14px;padding:16px 20px 20px}.hol-form-row,.hol-modal-body{display:flex;flex-direction:column}.hol-form-row{gap:5px}.hol-form-row label{color:var(--text-tertiary);font-size:var(--text-sm);font-weight:700;letter-spacing:.5px}.hol-form-row input,.hol-form-row select{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);outline:none;padding:9px 12px;transition:border-color .15s}.hol-form-row input:focus,.hol-form-row select:focus{border-color:var(--color-teal)}.hol-form-2col{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.hol-modal-actions{display:flex;gap:10px;margin-top:4px}.hol-btn{border:none;border-radius:var(--radius-lg);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:700;padding:9px 0;transition:all .15s}.hol-btn-primary{background:var(--color-teal);color:var(--text-inverse)}.hol-btn-primary:hover{background:var(--color-teal-dark)}.hol-btn-outline{background:#0000;border:1px solid var(--border-default);color:var(--text-secondary)}.hol-btn-outline:hover{border-color:var(--border-strong)}@media (max-width:768px){.hol-form-2col{grid-template-columns:1fr}.hol-header{align-items:flex-start;flex-direction:column;gap:8px}}@media (max-width:480px){.hol-root{padding:8px}}.bs-root{animation:bs-fadein .3s ease;display:flex;flex-direction:column;gap:14px}@keyframes bs-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes bs-pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes bs-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.bs-toast{animation:bs-fadein .2s;border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:600;padding:10px 20px;position:fixed;right:20px;top:20px;z-index:9999}.bs-toast.success{background:var(--color-green-50);border:1px solid var(--color-green-100);color:var(--color-green-600)}.bs-toast.error{background:var(--color-red-50);border:1px solid var(--color-red-light);color:var(--color-red-dark)}.bs-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.bs-title{color:var(--text-primary);font-size:var(--text-2xl);font-weight:800;margin:0}.bs-subtitle{color:var(--text-secondary);font-size:var(--text-xs);margin:2px 0 0}.bs-header-actions{align-items:center;display:flex;gap:8px}.bs-btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:inherit;font-size:var(--text-xs);font-weight:700;gap:6px;padding:7px 14px;transition:all .15s;white-space:nowrap}.bs-btn:hover{opacity:.88}.bs-btn:disabled{cursor:not-allowed;opacity:.5}.bs-btn.accent{background:var(--color-teal);box-shadow:0 2px 10px #00c9a74d;color:var(--text-inverse)}.bs-btn.accent-dim{background:var(--color-teal-50);color:var(--color-teal)}.bs-btn.outline{background:var(--surface-primary);border:1px solid var(--border-default);color:var(--text-primary)}.bs-btn.danger-dim{background:var(--color-pink-100);color:var(--color-pink)}.bs-btn.success-dim{background:var(--color-success-100);color:var(--color-success)}.bs-btn.blue-dim{background:var(--color-sky-50);color:var(--color-sky)}.bs-btn.red-dim{background:var(--color-pink-100);color:var(--color-pink)}.bs-btn.gold-dim{background:var(--color-gold-50);color:var(--color-gold)}.bs-summary-grid{display:flex;flex-wrap:wrap;gap:10px}.bs-summary-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);flex:1 1;min-width:140px;overflow:hidden;padding:var(--space-4) var(--space-4);position:relative}.bs-summary-header{display:flex;justify-content:space-between}.bs-summary-label{color:var(--text-tertiary);font-size:var(--text-2xs);font-weight:700;letter-spacing:.7px}.bs-summary-val{font-family:var(--font-mono);font-size:22px;font-weight:800;margin-top:3px}.bs-summary-sub{color:var(--text-tertiary);font-size:var(--text-2xs);margin-top:2px}.bs-tab-bar{align-items:center;display:flex;gap:8px}.bs-tab{background:#0000;border:1px solid var(--border-default);border-radius:9px;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:var(--text-xs);font-weight:700;padding:7px 16px;transition:all .15s}.bs-tab.active{background:var(--color-teal);border-color:var(--color-teal);color:var(--text-inverse)}.bs-tab-actions{display:flex;gap:8px;margin-left:auto}.bs-live-wrap{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);overflow:hidden}.bs-live-header{align-items:center;border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;padding:11px 14px}.bs-live-status{align-items:center;display:flex;gap:8px}.bs-live-dot{border-radius:50%;height:7px;width:7px}.bs-live-dot.active{animation:bs-pulse 2s infinite;background:var(--color-success);box-shadow:0 0 8px var(--color-success)}.bs-live-dot.paused{background:var(--text-tertiary)}.bs-live-label{font-size:var(--text-2xs);font-weight:700;letter-spacing:.8px}.bs-live-label.active{color:var(--color-success)}.bs-live-count,.bs-live-label.paused{color:var(--text-tertiary)}.bs-live-count{font-size:var(--text-2xs)}.bs-bounce-dots{display:flex;gap:4px}.bs-bounce-dot{background:var(--color-indigo);border-radius:50%;height:4px;width:4px}.bs-bounce-dot:first-child{animation:bs-bounce .9s 0s infinite}.bs-bounce-dot:nth-child(2){animation:bs-bounce .9s .2s infinite}.bs-bounce-dot:nth-child(3){animation:bs-bounce .9s .4s infinite}.bs-live-body{max-height:450px;overflow-y:auto}.bs-live-row{align-items:center;border-bottom:1px solid var(--border-default);display:flex;gap:12px;padding:10px 14px}.bs-live-row.latest{background:#6366f108}.bs-type-badge{align-items:center;border-radius:9px;display:flex;flex-shrink:0;font-family:var(--font-mono);font-size:var(--text-sm);font-weight:800;height:36px;justify-content:center;width:36px}.bs-type-badge.in{background:var(--color-success-100);border:1px solid #22c55e45;color:var(--color-success)}.bs-type-badge.out{background:var(--color-sky-50);border:1px solid #4d9fff45;color:var(--color-sky)}.bs-avatar{align-items:center;border-radius:9px;display:flex;flex-shrink:0;font-family:var(--font-mono);font-weight:800;justify-content:center}.bs-emp-info{flex:1 1;min-width:0}.bs-emp-name{color:var(--text-primary);font-size:var(--text-xs);font-weight:700}.bs-emp-name .code{font-family:var(--font-mono)}.bs-emp-detail,.bs-emp-name .code{color:var(--text-tertiary);font-size:var(--text-2xs)}.bs-status-badge{border-radius:var(--radius-3xl);font-size:var(--text-2xs);font-weight:700;padding:2px 8px;white-space:nowrap}.bs-punch-time{color:var(--text-tertiary);flex-shrink:0;font-family:var(--font-mono);font-size:var(--text-2xs)}.bs-device-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.bs-device-card{background:var(--surface-primary);border:1px solid;border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);overflow:hidden}.bs-device-card.online{border-color:#22c55e40}.bs-device-card.offline{border-color:#ff4d6d40}.bs-device-header{align-items:center;border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;padding:14px 16px}.bs-device-header.online{background:var(--color-success-50)}.bs-device-header.offline{background:var(--color-pink-100)}.bs-device-title{align-items:center;display:flex;gap:10px}.bs-device-title-icon{font-size:24px}.bs-device-name{color:var(--text-primary);font-size:var(--text-sm);font-weight:800}.bs-device-id{color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--text-2xs)}.bs-device-status{align-items:center;display:flex;gap:5px}.bs-device-status-dot{border-radius:50%;height:8px;width:8px}.bs-device-status-dot.online{animation:bs-pulse 2s infinite;background:var(--color-success);box-shadow:0 0 8px var(--color-success)}.bs-device-status-dot.offline{background:var(--color-pink)}.bs-device-status-text{font-size:var(--text-2xs);font-weight:700}.bs-device-status-text.online{color:var(--color-success)}.bs-device-status-text.offline{color:var(--color-pink)}.bs-device-body{padding:14px 16px}.bs-device-row{border-bottom:1px solid var(--border-default);display:flex;font-size:var(--text-sm);justify-content:space-between;padding:6px 0}.bs-device-row-key{color:var(--text-tertiary)}.bs-device-row-val{color:var(--text-secondary);font-weight:600}.bs-device-row-val.mono{font-family:var(--font-mono)}.bs-test-result{border:1px solid;border-radius:var(--radius-lg);font-size:var(--text-2xs);margin-top:10px;padding:8px 10px}.bs-test-result.ok{background:var(--color-success-50);border-color:#22c55e40;color:var(--color-success)}.bs-test-result.fail{background:var(--color-pink-100);border-color:#ff4d6d40;color:var(--color-pink)}.bs-device-actions{display:flex;gap:8px;margin-top:12px}.bs-config-wrap{display:flex;flex-direction:column;gap:16px}.bs-config-section{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);padding:var(--space-4)}.bs-config-title{color:var(--text-tertiary);font-size:var(--text-sm);font-weight:700;letter-spacing:.8px;margin-bottom:14px}.bs-config-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.bs-field{display:flex;flex-direction:column;gap:5px}.bs-field-label{color:var(--text-tertiary);font-size:var(--text-2xs)}.bs-input{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-sizing:border-box;color:var(--text-primary);font-family:inherit;outline:none;padding:9px 12px;width:100%}.bs-info-box,.bs-input{font-size:var(--text-sm)}.bs-info-box{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-top:12px;padding:12px 14px}.bs-info-title{color:var(--text-secondary);font-weight:700;margin-bottom:8px}.bs-info-row{align-items:flex-start;display:flex;gap:10px;margin-bottom:6px}.bs-info-dot{background:var(--color-indigo);border-radius:50%;flex-shrink:0;height:6px;margin-top:4px;width:6px}.bs-info-key{color:var(--color-indigo);flex-shrink:0;font-weight:700;min-width:130px}.bs-info-val{color:var(--text-tertiary)}.bs-toggle-list{display:flex;flex-direction:column;gap:10px}.bs-toggle-row{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;display:flex;justify-content:space-between;padding:10px 14px}.bs-toggle-label{color:var(--text-secondary);font-size:var(--text-xs);font-weight:600}.bs-toggle{border:none;border-radius:11px;cursor:pointer;flex-shrink:0;height:22px;position:relative;transition:background .25s;width:44px}.bs-toggle.on{background:var(--color-indigo)}.bs-toggle.off{background:var(--border-default)}.bs-toggle-knob{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000004d;height:16px;position:absolute;top:3px;transition:left .25s;width:16px}.bs-toggle.on .bs-toggle-knob{left:23px}.bs-toggle.off .bs-toggle-knob{left:3px}.bs-config-actions{display:flex;gap:8px}.bs-import-result{border:1px solid var(--border-default);border-radius:12px;font-size:13px;padding:16px}.bs-import-result.success{background:var(--color-success-50)}.bs-import-result.error{background:var(--color-pink-100)}.bs-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1300}.bs-modal{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:92vh;width:90%}.bs-modal-header{align-items:center;border-bottom:1px solid var(--border-default);display:flex;flex-shrink:0;justify-content:space-between;padding:15px 22px}.bs-modal-title{color:var(--text-primary);font-size:var(--text-md);font-weight:800}.bs-modal-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:18px;padding:4px}.bs-modal-body{overflow-y:auto;padding:18px 22px}.bs-modal-warn{background:#ffb54714;border:1px solid #ffb54730;border-radius:9px;color:var(--color-gold);font-size:var(--text-sm);margin-bottom:14px;padding:10px 14px}.bs-modal-fields{display:flex;flex-direction:column;gap:12px}.bs-modal-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.bs-modal-actions{border-top:1px solid #80808026;display:flex;gap:10px;margin-top:18px;padding-top:14px}.bs-modal-actions .bs-btn{flex:1 1}.bs-enroll-subtitle{color:var(--text-secondary);font-size:var(--text-sm);margin-top:2px}.bs-enroll-body{overflow-y:auto;padding:24px}.bs-enroll-error{background:var(--color-red-50);border:1px solid var(--color-red-light);border-radius:8px;color:var(--color-red-dark);font-size:var(--text-sm);margin-bottom:16px;padding:10px 14px}.bs-enroll-list{border:1px solid var(--border-default);border-radius:var(--radius-lg);max-height:180px;overflow-y:auto}.bs-enroll-item{align-items:center;border-bottom:1px solid var(--border-light);cursor:pointer;display:flex;font-size:13px;justify-content:space-between;padding:10px 14px}.bs-enroll-item.selected{background:#6366f10f}.bs-enroll-selected{background:var(--color-success-bg);border:1px solid var(--color-success-border);border-radius:8px;color:var(--color-green-700);font-size:var(--text-xs);margin-top:8px;padding:8px 12px}.bs-enroll-actions{display:flex;gap:10px;justify-content:flex-end}.bs-empty{color:var(--text-tertiary);font-size:var(--text-sm);padding:40px;text-align:center}.bs-laptop-wrap{display:flex;flex-direction:column;gap:14px}.bs-laptop-header-card{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);display:flex;justify-content:space-between;padding:var(--space-4) var(--space-5)}.bs-laptop-header-left{align-items:center;display:flex;gap:14px}.bs-laptop-header-icon{font-size:28px}.bs-laptop-header-title{color:var(--text-primary);font-size:var(--text-md);font-weight:800}.bs-laptop-header-device{color:var(--color-indigo)}.bs-laptop-header-meta{align-items:center;display:flex;gap:8px;margin-top:4px}.bs-laptop-status-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.bs-laptop-status-dot.active{animation:bs-pulse 2s infinite;background:var(--color-success);box-shadow:0 0 8px var(--color-success)}.bs-laptop-status-text{color:var(--color-success);font-size:var(--text-2xs);font-weight:700}.bs-laptop-meta-id,.bs-laptop-meta-sep{color:var(--text-tertiary);font-size:var(--text-2xs)}.bs-laptop-meta-id{font-family:var(--font-mono);font-weight:600}.bs-laptop-meta-count{color:var(--text-tertiary);font-size:var(--text-2xs)}.bs-laptop-punch-toggle{border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;gap:0;overflow:hidden}.bs-laptop-punch-btn{background:var(--surface-secondary);border:none;color:var(--text-tertiary);cursor:pointer;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:800;padding:8px 20px;transition:all .2s}.bs-laptop-punch-btn.active.in{background:var(--color-success);color:var(--text-inverse)}.bs-laptop-punch-btn.active.out{background:var(--color-sky);color:var(--text-inverse)}.bs-laptop-instructions{align-items:center;background:#6366f10f;border:1px solid #6366f126;border-radius:10px;color:var(--text-secondary);display:flex;font-size:var(--text-xs);gap:10px;line-height:1.5;padding:12px 16px}.bs-laptop-instructions-icon{flex-shrink:0;font-size:var(--text-xl)}.bs-laptop-instructions strong{color:var(--text-primary)}.bs-laptop-dept-bar{display:flex;flex-wrap:wrap;gap:6px}.bs-laptop-dept-pill{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-3xl);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:var(--text-sm);font-weight:700;padding:5px 14px;transition:all .15s}.bs-laptop-dept-pill:hover{border-color:var(--color-indigo)}.bs-laptop-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}.bs-laptop-emp-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);cursor:pointer;padding:var(--space-3);text-align:center;transition:all .2s}.bs-laptop-emp-card:hover{border-color:var(--color-indigo);box-shadow:0 4px 16px var(--color-indigo-50);transform:translateY(-1px)}.bs-laptop-emp-card.scanned{background:#22c55e05;border-color:#22c55e4d}.bs-laptop-emp-top{display:flex;justify-content:center;margin-bottom:8px;position:relative}.bs-laptop-emp-avatar{align-items:center;border-radius:10px;display:flex;font-size:var(--text-sm);height:40px;justify-content:center;width:40px}.bs-laptop-emp-avatar,.bs-laptop-emp-badge{font-family:var(--font-mono);font-weight:800}.bs-laptop-emp-badge{border-radius:var(--radius-sm);font-size:8px;padding:1px 6px;position:absolute;right:calc(50% - 32px);top:-4px}.bs-laptop-emp-badge.in{background:var(--color-success-100);color:var(--color-success)}.bs-laptop-emp-badge.out{background:var(--color-sky-50);color:var(--color-sky)}.bs-laptop-emp-name{color:var(--text-primary);font-size:var(--text-xs);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bs-laptop-emp-code{color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--text-2xs);margin:2px 0}.bs-laptop-emp-detail{align-items:center;display:flex;gap:6px;justify-content:center;margin:4px 0}.bs-laptop-emp-shift{background:var(--surface-secondary);border-radius:var(--radius-sm);color:var(--text-tertiary);font-size:var(--text-2xs);font-weight:600;padding:1px 6px}.bs-laptop-emp-dept{font-size:9px;font-weight:700}.bs-laptop-emp-action{margin-top:6px}.bs-laptop-emp-tap{color:var(--color-indigo);font-size:var(--text-2xs);font-weight:600}.bs-laptop-emp-scanned-text{color:var(--color-success);font-size:var(--text-2xs);font-weight:600}.bs-laptop-log-section{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);overflow:hidden}.bs-laptop-log-title{border-bottom:1px solid var(--border-default);color:var(--text-primary);font-size:var(--text-sm);font-weight:800;padding:14px 18px}.bs-laptop-log-table{max-height:300px;overflow-y:auto}.bs-laptop-log-header{background:var(--surface-secondary);color:var(--text-tertiary);font-size:9px;font-weight:700;letter-spacing:.7px;padding:8px 18px}.bs-laptop-log-header,.bs-laptop-log-row{border-bottom:1px solid var(--border-default);display:grid;grid-template-columns:50px 1fr 1fr 100px 100px}.bs-laptop-log-row{align-items:center;font-size:var(--text-xs);padding:10px 18px}.bs-laptop-log-emp{display:flex;flex-direction:column}.bs-laptop-log-emp strong{color:var(--text-primary);font-size:var(--text-xs)}.bs-laptop-log-code{color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--text-2xs)}.bs-laptop-log-dept,.bs-laptop-log-time{color:var(--text-secondary);font-size:var(--text-sm)}.bs-laptop-log-time{font-family:var(--font-mono)}.bs-laptop-log-method{color:var(--text-tertiary);font-size:var(--text-sm)}.bs-scan-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1400}.bs-scan-modal{animation:bs-fadein .3s ease;background:var(--surface-primary);border-radius:var(--radius-3xl);box-shadow:var(--shadow-xl);max-width:360px;padding:36px 32px 28px;position:relative;text-align:center;width:100%}.bs-scan-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:18px;position:absolute;right:18px;top:14px}.bs-scan-body{gap:14px}.bs-scan-body,.bs-scan-emp-info{align-items:center;display:flex;flex-direction:column}.bs-scan-emp-info{gap:6px;text-align:center}.bs-scan-emp-avatar{align-items:center;border-radius:12px;display:flex;font-family:var(--font-mono);height:48px;justify-content:center;width:48px}.bs-scan-emp-avatar,.bs-scan-emp-name{font-size:var(--text-lg);font-weight:800}.bs-scan-emp-name{color:var(--text-primary)}.bs-scan-emp-code{color:var(--text-tertiary);font-size:var(--text-sm)}.bs-scan-punch-type{margin:2px 0}.bs-scan-sensor{align-items:center;border-radius:50%;cursor:pointer;display:flex;height:140px;justify-content:center;position:relative;transition:transform .15s;user-select:none;-webkit-user-select:none;width:140px}.bs-scan-sensor:active{transform:scale(.96)}.bs-scan-sensor.waiting{color:var(--text-tertiary)}.bs-scan-sensor.holding{color:var(--color-indigo)}.bs-scan-sensor.success{color:var(--color-success);cursor:default}.bs-scan-sensor.error{color:var(--color-pink);cursor:default}.bs-scan-ring{height:140px;inset:0;position:absolute;width:140px}.bs-scan-fp-icon{align-items:center;background:var(--surface-secondary);border:2px solid var(--border-default);border-radius:50%;display:flex;height:100px;justify-content:center;position:relative;transition:all .3s;width:100px;z-index:2}.bs-scan-sensor.holding .bs-scan-fp-icon{background:#6366f114;border-color:#6366f14d;box-shadow:0 0 30px #6366f126}.bs-scan-sensor.success .bs-scan-fp-icon{background:#22c55e14;border-color:#22c55e4d;box-shadow:0 0 30px #22c55e33}.bs-scan-sensor.error .bs-scan-fp-icon{background:#ff4d6d14;border-color:#ff4d6d4d;box-shadow:0 0 30px #ff4d6d26}.bs-scan-line{animation:bs-scan-sweep 1.2s ease-in-out infinite;background:linear-gradient(90deg,#0000,var(--color-indigo),#0000);border-radius:2px;height:3px;left:20px;opacity:.7;position:absolute;right:20px;z-index:3}@keyframes bs-scan-sweep{0%{opacity:0;top:25%}10%{opacity:.7}90%{opacity:.7}to{opacity:0;top:75%}}.bs-scan-instruction{color:var(--text-secondary);font-size:var(--text-xs);line-height:1.5;max-width:260px;transition:color .3s}.bs-scan-instruction.holding{color:var(--color-indigo);font-weight:600}.bs-scan-instruction.success{color:var(--color-success);font-weight:700}.bs-scan-instruction.error{color:var(--color-pink);font-weight:600}.bs-scan-pct{color:var(--color-indigo);font-family:var(--font-mono);font-size:22px;font-weight:800;opacity:.7}@media (max-width:768px){.bs-config-grid,.bs-device-grid,.bs-modal-grid{grid-template-columns:1fr}.bs-emp-header,.bs-emp-row{gap:4px;grid-template-columns:1fr}.bs-header{align-items:flex-start;flex-direction:column;gap:8px}.bs-toolbar{align-items:stretch;flex-direction:column}}@media (max-width:480px){.bs-root{padding:8px}}.bsim-root{animation:bsim-fade .2s ease;display:flex;flex-direction:column;height:100%;overflow:hidden}@keyframes bsim-fade{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.bsim-header{background:#fff;background:var(--surface,#fff);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);flex-shrink:0;gap:12px;justify-content:space-between;padding:10px 18px}.bsim-header,.bsim-header-left{align-items:center;display:flex;flex-wrap:wrap}.bsim-header-left{gap:14px}.bsim-header-right{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:8px}.bsim-title{color:#111827;color:var(--text-primary,#111827);font-size:15px;font-weight:700;margin:0;white-space:nowrap}.bsim-mode-tabs{display:flex;gap:4px}.bsim-mode-tab{background:#f9fafb;background:var(--surface-alt,#f9fafb);border:1px solid #d1d5db;border:1px solid var(--border,#d1d5db);border-radius:6px;color:#374151;color:var(--text-secondary,#374151);cursor:pointer;font-size:12px;font-weight:600;padding:5px 13px;transition:all .15s;white-space:nowrap}.bsim-mode-tab:hover:not(:disabled){border-color:#6366f1;border-color:var(--primary,#6366f1);color:#6366f1;color:var(--primary,#6366f1)}.bsim-mode-tab.active{background:#6366f1;background:var(--primary,#6366f1);border-color:#6366f1;border-color:var(--primary,#6366f1);color:#fff}.bsim-mode-tab:disabled{cursor:not-allowed;opacity:.45}.bsim-dryrun-toggle{align-items:center;color:#374151;color:var(--text-secondary,#374151);cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:5px;white-space:nowrap}.bsim-serial-sel{max-width:200px}.bsim-serial-input,.bsim-serial-sel{background:#fff;background:var(--surface,#fff);border:1px solid #d1d5db;border:1px solid var(--border,#d1d5db);border-radius:6px;color:#111827;color:var(--text-primary,#111827);font-size:12px;padding:5px 8px}.bsim-serial-input{font-family:monospace;width:100px}.bsim-serial-input:focus,.bsim-serial-sel:focus{border-color:#6366f1;border-color:var(--primary,#6366f1);outline:none}.bsim-dry-badge{background:#fef3c7;border-radius:5px;color:#92400e;font-size:11px;font-weight:700;letter-spacing:.4px;padding:3px 8px}.bsim-terminal-layout{grid-gap:12px;display:grid;flex:1 1;gap:12px;grid-template-columns:280px 1fr;min-height:0;overflow:hidden;padding:12px 16px 14px}@media (max-width:860px){.bsim-terminal-layout{grid-template-columns:1fr;overflow:auto}}.bsim-terminal-left{display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding-right:2px}.bsim-terminal-right{display:flex;flex-direction:column;min-height:0;overflow:hidden}.bsim-tscreen{background:#0f172a;border:2px solid #1e293b;border-radius:12px;box-shadow:0 4px 24px #0000002e;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.bsim-tscreen-bar{align-items:center;background:#1e293b;border-bottom:1px solid #334155;display:flex;justify-content:space-between;padding:10px 16px}.bsim-tscreen-brand{align-items:center;color:#38bdf8;display:flex;font-size:13px;font-weight:700;gap:6px;letter-spacing:.5px}.bsim-tscreen-dot{animation:bsim-blink 2s ease-in-out infinite;background:#22c55e;border-radius:50%;height:8px;width:8px}@keyframes bsim-blink{0%,90%,to{opacity:1}45%{opacity:.2}}.bsim-tscreen-clock{color:#f1f5f9;font-family:Consolas,monospace;font-size:18px;font-weight:700;letter-spacing:1px}.bsim-tscreen-date{background:#0f172a;color:#64748b;font-family:monospace;font-size:11px;letter-spacing:.3px;padding:5px 16px}.bsim-tscreen-empty{align-items:center;color:#475569;display:flex;flex:1 1;flex-direction:column;font-size:14px;justify-content:center;line-height:1.6;padding:40px;text-align:center}.bsim-tc-grid{grid-gap:12px;display:grid;flex:1 1;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));overflow-y:auto;padding:14px}.bsim-tc{align-items:center;background:#1e293b;border:1.5px solid #334155;border-radius:10px;display:flex;flex-direction:column;gap:6px;overflow:hidden;padding:12px 10px 10px;position:relative;transition:border-color .2s,background .2s}.bsim-tc-in{background:#052e16cc;border-color:#22c55e44}.bsim-tc-lunch{background:#161100cc;border-color:#f59e0b55}.bsim-tc-out{background:#1e293b;border-color:#334155}.bsim-tc-res-ok{box-shadow:0 0 0 2px #22c55e88}.bsim-tc-res-error{box-shadow:0 0 0 2px #ef444488}.bsim-tc-badge{border-radius:12px;color:#fff;font-size:9px;font-weight:800;letter-spacing:1px;padding:2px 7px;text-transform:uppercase}.bsim-tc-name{color:#e2e8f0;font-size:12px;font-weight:700;line-height:1.3;max-width:100%;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.bsim-tc-uid{color:#64748b;font-family:monospace;font-size:10px}.bsim-tc-sensor{align-items:center;background:#0f172a;border:2px solid #334155;border-radius:50%;cursor:pointer;display:flex;height:76px;justify-content:center;outline:none;position:relative;transition:border-color .2s,background .2s,transform .1s;width:76px}.bsim-tc-sensor:hover:not(:disabled){background:#1e1b4b;border-color:#6366f1;transform:scale(1.04)}.bsim-tc-sensor.scanning{animation:bsim-sensor-pulse .8s ease-in-out infinite;border-color:#6366f1;cursor:default}@keyframes bsim-sensor-pulse{0%,to{box-shadow:0 0 0 0 #6366f144}50%{box-shadow:0 0 0 10px #6366f100}}.bsim-tc-sensor:disabled:not(.scanning){cursor:not-allowed;opacity:.5}.bsim-tc-ring{border:2px solid #0000;border-radius:50%;inset:-4px;pointer-events:none;position:absolute}.bsim-tc-sensor.scanning .bsim-tc-ring{animation:bsim-ring-spin 1s linear infinite;border-color:#6366f1}@keyframes bsim-ring-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.bsim-fp{stroke:#475569;height:44px;transition:stroke .2s;width:44px}.bsim-tc-sensor.scanning .bsim-fp,.bsim-tc-sensor:hover:not(:disabled) .bsim-fp{stroke:#818cf8}.bsim-fp-ok{stroke:#22c55e!important}.bsim-fp-error{stroke:#ef4444!important}.bsim-fp-scanning{animation:bsim-fp-scan .6s ease-in-out infinite alternate}@keyframes bsim-fp-scan{0%{stroke:#818cf8;opacity:.6}to{stroke:#a5b4fc;opacity:1}}.bsim-tc-hint{color:#64748b;font-size:10.5px;min-height:16px;text-align:center}.hint-scanning{animation:bsim-ellipsis 1.2s steps(4) infinite;color:#818cf8}.hint-ok{color:#22c55e;font-weight:700}.hint-err{color:#ef4444;font-weight:700}@keyframes bsim-ellipsis{0%{content:"Scanning"}33%{content:"Scanning."}66%{content:"Scanning.."}99%{content:"Scanning..."}}.bsim-tc-last{color:#475569;font-size:9.5px;text-align:center}.bsim-tc-force{background:none;border:1px solid #334155;border-radius:5px;color:#94a3b8;cursor:pointer;font-size:10px;padding:2px 7px;transition:all .15s}.bsim-tc-force:hover{background:#1e293b;border-color:#64748b;color:#f1f5f9}.bsim-body{grid-gap:12px;display:grid;flex:1 1;gap:12px;grid-template-columns:300px 1fr;min-height:0;overflow:hidden;padding:12px 16px 14px}@media (max-width:900px){.bsim-body{grid-template-columns:1fr;overflow:auto}}.bsim-left{overflow-y:auto}.bsim-left,.bsim-right{display:flex;flex-direction:column;gap:10px}.bsim-right{min-height:0;overflow:hidden}.bsim-card{background:#fff;background:var(--surface,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:10px;display:flex;flex-direction:column;flex-shrink:0;gap:9px;padding:12px 14px}.bsim-card-title{align-items:center;color:#6b7280;color:var(--text-muted,#6b7280);display:flex;font-size:11px;font-weight:700;gap:8px;justify-content:space-between;letter-spacing:.5px;text-transform:uppercase}.bsim-card-actions{display:flex;gap:5px}.bsim-field{display:flex;flex-direction:column;gap:3px}.bsim-field label{color:#374151;color:var(--text-secondary,#374151);font-size:11px;font-weight:600}.bsim-field input,.bsim-field select{background:#fff;background:var(--surface,#fff);border:1px solid #d1d5db;border:1px solid var(--border,#d1d5db);border-radius:6px;box-sizing:border-box;color:#111827;color:var(--text-primary,#111827);font-size:12.5px;padding:5px 8px;width:100%}.bsim-field input:focus,.bsim-field select:focus{border-color:#6366f1;border-color:var(--primary,#6366f1);outline:none}.bsim-field input:disabled,.bsim-field select:disabled{cursor:not-allowed;opacity:.5}.bsim-grid2{grid-gap:7px;display:grid;gap:7px;grid-template-columns:1fr 1fr}.bsim-checkbox-label{align-items:center;color:#374151;color:var(--text-secondary,#374151);cursor:pointer;display:flex;font-size:12px;gap:6px}.bsim-info-text{color:#6b7280;color:var(--text-muted,#6b7280);font-size:11.5px;line-height:1.5;margin:0}.bsim-btn{border:none;border-radius:7px;cursor:pointer;font-size:13px;font-weight:600;padding:7px 18px;transition:opacity .15s}.bsim-btn:disabled{cursor:not-allowed;opacity:.4}.bsim-btn-start{background:#6366f1;background:var(--primary,#6366f1);color:#fff}.bsim-btn-start:hover:not(:disabled){opacity:.88}.bsim-btn-stop{background:#ef4444;color:#fff}.bsim-btn-stop:hover{opacity:.85}.bsim-btn-sm{background:#fff;background:var(--surface,#fff);border:1px solid #d1d5db;border:1px solid var(--border,#d1d5db);border-radius:5px;color:#374151;color:var(--text-secondary,#374151);cursor:pointer;flex-shrink:0;font-size:11px;font-weight:600;padding:3px 9px;transition:all .13s;white-space:nowrap}.bsim-btn-sm:hover:not(:disabled){border-color:#6366f1;border-color:var(--primary,#6366f1);color:#6366f1;color:var(--primary,#6366f1)}.bsim-btn-sm:disabled{cursor:not-allowed;opacity:.4}.bsim-emp-card{flex-shrink:0}.bsim-emp-add{align-items:center;display:flex;gap:5px}.bsim-emp-add input{background:#fff;background:var(--surface,#fff);border:1px solid #d1d5db;border:1px solid var(--border,#d1d5db);border-radius:6px;color:#111827;color:var(--text-primary,#111827);flex:1 1;font-size:12px;padding:5px 8px}.bsim-emp-add input:focus{border-color:#6366f1;border-color:var(--primary,#6366f1);outline:none}.bsim-emp-header{align-items:center;border-bottom:1px solid #f0f0f0;border-bottom:1px solid var(--border,#f0f0f0);color:#374151;color:var(--text-secondary,#374151);display:flex;font-size:11.5px;justify-content:space-between;padding-bottom:5px}.bsim-emp-header label{align-items:center;cursor:pointer;display:flex;gap:6px}.bsim-emp-list{display:flex;flex-direction:column;gap:3px;max-height:200px;overflow-y:auto}.bsim-emp-row{align-items:center;background:#f9fafb;background:var(--surface-alt,#f9fafb);border-radius:5px;display:flex;font-size:12px;gap:6px;padding:3px 5px}.bsim-emp-row.sel{background:#eff6ff}.bsim-emp-id{color:#6366f1;color:var(--primary,#6366f1);flex-shrink:0;font-family:monospace;font-size:11px;min-width:58px}.bsim-emp-name{color:#111827;color:var(--text-primary,#111827);flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bsim-emp-empty{color:#9ca3af;font-size:12px;padding:14px 0;text-align:center}.bsim-verify-all,.bsim-verify-select{background:#fff;background:var(--surface,#fff);border:1px solid #d1d5db;border:1px solid var(--border,#d1d5db);border-radius:4px;flex-shrink:0;font-size:11px;padding:2px 5px}.bsim-emp-remove{background:none;border:none;border-radius:3px;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:11px;padding:2px 3px}.bsim-emp-remove:hover:not(:disabled){background:#fee2e2;color:#ef4444}.bsim-emp-remove:disabled{cursor:not-allowed;opacity:.4}.bsim-stats{background:#f9fafb;background:var(--surface-alt,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:7px;flex-shrink:0;font-size:12px;font-weight:600;gap:14px;padding:7px 13px}.bsim-stat,.bsim-stats{align-items:center;display:flex}.bsim-stat{gap:3px}.bsim-stat.ok{color:#16a34a}.bsim-stat.skip{color:#ca8a04}.bsim-stat.error{color:#dc2626}.bsim-running-dot{animation:bsim-dot-pulse 1s ease-in-out infinite;background:#6366f1;background:var(--primary,#6366f1);border-radius:50%;height:7px;margin-left:auto;width:7px}@keyframes bsim-dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.75)}}.bsim-log-card{flex:1 1;min-height:0;overflow:hidden}.bsim-log{display:flex;flex:1 1;flex-direction:column;font-family:Consolas,Menlo,monospace;font-size:11px;gap:2px;max-height:380px;overflow-y:auto}.bsim-log-empty{color:#9ca3af;font-family:inherit;font-size:11.5px;padding:18px 0;text-align:center}.bsim-log-row{align-items:center;border-radius:4px;display:flex;gap:7px;line-height:1.4;padding:2px 6px}.bsim-log-ok{background:#f0fdf4}.bsim-log-error{background:#fef2f2}.bsim-log-skip{background:#f8fafc}.bsim-log-dry{background:#f5f3ff}.bsim-log-info{background:#eff6ff}.bsim-log-ts{color:#9ca3af;flex-shrink:0;font-size:10px}.bsim-log-date{color:#6b7280;flex-shrink:0}.bsim-log-time{color:#374151;flex-shrink:0;font-weight:600}.bsim-log-uid{color:#6366f1;color:var(--primary,#6366f1);flex-shrink:0}.bsim-log-name{color:#374151;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bsim-log-note{color:#9ca3af;flex-shrink:0;font-size:10px;font-style:italic}.bsim-log-ok .bsim-log-type{color:#16a34a;font-weight:600}.bsim-log-error .bsim-log-type{color:#dc2626;font-weight:600}.bsim-log-skip .bsim-log-type{color:#9ca3af}.bsim-log-dry .bsim-log-type{color:#7c3aed}.bsim-log-info .bsim-log-type{color:#2563eb}.mc-root{background:#f8fafc;background:var(--bg-primary,#f8fafc);color:#1e293b;color:var(--text-primary,#1e293b);font-family:Inter,sans-serif;font-family:var(--font-family,"Inter",sans-serif);min-height:100vh;padding:24px 24px 80px;position:relative}.mc-toast{animation:mc-slide-in .2s ease;border-radius:var(--radius-lg);bottom:72px;font-size:var(--text-sm);font-weight:500;padding:10px 18px;pointer-events:none;position:fixed;right:24px;z-index:9999}.mc-toast.success{background:#22c55e22;border:1px solid #22c55e44;color:var(--color-success)}.mc-toast.error{background:#ff4d6d22;border:1px solid #ff4d6d44;color:var(--color-pink)}@keyframes mc-slide-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mc-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:16px}.mc-title{align-items:center;color:#1e293b;color:var(--text-primary,#1e293b);display:flex;font-size:var(--text-2xl);font-weight:700;gap:10px;margin:0 0 4px}.mc-subtitle{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);line-height:1.5;margin:0;max-width:600px}.mc-header-actions{flex-shrink:0}.mc-header-actions,.mc-status-bar{align-items:center;display:flex;gap:8px}.mc-status-bar{border-radius:var(--radius-lg);font-size:var(--text-sm);margin-bottom:16px;padding:10px 14px}.mc-status-bar.enabled{background:#22c55e18;border:1px solid #22c55e44;color:var(--color-success)}.mc-status-bar.disabled{background:#ff4d6d18;border:1px solid #ff4d6d44;color:var(--color-pink)}.mc-stats-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.mc-stat-card{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);flex:1 1;min-width:100px;padding:10px 14px}[data-theme=dark] .mc-stat-card{background:#1e293b;background:var(--card-bg,#1e293b);border-color:var(--color-gray-700)}.mc-stat-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-2xs);font-weight:700;letter-spacing:.06em;margin-bottom:6px;text-transform:uppercase}.mc-stat-val{font-size:var(--text-base);font-weight:700}.mc-tab-bar{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);display:flex;gap:2px;margin-bottom:20px;overflow-x:auto}.mc-tab{background:none;border:none;border-bottom:2px solid #0000;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;font-size:var(--text-sm);font-weight:500;margin-bottom:-1px;padding:9px 18px;transition:color .15s,border-color .15s;white-space:nowrap}.mc-tab.active,.mc-tab:hover{color:#6366f1;color:var(--primary-color,#6366f1)}.mc-tab.active{border-bottom-color:#6366f1;border-bottom-color:var(--primary-color,#6366f1)}.mc-panel{display:flex;flex-direction:column;gap:20px}.mc-section{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);padding:20px}[data-theme=dark] .mc-section{background:#1e293b;background:var(--card-bg,#1e293b);border-color:var(--color-gray-700)}.mc-section-title{align-items:center;display:flex;font-weight:700;gap:6px;letter-spacing:.08em;margin-bottom:14px;text-transform:uppercase}.mc-section-desc,.mc-section-title{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm)}.mc-section-desc{line-height:1.5;margin:-6px 0 16px}.mc-toggle-row{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);cursor:pointer;display:flex;gap:12px;justify-content:space-between;padding:12px 0;transition:background .1s}.mc-toggle-row:last-child{border-bottom:none}.mc-toggle-row:hover:not(.disabled){background:#f8fafc;background:var(--hover-bg,#f8fafc);border-radius:var(--radius-sm);margin:0 -20px;padding-left:20px;padding-right:20px}[data-theme=dark] .mc-toggle-row:hover:not(.disabled){background:#1a2333}.mc-toggle-row.disabled{cursor:not-allowed;opacity:.45}.mc-toggle-left{align-items:center;display:flex;gap:10px}.mc-toggle-icon{color:#64748b;color:var(--text-secondary,#64748b);flex-shrink:0}.mc-toggle-label{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);font-weight:600}.mc-toggle-desc{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);line-height:1.4;margin-top:2px}.mc-toggle-switch{border-radius:var(--radius-xl);flex-shrink:0;height:22px;position:relative;transition:background .2s;width:40px}.mc-toggle-switch.on{background:#6366f1;background:var(--primary-color,#6366f1)}.mc-toggle-switch.off{background:#cbd5e1;background:var(--border-color,#cbd5e1)}.mc-toggle-knob{background:var(--surface-primary);border-radius:50%;box-shadow:0 1px 3px #00000026;height:16px;position:absolute;top:3px;transition:left .2s;width:16px}.mc-toggle-switch.on .mc-toggle-knob{left:calc(100% - 19px)}.mc-toggle-switch.off .mc-toggle-knob{left:3px}.mc-field{margin-bottom:18px}.mc-field:last-child{margin-bottom:0}.mc-field-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.mc-field-label{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);font-weight:600}.mc-field-val-badge{background:#6366f111;background:var(--primary-bg,#6366f111);border-radius:var(--radius-3xl);color:#6366f1;color:var(--primary-color,#6366f1);font-size:var(--text-xs);font-weight:700;padding:2px 10px}.mc-field-hint{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);line-height:1.4;margin-top:6px}.mc-range-row{align-items:center;display:flex;gap:12px}.mc-range-val{color:#6366f1;color:var(--primary-color,#6366f1);font-size:var(--text-sm);font-weight:700;min-width:52px;text-align:right}.mc-range{-webkit-appearance:none;background:#e2e8f0;background:var(--border-color,#e2e8f0);border-radius:var(--radius-sm);cursor:pointer;height:4px;outline:none;width:100%}.mc-range::-webkit-slider-thumb{-webkit-appearance:none;background:#6366f1;background:var(--primary-color,#6366f1);border-radius:50%;box-shadow:0 1px 6px #6366f159;cursor:pointer;height:16px;width:16px}.mc-range::-moz-range-thumb{background:#6366f1;background:var(--primary-color,#6366f1);border:none;border-radius:50%;cursor:pointer;height:16px;width:16px}[data-theme=dark] .mc-range{background:var(--color-gray-700)}.mc-summary-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.mc-summary-card{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9);border-radius:var(--radius-lg);padding:12px}[data-theme=dark] .mc-summary-card{background:#0f172a}.mc-summary-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-2xs);font-weight:700;letter-spacing:.06em;margin-bottom:6px;text-transform:uppercase}.mc-summary-val{font-size:var(--text-sm);font-weight:700}.mc-summary-val.ok{color:var(--color-success)}.mc-summary-val.off{color:#64748b;color:var(--text-secondary,#64748b)}.mc-time-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(270px,1fr))}.mc-time-card{background:#f8fafc;background:var(--bg-secondary,#f8fafc);border-radius:var(--radius-xl);padding:14px 16px}[data-theme=dark] .mc-time-card{background:#0f172a}.mc-time-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.mc-time-label{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-xs);font-weight:600}.mc-time-badge{border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;padding:2px 10px}.mc-time-scale{display:flex;font-size:var(--text-2xs);justify-content:space-between;margin-top:4px}.mc-time-desc,.mc-time-scale{color:#64748b;color:var(--text-secondary,#64748b)}.mc-time-desc{font-size:var(--text-sm);line-height:1.4;margin-top:8px}.mc-timeline{display:flex;flex-direction:column}.mc-timeline-item{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);display:flex;gap:14px;padding:10px 0}.mc-timeline-item:last-child{border-bottom:none}.mc-timeline-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.mc-timeline-time{color:#1e293b;color:var(--text-primary,#1e293b);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;min-width:44px}.mc-timeline-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm)}.mc-info-box{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9);border-left:3px solid #6366f1;border-left:3px solid var(--primary-color,#6366f1);border-radius:var(--radius-xl);padding:16px}[data-theme=dark] .mc-info-box{background:#0f172a}.mc-info-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-xs);font-weight:700;margin-bottom:12px}.mc-info-rows{display:flex;flex-direction:column;gap:8px}.mc-info-row{align-items:flex-start;display:flex;gap:12px}.mc-info-key{color:#6366f1;color:var(--primary-color,#6366f1);flex-shrink:0;font-size:var(--text-sm);font-weight:700;min-width:120px}.mc-info-val{color:#64748b;color:var(--text-secondary,#64748b);line-height:1.5}.mc-btn,.mc-info-val{font-size:var(--text-sm)}.mc-btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-weight:500;gap:6px;padding:8px 16px;transition:all .15s;white-space:nowrap}.mc-btn.accent{background:#6366f1;background:var(--primary-color,#6366f1);color:var(--text-inverse)}.mc-btn.accent:hover{filter:brightness(1.1)}.mc-btn.outline{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);color:#1e293b;color:var(--text-primary,#1e293b)}.mc-btn.outline:hover{background:#f1f5f9;background:var(--hover-bg,#f1f5f9)}[data-theme=dark] .mc-btn.outline:hover{background:#1e293b}.mc-save-bar{align-items:center;background:#fff;background:var(--card-bg,#fff);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color,#e2e8f0);bottom:0;box-shadow:0 -4px 20px #0000000f;display:flex;justify-content:space-between;left:0;padding:12px 24px;position:fixed;right:0;z-index:100}[data-theme=dark] .mc-save-bar{background:#1e293b;background:var(--card-bg,#1e293b);border-top-color:var(--color-gray-700)}.mc-save-left{align-items:center;display:flex;font-size:var(--text-sm);gap:6px}.mc-save-right{display:flex;gap:8px}.bs-facescan-wrap{margin-top:4px}.fsa-root{animation:fsa-in .3s ease;display:flex;flex-direction:column;gap:16px;padding-bottom:28px;position:relative}@keyframes fsa-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fsa-pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}@keyframes fsa-flash-in{0%{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}@keyframes fsa-init-bar{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.fsa-init-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffeb;border-radius:12px;border-radius:var(--radius-xl,12px);display:flex;inset:0;justify-content:center;min-height:420px;position:absolute;z-index:50}.fsa-init-card{align-items:center;display:flex;flex-direction:column;gap:14px;max-width:360px;padding:40px 32px;text-align:center}.fsa-init-icon{color:#6366f1;color:var(--color-primary,#6366f1)}.fsa-init-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:1.125rem;font-size:var(--text-lg,1.125rem);font-weight:800;margin:0}.fsa-init-spinner{color:#6366f1;color:var(--color-primary,#6366f1)}.fsa-init-msg{color:#64748b;color:var(--text-secondary,#64748b);font-size:.875rem;font-size:var(--text-sm,.875rem);line-height:1.5;margin:0}.fsa-init-bar{background:#e2e8f0;background:var(--border,#e2e8f0);height:4px;overflow:hidden;width:200px}.fsa-init-bar,.fsa-init-fill{border-radius:999px;border-radius:var(--radius-full,999px)}.fsa-init-fill{animation:fsa-init-bar 1.2s ease-in-out infinite;background:linear-gradient(90deg,#6366f1,#818cf8);background:linear-gradient(90deg,var(--color-primary,#6366f1),#818cf8);height:100%;width:60%}.fsa-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.fsa-title{align-items:center;color:#1e293b;color:var(--text-primary,#1e293b);display:flex;font-size:var(--text-2xl);font-weight:800;gap:8px;margin:0}.fsa-subtitle{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-xs);margin:3px 0 0}.fsa-header-right{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.fsa-chips{display:flex;flex-wrap:wrap;gap:6px}.fsa-chip{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-sm);font-weight:700;gap:4px;padding:4px 9px;white-space:nowrap}.chip-green{background:var(--color-success-bg);border:1px solid var(--color-success-border);color:var(--color-green-700)}.chip-amber{background:var(--color-orange-50);border:1px solid #fde68a;color:var(--color-orange)}.chip-red{background:var(--color-red-50);border:1px solid var(--color-red-light);color:var(--color-red-dark)}.chip-neutral{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);color:#64748b;color:var(--text-secondary,#64748b)}.fsa-mode-btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:inherit;font-size:var(--text-xs);font-weight:800;gap:6px;padding:7px 14px;transition:all .15s}.fsa-mode-auto{background:#6366f1;box-shadow:0 0 0 3px #6366f122;color:var(--text-inverse)}.fsa-mode-manual{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);color:#64748b;color:var(--text-secondary,#64748b)}.fsa-grid{grid-gap:16px;align-items:start;display:grid;gap:16px;grid-template-columns:minmax(0,400px) 1fr}@media(max-width:900px){.fsa-grid{grid-template-columns:1fr}}.fsa-cam-col{display:flex;flex-direction:column;gap:10px}.fsa-cam-card{background:#fff;background:var(--bg-card,#fff);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-xl);box-shadow:0 2px 8px #0000000f;overflow:hidden}.fsa-cam-wrap{aspect-ratio:4/3;background:#0f172a;overflow:hidden;position:relative}.fsa-video{display:block;height:100%;object-fit:cover;opacity:0;transform:scaleX(-1);transition:opacity .4s;width:100%}.fsa-video-on{opacity:1}.fsa-canvas{height:100%;inset:0;pointer-events:none;position:absolute;transform:scaleX(-1);width:100%}.fsa-cam-idle{align-items:center;background:#0f172a;display:flex;flex-direction:column;gap:12px;inset:0;justify-content:center;position:absolute}.fsa-cam-msg{color:#94a3b8;font-size:var(--text-sm);line-height:1.5;margin:0;max-width:260px;text-align:center}.fsa-live-badge{align-items:center;background:#ef4444cc;color:var(--text-inverse);display:flex;font-size:var(--text-2xs);font-weight:800;gap:5px;letter-spacing:.12em;padding:3px 8px 3px 6px;position:absolute;right:10px;top:10px}.fsa-live-badge,.fsa-live-dot{border-radius:var(--radius-full)}.fsa-live-dot{animation:fsa-pulse-dot 1s infinite;background:var(--surface-primary);height:7px;width:7px}.fsa-auto-pill{background:#fff3;border-radius:var(--radius-full);font-size:var(--text-2xs);padding:1px 5px}.fsa-lock-ring{display:grid;height:40px;left:8px;place-items:center;position:absolute;top:8px;width:40px}.fsa-lock-emoji{font-size:var(--text-sm);position:absolute}.fsa-flash{align-items:center;animation:fsa-flash-in .3s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172ad9;border:1px solid #22c55e44;border-radius:var(--radius-xl);bottom:12px;color:var(--text-inverse);display:flex;gap:10px;left:12px;max-width:calc(100% - 24px);padding:10px 14px;position:absolute}.fsa-flash-name{font-size:var(--text-base);font-weight:800}.fsa-flash-label{color:#86efac;font-size:var(--text-sm);margin-top:2px}.fsa-cam-bar{background:#f8fafc;background:var(--bg-secondary,#f8fafc);border-top:1px solid #e2e8f0;border-top:1px solid var(--border,#e2e8f0);display:flex;flex-wrap:wrap;gap:8px;padding:10px 12px}.fsa-rec-strip{background:#fff;background:var(--bg-card,#fff);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-xl);box-shadow:0 2px 6px #0000000a;padding:12px 14px;transition:border-color .2s,box-shadow .2s}.rec-matched{border-color:var(--color-success);box-shadow:0 0 0 3px var(--color-success-bg)}.fsa-rec-inner{align-items:center;display:flex;gap:12px}.fsa-rec-thumb{border:2px solid var(--color-success);border-radius:var(--radius-lg);flex-shrink:0;height:52px;object-fit:cover;width:52px}.fsa-rec-details{flex:1 1;min-width:0}.fsa-rec-name{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-base);font-weight:700}.fsa-rec-code{color:#64748b;color:var(--text-secondary,#64748b);font-family:var(--font-mono);font-size:var(--text-sm)}.fsa-rec-conf-row{align-items:center;display:flex;gap:7px;margin-top:5px}.fsa-conf-track{background:#e2e8f0;flex:1 1;height:5px;overflow:hidden}.fsa-conf-fill,.fsa-conf-track{border-radius:var(--radius-full)}.fsa-conf-fill{background:linear-gradient(90deg,var(--color-success),var(--color-success));height:100%;transition:width .4s}.fsa-conf-pct{color:var(--color-green-700);font-size:var(--text-sm);font-weight:700;min-width:30px;text-align:right}.fsa-conf-grade{border-radius:var(--radius-sm);font-size:var(--text-2xs);font-weight:700;padding:1px 6px;white-space:nowrap}.grade-auto{background:var(--color-success-bg);color:var(--color-green-700)}.grade-display{background:var(--color-orange-50);color:var(--color-orange)}.fsa-rec-idle{align-items:center;color:#64748b;color:var(--text-secondary,#64748b);display:flex;font-size:var(--text-xs);gap:8px}.fsa-auto-box{background:#fff;background:var(--bg-card,#fff);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-xl);font-size:var(--text-xs);line-height:1.7;padding:12px 14px}.fsa-auto-box-title{align-items:center;color:#1e293b;color:var(--text-primary,#1e293b);display:flex;font-size:var(--text-xs);font-weight:800;gap:5px;margin-bottom:6px}.fsa-auto-row{color:#64748b;color:var(--text-secondary,#64748b)}.fsa-auto-muted{align-items:center;color:#94a3b8;display:flex;font-size:var(--text-sm);gap:4px}.fsa-right-col{background:#fff;background:var(--bg-card,#fff);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-xl);box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;overflow:hidden}.fsa-tabs{background:#f8fafc;background:var(--bg-secondary,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border,#e2e8f0);display:flex}.fsa-tab{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:var(--text-xs);font-weight:700;gap:5px;justify-content:center;padding:11px 8px;transition:color .15s}.fsa-tab:hover{background:#f1f5f9;background:var(--bg-hover,#f1f5f9)}.fsa-tab.active,.fsa-tab:hover{color:#6366f1;color:var(--color-primary,#6366f1)}.fsa-tab.active{background:#fff;background:var(--bg-card,#fff);border-bottom-color:#6366f1;border-bottom-color:var(--color-primary,#6366f1)}.fsa-body{display:flex;flex-direction:column;gap:12px;min-height:320px;padding:16px}.fsa-body.table-body{gap:10px;padding:14px}.fsa-stats{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr)}.stat{align-items:center;border-radius:var(--radius-xl);display:flex;font-size:var(--text-xs);gap:8px;padding:10px}.stat b{display:block;font-size:var(--text-2xl);font-weight:800;line-height:1.1}.stat span{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-2xs);font-weight:600}.stat.green{background:var(--color-success-bg);color:var(--color-green-700)}.stat.amber{background:var(--color-orange-50);color:var(--color-orange)}.stat.blue{background:var(--color-primary-100);color:var(--color-primary-dark)}.stat.neutral{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9);color:#64748b;color:var(--text-secondary,#64748b)}@media(max-width:600px){.fsa-stats{grid-template-columns:repeat(2,1fr)}}.fsa-guide,.fsa-info,.fsa-warn{border-radius:var(--radius-lg);color:#64748b;color:var(--text-secondary,#64748b);display:flex;font-size:var(--text-xs);gap:7px;line-height:1.6;padding:9px 12px}.fsa-warn{background:#fefce8;border:1px solid #fde68a}.fsa-info{background:#eff6ff;border:1px solid #bfdbfe}.fsa-guide{background:#f0fdf4;border:1px solid var(--color-success-border)}.fsa-settings-btn{align-items:center;background:#0000;border:1px dashed #e2e8f0;border:1px dashed var(--border,#e2e8f0);border-radius:var(--radius-md);color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;display:flex;font-family:inherit;font-size:var(--text-sm);font-weight:700;gap:6px;padding:6px 10px;width:fit-content}.fsa-settings-btn:hover{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9)}.fsa-settings{background:#f8fafc;background:var(--bg-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:10px;padding:14px}.fsa-settings-head{align-items:center;color:#1e293b;color:var(--text-primary,#1e293b);display:flex;font-size:var(--text-xs);font-weight:800;gap:5px}.fsa-setting-row{display:flex;flex-direction:column;gap:4px}.fsa-setting-lab{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);font-weight:600}.fsa-setting-ctrl{align-items:center;display:flex;gap:8px}.fsa-setting-val{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);font-weight:700;min-width:36px;text-align:right}.fsa-range{accent-color:#6366f1;accent-color:var(--color-primary,#6366f1);cursor:pointer;flex:1 1;height:4px}.fsa-feed{border-top:1px solid #e2e8f0;border-top:1px solid var(--border,#e2e8f0);padding-top:10px}.fsa-feed-head{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-xs);font-weight:700;gap:6px;margin-bottom:8px}.fsa-feed-empty,.fsa-feed-head{align-items:center;display:flex}.fsa-feed-empty{color:#94a3b8;color:var(--text-secondary,#94a3b8);flex-direction:column;font-size:var(--text-sm);gap:8px;padding:24px 0;text-align:center}.fsa-feed-list{display:flex;flex-direction:column;gap:5px;max-height:260px;overflow-y:auto}.fsa-feed-item{align-items:center;background:#f8fafc;background:var(--bg-secondary,#f8fafc);border-left:3px solid #0000;border-radius:var(--radius-lg);display:flex;font-size:var(--text-sm);gap:8px;padding:7px 9px}.feed-ok{border-left-color:var(--color-success)}.feed-err{border-left-color:var(--color-red)}.fsa-feed-ph{border:1.5px solid #e2e8f0;border:1.5px solid var(--border,#e2e8f0);border-radius:50%;flex-shrink:0;height:32px;object-fit:cover;width:32px}.fsa-feed-body{flex:1 1;min-width:0}.fsa-feed-top{align-items:center;display:flex;gap:6px}.fsa-feed-top .fw{color:#1e293b;color:var(--text-primary,#1e293b);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fsa-feed-top .code{color:#64748b;color:var(--text-secondary,#64748b);font-family:var(--font-mono);font-size:var(--text-2xs)}.fsa-feed-bot{align-items:center;display:flex;gap:6px;margin-top:3px}.fsa-action-badge{align-items:center;border-radius:var(--radius-sm);display:inline-flex;font-size:var(--text-2xs);font-weight:700;gap:3px;padding:1px 6px}.fsa-action-badge.ok{background:var(--color-success-bg);color:var(--color-green-700)}.fsa-action-badge.err{background:var(--color-red-50);color:var(--color-red-dark)}.feed-note{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis}.feed-note,.feed-time{color:#94a3b8;font-size:var(--text-2xs);white-space:nowrap}.feed-time{margin-left:auto}.fsa-tbl-toolbar{align-items:flex-start;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.fsa-tbl-title{align-items:center;color:#1e293b;color:var(--text-primary,#1e293b);display:flex;flex-wrap:wrap;font-size:var(--text-base);font-weight:800;gap:7px}.fsa-tbl-date{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);font-weight:400}.fsa-tbl-right{align-items:center;display:flex;gap:7px}.fsa-search{background:#fff;background:var(--bg-card,#fff);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-lg);color:#1e293b;color:var(--text-primary,#1e293b);font-family:inherit;font-size:var(--text-xs);outline:none;padding:6px 10px;width:160px}.fsa-search:focus{border-color:#6366f1;border-color:var(--color-primary,#6366f1)}.fsa-refresh-note{color:#94a3b8;font-size:var(--text-2xs);margin:0}.fsa-tbl-stats{display:flex;flex-wrap:wrap;gap:8px}.ts{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-sm);font-weight:700;gap:4px;padding:3px 9px}.ts.green{background:var(--color-success-bg);color:var(--color-green-700)}.ts.amber{background:var(--color-orange-50);color:var(--color-orange)}.ts.blue{background:var(--color-primary-100);color:var(--color-primary-dark)}.ts.neutral{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9)}.fsa-tbl-empty,.fsa-tbl-loading,.ts.neutral{color:#64748b;color:var(--text-secondary,#64748b)}.fsa-tbl-empty,.fsa-tbl-loading{align-items:center;display:flex;flex:1 1;flex-direction:column;font-size:var(--text-sm);gap:10px;justify-content:center;padding:40px 20px;text-align:center}.fsa-tbl-empty .sub{color:#94a3b8;font-size:var(--text-sm);line-height:1.5;max-width:280px}.fsa-tbl-wrap{border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-xl);overflow-x:auto}.fsa-tbl{border-collapse:collapse;font-size:var(--text-xs);width:100%}.fsa-tbl thead th{background:#f8fafc;background:var(--bg-secondary,#f8fafc);color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);font-weight:700;padding:9px 10px;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:1}.fsa-tbl tbody tr,.fsa-tbl thead th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border,#e2e8f0)}.fsa-tbl tbody tr{transition:background .1s}.fsa-tbl tbody tr:hover{background:#f8fafc;background:var(--bg-secondary,#f8fafc)}.fsa-tbl tbody tr:last-child{border-bottom:none}.fsa-tbl td{color:#64748b;color:var(--text-secondary,#64748b);padding:9px 10px;vertical-align:middle;white-space:nowrap}.tr-present td{color:#1e293b;color:var(--text-primary,#1e293b)}.fsa-tbl-wrap{display:block;max-height:440px;overflow-y:auto}.emp-cell{align-items:center;display:flex;gap:8px}.emp-avatar{background:#6366f1;background:var(--color-primary,#6366f1);color:var(--text-inverse);display:grid;font-size:var(--text-sm);font-weight:800;height:28px;place-items:center;width:28px}.emp-avatar,.emp-avatar-img{border-radius:50%;flex-shrink:0}.emp-avatar-img{height:28px;object-fit:cover;width:28px}.emp-name{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-xs);font-weight:700}.emp-code{color:#64748b;color:var(--text-secondary,#64748b);font-family:var(--font-mono);font-size:var(--text-2xs)}.td-in{color:var(--color-green-700)!important}.td-in,.td-lo{font-weight:700}.td-lo{color:#b45309!important}.td-li{color:var(--color-primary-dark)!important}.td-li,.td-out{font-weight:700}.td-out{color:var(--color-red-dark)!important}.td-ot-in{color:var(--color-accent-dark)!important;font-weight:700}.td-ot-out{color:#6b21a8!important;font-weight:700}.td-hrs{font-weight:600}.td-hrs,.td-shift{font-family:var(--font-mono)}.td-shift{font-size:var(--text-sm)}.fsa-status{border-radius:var(--radius-full);font-size:var(--text-2xs);font-weight:700;padding:3px 8px;white-space:nowrap}.fsa-s-present{background:var(--color-success-bg);color:var(--color-green-700)}.fsa-s-absent{background:var(--color-red-50);color:var(--color-red-dark)}.fsa-s-half{background:var(--color-orange-50);color:var(--color-orange)}.fsa-s-leave{background:var(--color-primary-100);color:var(--color-primary-dark)}.fsa-s-holiday{background:var(--color-accent-50);color:var(--color-accent-dark)}.fsa-act-btn{align-items:center;background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-md);color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;display:inline-flex;height:26px;justify-content:center;transition:background .15s;width:26px}.fsa-act-btn:hover{background:#f1f5f9;color:#1e293b;color:var(--text-primary,#1e293b)}.fsa-msg{align-items:center;border-radius:var(--radius-lg);display:flex;font-size:var(--text-xs);font-weight:600;gap:7px;padding:9px 12px}.msg-ok{background:var(--color-success-bg);border:1px solid var(--color-success-border);color:var(--color-green-700)}.msg-err{background:var(--color-red-50);border:1px solid var(--color-red-light);color:var(--color-red-dark)}.fsa-thumb-row{align-items:center;display:flex;gap:12px}.fsa-thumb{border:2px solid var(--color-success);border-radius:var(--radius-lg);height:80px;object-fit:cover;width:80px}.fsa-thumb-ok{align-items:center;color:var(--color-green-700);display:flex;font-size:var(--text-xs);font-weight:600;gap:5px}.fsa-form-grp{display:flex;flex-direction:column;gap:5px}.fsa-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-xs);font-weight:700}.fsa-select{background:#fff;background:var(--bg-card,#fff);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-lg);color:#1e293b;color:var(--text-primary,#1e293b);cursor:pointer;font-family:inherit;font-size:var(--text-sm);outline:none;padding:8px 10px}.fsa-select:focus{border-color:#6366f1;border-color:var(--color-primary,#6366f1)}.fsa-empty{align-items:center;color:#64748b;color:var(--text-secondary,#64748b);display:flex;flex-direction:column;font-size:var(--text-base);gap:10px;justify-content:center;padding:36px 20px;text-align:center}.fsa-empty .sub{color:#94a3b8;font-size:var(--text-xs)}.fsa-enrolled-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}.enrolled-card{align-items:center;background:#f8fafc;background:var(--bg-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-xl);display:flex;gap:10px;padding:10px 12px}.enrolled-thumb{border:1.5px solid #e2e8f0;border:1.5px solid var(--border,#e2e8f0);border-radius:var(--radius-lg);flex-shrink:0;height:46px;object-fit:cover;width:46px}.enrolled-info{display:flex;flex:1 1;flex-direction:column;gap:1px;min-width:0}.enrolled-name{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-xs);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.enrolled-code{color:#64748b;color:var(--text-secondary,#64748b);font-family:var(--font-mono);font-size:var(--text-2xs)}.enrolled-date{color:#94a3b8;font-size:var(--text-2xs)}.fsa-del-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:#94a3b8;color:var(--text-secondary,#94a3b8);cursor:pointer;display:inline-flex;flex-shrink:0;height:28px;justify-content:center;transition:background .15s,color .15s;width:28px}.fsa-del-btn:hover{background:var(--color-red-50);color:var(--color-red-dark)}.fsa-btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:inherit;font-size:var(--text-xs);font-weight:700;gap:6px;padding:7px 14px;transition:filter .15s,opacity .15s;white-space:nowrap}.fsa-btn.primary{background:#6366f1;background:var(--color-primary,#6366f1);color:var(--text-inverse)}.fsa-btn.danger{background:var(--color-red-dark);color:var(--text-inverse)}.fsa-btn.ghost{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9);border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);color:#64748b;color:var(--text-secondary,#64748b)}.fsa-btn.full{font-size:var(--text-sm);justify-content:center;padding:10px;width:100%}.fsa-btn.sm{font-size:var(--text-sm);padding:5px 10px}.fsa-btn:disabled{cursor:not-allowed;opacity:.55}.fsa-btn:not(:disabled):hover{filter:brightness(1.08)}.fsa-btn:not(:disabled):active{filter:brightness(.95)}.fsa-micro-btn{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border,#e2e8f0);border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;font-family:inherit;font-size:var(--text-2xs);margin-left:auto;padding:2px 8px}.fsa-micro-btn:hover{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9)}.fsa-icon-green{color:var(--color-success)}.fsa-icon-red{color:var(--color-red-dark)}.fsa-icon-muted{color:#94a3b8}.mob-nav{background:var(--surface-primary);border-top:1px solid var(--border-default);bottom:0;box-shadow:0 -4px 20px #00000014;display:none;height:60px;left:0;padding-bottom:env(safe-area-inset-bottom,0);position:fixed;right:0;z-index:calc(var(--z-sticky) + 1)}@media (max-width:768px){.mob-nav{align-items:stretch;display:flex}}.mob-nav-item{-webkit-tap-highlight-color:transparent;align-items:center;background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-family:var(--font-sans);gap:3px;justify-content:center;min-height:44px;padding:6px 2px;position:relative;transition:color .15s ease}.mob-nav-item:active{opacity:.7}.mob-nav-item.active{color:#00c9a7;color:var(--color-teal,#00c9a7)}.mob-nav-item.active:after{background:#00c9a7;background:var(--color-teal,#00c9a7);border-radius:0 0 var(--radius-sm) var(--radius-sm);content:"";height:3px;left:50%;position:absolute;top:0;transform:translateX(-50%);width:28px}.mob-nav-icon{align-items:center;display:flex;justify-content:center;transition:transform .15s ease}.mob-nav-item.active .mob-nav-icon{transform:translateY(-1px)}.mob-nav-label{font-size:10px;font-weight:500;line-height:1}.mob-nav-item.active .mob-nav-label{font-weight:700}.srb-root{display:flex;flex-direction:column;gap:20px}.srb-header-form{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.srb-field{display:flex;flex-direction:column;gap:5px}.srb-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.srb-required{color:#ef4444;color:var(--color-red,#ef4444);margin-left:2px}.srb-optional{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-weight:400;letter-spacing:0;text-transform:none}.srb-input{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:8px;color:#1e293b;color:var(--text-primary,#1e293b);font-family:inherit;font-size:13px;padding:9px 12px;transition:border-color .15s}.srb-input:focus{border-color:#00e5c0;border-color:var(--color-primary,#00e5c0);outline:none}.srb-presets-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.srb-presets-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:11px;gap:5px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.srb-preset-btn,.srb-presets-label{align-items:center;display:flex;font-weight:600}.srb-preset-btn{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1.5px solid #e2e8f0;border:1.5px solid var(--border-default,#e2e8f0);border-radius:20px;color:#1e293b;color:var(--text-primary,#1e293b);cursor:pointer;font-family:inherit;font-size:12px;gap:6px;padding:5px 12px 5px 8px;transition:all .15s}.srb-preset-btn:hover{background:#e6faf7;background:var(--color-primary-faint,#e6faf7);border-color:#00e5c0;border-color:var(--color-primary,#00e5c0);color:#00b89c;color:var(--color-primary,#00b89c)}.srb-preset-num{align-items:center;background:#00e5c0;background:var(--color-primary,#00e5c0);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:11px;font-weight:800;height:20px;justify-content:center;width:20px}.srb-preset-btn:hover .srb-preset-num{background:#00b89c;background:var(--color-primary,#00b89c)}.srb-preset-desc{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:10px;font-weight:400}.srb-phases{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:12px;display:flex;flex-direction:column;gap:10px;padding:16px}.srb-phases-header{align-items:center;display:flex;justify-content:space-between}.srb-phases-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:13px;font-weight:700}.srb-phases-count{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:10px;color:#64748b;color:var(--text-secondary,#64748b);font-size:11px;font-weight:600;padding:2px 10px}.srb-empty{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:13px;line-height:1.6;padding:20px 12px;text-align:center}.srb-phase-list{display:flex;flex-direction:column;gap:8px}.srb-phase-row{align-items:center;background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:10px;display:flex;gap:10px;padding:10px 12px;transition:border-color .15s,box-shadow .15s}.srb-phase-row:hover{border-color:#cbd5e1;border-color:var(--border-strong,#cbd5e1);box-shadow:0 1px 4px #0000000f}.srb-phase-row--warn{background:#fffbeb;border-color:#f59e0b;border-color:var(--color-amber,#f59e0b)}.srb-phase-badge{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:12px;font-weight:800;height:28px;justify-content:center;width:28px}.srb-phase-shift{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.srb-phase-time{font-feature-settings:"tnum";font-size:11px;font-variant-numeric:tabular-nums;font-weight:600;padding-left:2px}.srb-phase-dur{align-items:center;display:flex;flex-shrink:0;gap:4px}.srb-dur-input{font-feature-settings:"tnum";background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:6px;color:#1e293b;color:var(--text-primary,#1e293b);font-family:inherit;font-size:13px;font-variant-numeric:tabular-nums;padding:6px 8px;text-align:center;width:54px}.srb-dur-input:focus{border-color:#00e5c0;border-color:var(--color-primary,#00e5c0);outline:none}.srb-dur-unit{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:6px;color:#1e293b;color:var(--text-primary,#1e293b);cursor:pointer;font-family:inherit;font-size:12px;padding:6px 8px}.srb-dur-unit:focus{border-color:#00e5c0;border-color:var(--color-primary,#00e5c0);outline:none}.srb-phase-flags{display:flex;flex-shrink:0;gap:4px}.srb-flag{align-items:center;border-radius:6px;display:flex;flex-shrink:0;height:22px;justify-content:center;width:22px}.srb-flag--night{background:#1e1b4b;color:#a5b4fc}.srb-flag--warn{background:#fef3c7;color:#d97706}.srb-phase-order{display:flex;flex-direction:column;flex-shrink:0;gap:2px}.srb-order-btn{align-items:center;background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:4px;color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;display:flex;height:18px;justify-content:center;padding:0;transition:all .12s;width:22px}.srb-order-btn:hover:not(:disabled){background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border-color:#cbd5e1;border-color:var(--border-strong,#cbd5e1);color:#1e293b;color:var(--text-primary,#1e293b)}.srb-order-btn:disabled{cursor:not-allowed;opacity:.3}.srb-remove-btn{align-items:center;background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:7px;color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;transition:all .12s;width:28px}.srb-remove-btn:hover{background:#fef2f2;background:var(--color-red-50,#fef2f2);border-color:#fca5a5;color:#ef4444;color:var(--color-red,#ef4444)}.srb-add-btn{align-items:center;align-self:flex-start;background:#0000;border:1.5px dashed #cbd5e1;border:1.5px dashed var(--border-default,#cbd5e1);border-radius:8px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;display:flex;font-family:inherit;font-size:12px;font-weight:600;gap:6px;padding:7px 14px;transition:all .15s}.srb-add-btn:hover{background:#e6faf7;background:var(--color-primary-faint,#e6faf7);border-color:#00e5c0;border-color:var(--color-primary,#00e5c0);color:#00b89c;color:var(--color-primary,#00b89c)}.srb-preview{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:16px}.srb-preview-header{align-items:center;display:flex;justify-content:space-between}.srb-preview-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:13px;font-weight:700}.srb-preview-total{color:#64748b;color:var(--text-secondary,#64748b);font-size:11px;font-weight:600}.srb-timeline{border-radius:8px;display:flex;gap:2px;height:36px;overflow:hidden}.srb-timeline-seg{align-items:center;border-radius:4px;cursor:default;display:flex;justify-content:center;min-width:24px;overflow:hidden;transition:opacity .15s}.srb-timeline-seg:hover{opacity:.85}.srb-timeline-label{color:#fff;font-size:11px;font-weight:800;overflow:hidden;padding:0 6px;text-overflow:ellipsis;text-shadow:0 1px 2px #00000040;white-space:nowrap}.srb-legend{display:flex;flex-wrap:wrap;gap:8px 18px}.srb-legend-item{align-items:center;display:flex;gap:6px}.srb-legend-dot{border-radius:3px;flex-shrink:0;height:10px;width:10px}.srb-legend-text{color:#64748b;color:var(--text-secondary,#64748b);font-size:12px}.srb-legend-time{font-size:11px}.srb-legend-days,.srb-legend-time{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.srb-legend-night{color:#818cf8;margin-left:4px;vertical-align:middle}.srb-stats-row{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:10px;flex-wrap:wrap;gap:20px;padding:12px 16px}.srb-stat,.srb-stats-row{align-items:center;display:flex}.srb-stat{flex-direction:column;gap:1px}.srb-stat-val{font-feature-settings:"tnum";color:#1e293b;color:var(--text-primary,#1e293b);font-size:22px;font-variant-numeric:tabular-nums;font-weight:800;line-height:1.1}.srb-stat-lbl{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.srb-stat--night .srb-stat-val{color:#818cf8}.srb-night-notice{align-items:center;background:#eef2ff;border-radius:20px;color:#818cf8;display:flex;font-size:11px;font-weight:500;gap:6px;margin-left:auto;padding:5px 12px}.srb-errors{display:flex;flex-direction:column;gap:5px}.srb-error-item{align-items:center;background:#fef2f2;background:var(--color-red-50,#fef2f2);border:1px solid #fca5a5;border-radius:7px;color:#ef4444;color:var(--color-red,#ef4444);display:flex;font-size:12px;gap:7px;padding:7px 12px}.srb-footer{display:flex;gap:10px;justify-content:flex-end;padding-top:4px}.srb-weekoff-section{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:16px}.srb-weekoff-header{align-items:center;display:flex;gap:7px}.srb-weekoff-icon{color:#00e5c0;color:var(--color-primary,#00e5c0)}.srb-weekoff-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:13px;font-weight:700}.srb-weekoff-options{display:flex;flex-direction:column;gap:8px}.srb-weekoff-option{align-items:flex-start;border:1.5px solid #e2e8f0;border:1.5px solid var(--border-default,#e2e8f0);border-radius:10px;cursor:pointer;display:flex;gap:10px;padding:10px 14px;transition:border-color .15s,background .15s}.srb-weekoff-option input[type=radio]{accent-color:#00e5c0;accent-color:var(--color-primary,#00e5c0);cursor:pointer;flex-shrink:0;margin-top:2px}.srb-weekoff-option--active{background:#e6faf7;background:var(--color-primary-faint,#e6faf7);border-color:#00e5c0;border-color:var(--color-primary,#00e5c0)}.srb-weekoff-option-body{display:flex;flex-direction:column;gap:2px}.srb-weekoff-option-label{color:#1e293b;color:var(--text-primary,#1e293b);font-size:13px;font-weight:600}.srb-weekoff-option-desc{color:#64748b;color:var(--text-secondary,#64748b);font-size:11px;line-height:1.5}.srb-restday-config{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:8px;display:flex;flex-direction:column;gap:10px;padding:12px 14px}.srb-restday-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.srb-restday-unit{color:#64748b;color:var(--text-secondary,#64748b);font-size:13px;white-space:nowrap}.srb-restday-auto-btn{background:#e6faf7;background:var(--color-primary-faint,#e6faf7);border:1px solid #00e5c0;border:1px solid var(--color-primary,#00e5c0);border-radius:6px;color:#00b89c;color:var(--color-primary,#00b89c);cursor:pointer;font-family:inherit;font-size:11px;font-weight:600;padding:4px 10px;transition:opacity .15s;white-space:nowrap}.srb-restday-auto-btn:hover{opacity:.8}.srb-restday-preview{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.srb-restday-preview-seg{border-radius:6px;font-size:12px;font-weight:600;padding:4px 12px}.srb-restday-preview-work{background:#dbeafe;color:#1d4ed8}.srb-restday-preview-rest{background:#f3e8ff;color:#7c3aed}.srb-restday-preview-arrow{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:14px;font-weight:700}.srb-restday-preview-total{color:#1e293b;color:var(--text-primary,#1e293b);font-size:13px;font-weight:700}.srb-restday-note{align-items:center;background:#f3e8ff;border-radius:6px;color:#7c3aed;display:flex;font-size:11px;gap:6px;padding:6px 10px}@media (max-width:640px){.srb-header-form{grid-template-columns:1fr}.srb-phase-row{flex-wrap:wrap;gap:8px}.srb-phase-shift{min-width:160px}.srb-presets-row{gap:6px}.srb-preset-desc{display:none}.srb-night-notice{margin-left:0}}.shm-root{display:flex;flex-direction:column;gap:20px;min-height:100%;padding:20px}.shm-toast{animation:shm-slide-in .2s ease;background:var(--color-green);border-radius:8px;box-shadow:0 4px 20px #0000001f;font-size:13px;font-weight:500;padding:10px 18px;position:fixed;right:20px;top:20px;z-index:9999}.shm-toast,.shm-toast.error{color:var(--surface-primary)}.shm-toast.error{background:var(--color-red)}@keyframes shm-slide-in{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.shm-add-btn{background:var(--color-primary);border:none;border-radius:8px;color:var(--surface-primary);cursor:pointer;font-size:13px;font-weight:600;height:36px;padding:0 18px;transition:opacity .15s}.shm-add-btn:hover{opacity:.85}.shm-error{background:var(--color-red-50);border-radius:6px;color:var(--color-red);font-size:13px;padding:8px 12px}.shm-loading{color:var(--text-secondary);font-size:13px;padding:20px 0}.shm-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}.shm-empty-cards{color:var(--text-secondary);font-size:13px;grid-column:1/-1;padding:40px 20px;text-align:center}.shm-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:12px;padding:18px;transition:box-shadow .15s,border-color .15s}.shm-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.shm-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.shm-card-title-row{align-items:center;display:flex;gap:10px}.shm-card-icon{align-items:center;border-radius:7px;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.shm-card-name{color:var(--text-primary);font-size:14px;font-weight:700}.shm-card-actions{display:flex;gap:4px}.shm-icon-btn{align-items:center;background:#0000;border:1px solid var(--border-default);border-radius:5px;color:var(--text-secondary);cursor:pointer;display:inline-flex;height:26px;justify-content:center;transition:all .15s;width:26px}.shm-icon-btn:hover{background:var(--surface-tertiary);color:var(--text-primary)}.shm-icon-btn.danger:hover{background:var(--color-red-50);border-color:var(--color-red-light);color:var(--color-red)}.shm-card-rows{display:flex;flex-direction:column;gap:0}.shm-card-row{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:7px 0}.shm-card-row:last-child{border-bottom:none}.shm-row-label{color:var(--text-secondary);font-size:11px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.shm-row-value{color:var(--text-primary);font-size:13px;font-weight:500}.shm-row-value.time{font-feature-settings:"tnum";color:var(--color-primary);font-variant-numeric:tabular-nums}.shm-row-value.emp{font-size:14px;font-weight:800}.shm-assignment-panel{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:12px;overflow:hidden}.shm-panel-header{align-items:center;border-bottom:1px solid var(--border-default);display:flex;gap:10px;padding:16px 20px}.shm-panel-icon{align-items:center;color:var(--color-primary);display:flex}.shm-panel-title{color:var(--text-primary);font-size:15px;font-weight:700}.shm-table-wrap{overflow-x:auto}.shm-table{border-collapse:collapse;min-width:600px;width:100%}.shm-th{background:var(--surface-secondary);border-bottom:1px solid var(--border-default);color:var(--text-secondary);font-size:10px;font-weight:600;letter-spacing:.08em;padding:10px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.shm-tr{border-bottom:1px solid var(--border-light);transition:background .12s}.shm-tr:hover{background:var(--surface-tertiary)}.shm-tr:last-child{border-bottom:none}.shm-td{color:var(--text-primary);font-size:13px;padding:11px 16px;vertical-align:middle}.shm-emp-cell{align-items:center;display:flex;gap:10px}.shm-avatar{align-items:center;color:var(--surface-primary);display:flex;font-size:11px;font-weight:700;justify-content:center;text-transform:uppercase}.shm-avatar,.shm-avatar-img{border-radius:50%;flex-shrink:0;height:34px;width:34px}.shm-avatar-img{object-fit:cover}.shm-emp-name{font-weight:500;white-space:nowrap}.shm-dept-badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:600;padding:2px 10px;white-space:nowrap}.shm-shift-name{font-size:13px;font-weight:600}.shm-no-shift{color:var(--text-tertiary);font-size:12px;font-style:italic}.shm-time{font-feature-settings:"tnum";font-size:12px;font-variant-numeric:tabular-nums}.shm-empty-row,.shm-time{color:var(--text-secondary)}.shm-empty-row{font-size:13px;padding:30px;text-align:center}.shm-change-select{font-size:12px;min-width:160px}.shm-change-select .ss-searchable__trigger{background:var(--surface-primary);border-color:var(--border-default);border-radius:6px;color:var(--text-primary);font-size:12px;height:32px}@media (max-width:768px){.shm-cards{grid-template-columns:1fr}.shm-table{min-width:520px}.shm-root{gap:14px;padding:12px}}.shift-modal{max-height:90vh;max-width:1100px!important}.srb-modal{max-height:90vh;max-width:720px!important}.shift-form-layout{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;min-height:0}.calculation-slot-section,.shift-details-section{display:flex;flex-direction:column;gap:18px;min-height:0}.calculation-slot-section h3,.shift-details-section .form-section h3{border-bottom:1px solid var(--border-light);color:var(--text-primary);font-size:14px;font-weight:700;margin:0 0 8px;padding-bottom:6px}.shift-details-section .form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.shift-details-section .form-grid .full-width{grid-column:1/-1}.timing-grid{display:flex;flex-direction:column;gap:8px}.timing-row{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:90px 1fr}.timing-label{color:var(--text-secondary);font-size:12px;font-weight:600;white-space:nowrap}.timing-inputs{display:flex;gap:6px}.timing-inputs input[type=time]{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:6px;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:12px;min-width:0;padding:6px 8px}.timing-inputs input[type=time]:focus{border-color:var(--color-primary);outline:none}.simple-timing-form{display:flex;flex-direction:column;gap:16px}.simple-timing-row{display:flex;flex-wrap:wrap;gap:12px}.simple-timing-row--inline{margin-top:10px}.simple-timing-field{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:100px}.simple-timing-field label{color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.simple-timing-field input[type=number],.simple-timing-field input[type=time],.simple-timing-field select{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:13px;padding:8px 10px}.simple-timing-field input[type=number]:focus,.simple-timing-field input[type=time]:focus,.simple-timing-field select:focus{border-color:var(--color-primary);outline:none}.simple-toggle-row{background:#f7f8fa;background:var(--surface-secondary,#f7f8fa);border:1px solid var(--border-default);border-radius:8px;display:flex;flex-direction:column;gap:0;padding:10px 12px}.simple-toggle-label{align-items:center;color:var(--text-primary);cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:8px;-webkit-user-select:none;user-select:none}.simple-toggle-label input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;height:16px;width:16px}.timing-view p{color:var(--text-primary);font-size:13px;line-height:1.6;margin:4px 0}.working-hours-display{align-items:baseline;display:flex;gap:6px;padding:8px 0}.hours-value{font-feature-settings:"tnum";color:var(--color-primary);font-size:24px;font-variant-numeric:tabular-nums;font-weight:800}.hours-label{color:var(--text-secondary);font-size:12px}.help-text{color:var(--text-tertiary);font-size:11px;margin-top:4px}.slot-table-container{border:1px solid var(--border-default);border-radius:8px;overflow-x:auto}.slot-table{border-collapse:collapse;font-size:12px;min-width:500px;width:100%}.slot-table th{background:var(--surface-secondary);border-bottom:1px solid var(--border-default);color:var(--text-secondary);font-size:10px;font-weight:600;letter-spacing:.05em;padding:8px 10px;text-align:left;text-transform:uppercase;white-space:nowrap}.slot-table td{font-feature-settings:"tnum";border-bottom:1px solid var(--border-light);color:var(--text-primary);font-variant-numeric:tabular-nums;padding:7px 10px}.slot-table tr:last-child td{border-bottom:none}.slot-actions{display:flex;gap:8px;margin-top:8px}.slot-actions .btn-sm{font-size:11px;padding:5px 12px}@media (max-width:900px){.shift-form-layout,.timing-row{grid-template-columns:1fr}.timing-row{gap:4px}}.shm-tabs{border-bottom:2px solid var(--border-default);display:flex;gap:4px;margin-bottom:4px}.shm-tab{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;margin-bottom:-2px;padding:8px 16px;transition:color .15s,border-color .15s}.shm-tab:hover{color:var(--text-primary)}.shm-tab--active{border-bottom-color:var(--color-primary);color:var(--color-primary)}.shm-rotation-badge{border-radius:10px;display:inline-block;font-size:11px;font-weight:600;margin-bottom:2px;margin-right:4px;padding:2px 8px}.shm-topbar{align-items:center;display:flex;gap:8px;justify-content:flex-end}.shm-history-btn{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:11px;font-weight:600;padding:4px 10px;transition:border-color .15s,color .15s;white-space:nowrap}.shm-history-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.shift-history-modal{max-width:95vw;width:520px}.sh-empty,.sh-loading{color:var(--text-secondary);font-size:14px;line-height:1.7;padding:32px;text-align:center}.sh-timeline{display:flex;flex-direction:column;gap:0;padding:8px 4px 8px 0}.sh-entry{display:flex;gap:14px;padding:4px 0}.sh-entry--current .sh-entry-body{background:#e6faf7;background:var(--color-primary-faint,#e6faf7);border-radius:8px}.sh-dot-col{align-items:center;display:flex;flex-direction:column;flex-shrink:0;padding-top:6px;width:16px}.sh-dot{border-radius:50%;flex-shrink:0;height:12px;width:12px}.sh-dot--direct{background:#00e5c0;background:var(--color-primary,#00e5c0)}.sh-dot--rotation{background:#8b5cf6}.sh-line{background:var(--border-default);flex:1 1;margin:3px 0;min-height:20px;width:2px}.sh-entry-body{flex:1 1;margin-bottom:6px;padding:8px 12px}.sh-entry-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.sh-type-badge{border-radius:10px;font-size:10px;font-weight:700;padding:2px 7px;white-space:nowrap}.sh-badge--direct{background:#e6faf7;color:#00b89c}.sh-badge--rotation{background:#f3eeff;color:#8b5cf6}.sh-label{color:var(--text-primary);font-size:13px;font-weight:600}.sh-current-tag{background:#00e5c0;background:var(--color-primary,#00e5c0);border-radius:10px;color:#fff;font-size:10px;font-weight:700;padding:1px 7px}.sh-dates{align-items:center;color:var(--text-secondary);display:flex;font-size:12px;gap:6px}.sh-arrow{font-size:10px}.sh-arrow,.sh-notes{color:var(--text-tertiary)}.sh-notes{font-size:11px;font-style:italic;margin-top:4px}.shm-root--new{gap:0;padding:0}.shm-sub-hdr{align-items:center;background:var(--surface-primary);border-bottom:1px solid var(--border-default);display:flex;flex-shrink:0;gap:12px;justify-content:space-between;padding:14px 20px}.shm-page-title{color:var(--text-primary);font-size:16px;font-weight:700}.shm-page-sub{color:var(--text-tertiary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:11px;margin-top:2px}.shm-hdr-right{align-items:center;display:flex;gap:8px}.shm-seg{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:8px;display:flex;gap:2px;padding:3px}.shm-seg-btn{background:#0000;border:none;border-radius:5px;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;padding:5px 14px;transition:all .12s;white-space:nowrap}.shm-seg-btn.on{background:var(--surface-primary);box-shadow:0 1px 3px #00000014;color:var(--text-primary);font-weight:600}.shm-seg-btn:hover:not(.on){background:var(--surface-tertiary);color:var(--text-primary)}.shm-unified{display:grid;flex:1 1;grid-template-columns:220px 260px 1fr;height:calc(100vh - 161px);min-height:0;overflow:hidden}.shm-col-list{background:var(--surface-primary);border-right:1px solid var(--border-default);display:flex;flex-direction:column;overflow:hidden}.shm-col-hdr{border-bottom:1px solid var(--border-default);flex-shrink:0;justify-content:space-between;padding:12px 14px}.shm-col-hdr,.shm-col-title{align-items:center;display:flex}.shm-col-title{color:var(--text-secondary);font-size:10px;font-weight:700;gap:6px;letter-spacing:.07em;text-transform:uppercase}.shm-col-count{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:20px;color:var(--text-tertiary);font-size:10px;font-weight:500;padding:1px 6px}.shm-col-add{color:var(--color-primary);cursor:pointer;font-size:12px;font-weight:500}.shm-col-add:hover{opacity:.75}.shm-col-search-wrap{border-bottom:1px solid var(--border-default);flex-shrink:0;padding:8px 10px}.shm-col-search{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:12px;outline:none;padding:5px 10px;transition:border-color .15s;width:100%}.shm-col-search:focus{border-color:var(--color-primary)}.shm-col-scroll{flex:1 1;overflow-y:auto}.shm-col-empty{color:var(--text-tertiary);font-size:12px;padding:20px;text-align:center}.shm-slist-item{align-items:center;border-bottom:1px solid var(--border-light);border-left:2.5px solid #0000;cursor:pointer;display:flex;gap:8px;padding:9px 12px;transition:background .1s}.shm-slist-item:hover{background:var(--surface-secondary)}.shm-slist-item.active{background:#e6faf7;background:var(--color-primary-faint,#e6faf7);border-left-color:var(--color-primary)}.shm-slist-item.active .shm-slist-name{color:var(--color-primary)}.shm-slist-dot{border-radius:50%;flex-shrink:0;height:9px;width:9px}.shm-slist-info{flex:1 1;min-width:0}.shm-slist-name{color:var(--text-primary);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shm-slist-time{color:var(--text-tertiary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:10px;margin-top:2px}.shm-slist-emp{flex-shrink:0;font-size:12px;font-weight:700}.shm-slist-acts{display:flex;gap:3px;opacity:0;transition:opacity .12s}.shm-rlist-item:hover .shm-slist-acts,.shm-slist-item:hover .shm-slist-acts{opacity:1}.shm-rlist-item{border-bottom:1px solid var(--border-light);border-left:2.5px solid #0000;cursor:pointer;padding:10px 12px;transition:background .1s}.shm-rlist-item:hover{background:var(--surface-secondary)}.shm-rlist-item.active{background:#e6faf7;background:var(--color-primary-faint,#e6faf7);border-left-color:var(--color-primary)}.shm-rlist-item.active .shm-rlist-name{color:var(--color-primary)}.shm-rlist-top{align-items:flex-start;display:flex;gap:6px;justify-content:space-between}.shm-rlist-meta{flex:1 1;min-width:0}.shm-rlist-name{color:var(--text-primary);font-size:12px;font-weight:600;line-height:1.3}.shm-rlist-cycle{color:var(--text-tertiary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:10px;margin-top:2px}.shm-rlist-pills{display:flex;flex-wrap:wrap;gap:4px;margin-top:7px}.shm-pill{border-radius:4px;font-family:monospace;font-family:var(--font-mono,monospace);font-size:10px;font-weight:700;padding:2px 7px}.shm-col-detail{background:var(--surface-secondary);display:flex;flex-direction:column;overflow-y:auto}.shm-detail-empty{color:var(--text-tertiary);flex:1 1;flex-direction:column;gap:10px}.shm-detail-empty,.shm-empty-icon{align-items:center;display:flex;justify-content:center}.shm-empty-icon{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:50%;height:44px;width:44px}.shm-empty-text{font-size:13px}.shm-detail-card{animation:slideInDetail .18s ease both;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:12px;margin:14px;overflow:hidden}@keyframes slideInDetail{0%{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}.shm-det-head{align-items:flex-start;border-bottom:1px solid var(--border-default);display:flex;gap:12px;justify-content:space-between;padding:14px 18px}.shm-det-title{color:var(--text-primary);font-size:14px;font-weight:700}.shm-det-sub{color:var(--text-tertiary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:11px;margin-top:3px}.shm-det-acts{display:flex;flex-shrink:0;gap:7px}.shm-det-body{padding:16px 18px}.shm-det-field-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:14px}.shm-det-field{display:flex;flex-direction:column;gap:4px}.shm-det-flabel{color:var(--text-tertiary);font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.shm-det-fval{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:6px;color:var(--text-primary);font-size:12px;padding:6px 10px}.shm-det-fval.accent{color:var(--color-primary);font-family:monospace;font-family:var(--font-mono,monospace);font-weight:600}.shm-det-kpi-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);margin-bottom:14px}.shm-det-kpi{background:var(--surface-secondary);border-radius:8px;padding:10px 12px;text-align:center}.shm-kpi-val{color:var(--text-primary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:22px;font-weight:800;line-height:1}.shm-kpi-lbl{color:var(--text-secondary);font-size:10px;margin-top:4px}.shm-det-seq{margin-bottom:14px}.shm-det-seq-label{color:var(--text-tertiary);font-size:9px;font-weight:700;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.shm-det-seq-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.shm-seq-chip{border-radius:7px;font-family:monospace;font-family:var(--font-mono,monospace);font-size:11px;font-weight:700;padding:5px 12px}.shm-seq-arrow{color:var(--text-tertiary);font-size:13px}.shm-wo-chip{background:#e6fdf0;background:var(--color-green-faint,#e6fdf0);border:1px solid #86efac;border:1px solid var(--color-green-light,#86efac);border-radius:7px;color:#14532d;color:var(--color-green,#14532d);font-size:11px;font-weight:700;padding:5px 12px}.shm-seq-repeat,.shm-wo-chip{font-family:monospace;font-family:var(--font-mono,monospace)}.shm-seq-repeat{color:var(--text-tertiary);font-size:10px}.shm-det-divider{background:var(--border-default);height:1px;margin:12px 0}.shm-det-emp-hdr{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.shm-det-sec-title{color:var(--text-tertiary);font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.shm-det-no-emp{color:var(--text-tertiary);font-size:12px;padding:16px 0;text-align:center}.shm-det-emp-row{align-items:center;border-bottom:1px solid var(--border-light);display:flex;gap:9px;padding:7px 0}.shm-det-emp-row:last-child{border-bottom:none}.shm-det-emp-info{flex:1 1}.shm-det-emp-name{color:var(--text-primary);font-size:12px;font-weight:600}.shm-det-emp-meta{color:var(--text-tertiary);margin-top:1px}.shm-det-emp-meta,.shm-det-emp-tag{font-family:monospace;font-family:var(--font-mono,monospace);font-size:10px}.shm-det-emp-tag{border-radius:5px;flex-shrink:0;font-weight:700;padding:3px 9px}.shm-det-more{color:var(--text-tertiary);font-size:11px;padding:6px 0;text-align:center}.shm-root--new .shm-assignment-panel,.shm-root--new .shm-cards{margin:16px 20px 0}.shm-root--new .shm-cards{margin-bottom:0}.shm-root--new .shm-assignment-panel:last-child{margin-bottom:16px}@media (max-width:1024px){.shm-unified{grid-template-columns:200px 240px 1fr}}@media (max-width:800px){.shm-unified{grid-template-columns:1fr;height:auto;overflow:visible}.shm-col-list{max-height:280px}.shm-col-detail{min-height:400px}}.sp-root{animation:sp-fadein .3s ease;display:flex;flex-direction:column;gap:18px;min-width:0;overflow-x:auto;overflow-y:visible}@keyframes sp-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sp-loading{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-base);padding:60px;text-align:center}.sp-toast{animation:sp-fadein .2s;border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:600;padding:10px 20px;position:fixed;right:20px;top:20px;z-index:9999}.sp-toast.success{background:var(--color-green-50);border:1px solid var(--color-green-100);color:var(--color-green-600)}.sp-toast.error{background:var(--color-red-50);border:1px solid var(--color-red-light);color:var(--color-red-dark)}.sp-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.sp-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-2xl);font-weight:800;margin:0}.sp-subtitle{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-xs);margin:2px 0 0}.sp-header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end;min-width:0}.sp-export-wrap{position:relative}.sp-export-popup{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);box-shadow:0 8px 24px #0000001f;display:flex;flex-direction:column;gap:2px;min-width:200px;overflow:hidden;padding:6px;position:absolute;right:0;top:calc(100% + 6px);z-index:999}.sp-export-opt{align-items:center;background:#0000;border:none;border-radius:var(--radius-lg);color:#1e293b;color:var(--text-primary,#1e293b);cursor:pointer;display:flex;gap:10px;padding:10px 12px;text-align:left;transition:background .15s;width:100%}.sp-export-opt:hover{background:#f1f5f9;background:var(--hover-bg,#f1f5f9)}.sp-export-opt svg{color:#6366f1;flex-shrink:0}.sp-export-opt-title{font-size:var(--text-sm);font-weight:600;line-height:1.3}.sp-export-opt-sub{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm)}.sp-btn{align-items:center;border:none;border-radius:var(--radius-xl);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:var(--text-xs);font-weight:700;gap:6px;padding:8px 14px;transition:all .15s;white-space:nowrap}.sp-btn.accent{background:#6366f1;background:var(--primary-color,#6366f1);color:var(--text-inverse)}.sp-btn.gold{background:var(--color-orange-50);color:var(--color-orange)}.sp-btn.blue{background:var(--color-primary-100);color:var(--color-primary)}.sp-btn.green{background:var(--color-success);color:var(--text-inverse)}.sp-btn.outline{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);color:#1e293b;color:var(--text-primary,#1e293b)}.sp-btn:hover{opacity:.85}.sp-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.sp-view-tabs{display:flex;gap:6px}.sp-tab{border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-xs);font-weight:700;padding:7px 16px;transition:all .15s}.sp-tab.active{background:#00897b1f;background:var(--color-primary-100,#00897b1f);border-color:#00897b;border-color:var(--color-primary,#00897b);color:#00695c;color:var(--color-primary-dark,#00695c)}.sp-filters{display:flex;gap:8px}.sp-select{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);color:#1e293b;color:var(--text-primary,#1e293b);cursor:pointer;font-size:var(--text-xs);padding:7px 12px}.sp-legend{flex-wrap:wrap;gap:10px}.sp-legend,.sp-legend-item{align-items:center;display:flex}.sp-legend-item{border:1px solid;border-radius:var(--radius-3xl);gap:6px;padding:4px 12px}.sp-legend-code{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:800}.sp-legend-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm)}.sp-legend-time{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-family:var(--font-mono);font-size:var(--text-2xs)}.sp-legend-tip{color:#6366f1;color:var(--primary-color,#6366f1);font-size:var(--text-sm);margin-left:auto}.sp-table-wrap{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);max-height:calc(100vh - 320px);overflow:auto}.sp-table{border-collapse:collapse;min-width:700px;width:100%}.sp-table thead tr{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0)}.sp-table th{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs);font-weight:700;letter-spacing:.6px;padding:10px 8px;text-align:center;white-space:nowrap}.sp-th-emp{min-width:180px;padding-left:14px;text-align:left}.sp-th-dept{min-width:70px}.sp-th-day{min-width:54px}.sp-th-day.sun{color:var(--color-red)}.sp-th-off{min-width:42px}.sp-table tbody tr{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);transition:background .12s}.sp-table tbody tr:hover{background:#f8fafc;background:var(--surface-hover,#f8fafc)}.sp-table tbody tr.alt{background:#f8fafc80;background:var(--table-alt,#f8fafc80)}.sp-td-emp{padding:8px 14px}.sp-td-dept{padding:8px 6px;text-align:center}.sp-emp-cell{gap:8px}.sp-emp-avatar,.sp-emp-cell{align-items:center;display:flex}.sp-emp-avatar{border-radius:50%;color:var(--text-inverse);flex-shrink:0;font-size:var(--text-2xs);font-weight:700;height:28px;justify-content:center;width:28px}.sp-emp-name{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-xs);font-weight:700}.sp-emp-code{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-family:var(--font-mono);font-size:var(--text-2xs)}.sp-dept-badge{border-radius:var(--radius-xl);font-size:var(--text-2xs);font-weight:700;padding:2px 8px;white-space:nowrap}.sp-td-cell{padding:6px 4px;text-align:center}.sp-shift-cell{border:1px solid;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-mono);font-size:var(--text-sm);font-weight:800;min-width:46px;padding:4px 0;text-align:center;transition:all .15s;-webkit-user-select:none;user-select:none}.sp-shift-cell:hover{transform:scale(1.08)}.sp-edit-wrap{position:relative}.sp-cell-select{background:#fff;background:var(--card-bg,#fff);border:1.5px solid #6366f1;border:1.5px solid var(--primary-color,#6366f1);border-radius:var(--radius-md);color:#1e293b;color:var(--text-primary,#1e293b);cursor:pointer;font-family:var(--font-mono);font-size:var(--text-sm);font-weight:800;outline:none;padding:3px 2px;text-align:center;width:46px}.sp-cell-select:focus{box-shadow:0 0 0 2px #6366f140}.sp-td-off{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:800;padding:8px;text-align:center}.sp-td-off .warn{color:var(--color-red)}.sp-empty{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-sm);padding:40px;text-align:center}.sp-summary-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.sp-summary-card{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);padding:14px}.sp-summary-top{align-items:center;display:flex;gap:10px;margin-bottom:6px}.sp-summary-info{flex:1 1;min-width:0}.sp-main-shift{border-radius:var(--radius-3xl);display:inline-block;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:800;margin-bottom:10px;padding:3px 10px}.sp-summary-days{display:flex;gap:4px}.sp-summary-day{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:3px}.sp-day-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs);font-weight:700}.sp-day-label.sun{color:var(--color-red)}.sp-day-block{align-items:center;border-radius:var(--radius-md);display:flex;font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:800;height:28px;justify-content:center;width:100%}.sp-stats-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.sp-stat-card{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);padding:8px 10px}.sp-stat-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:6px}.sp-stat-label{font-weight:700;letter-spacing:.6px}.sp-stat-label,.sp-stat-time{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:9px}.sp-stat-time{font-family:var(--font-mono);margin-top:1px}.sp-stat-count{font-family:var(--font-mono);font-size:20px;font-weight:800}.sp-stat-bar{height:4px;margin-top:3px;overflow:hidden}.sp-stat-bar,.sp-stat-fill{border-radius:var(--radius-full)}.sp-stat-fill{height:100%;transition:width .5s ease}.sp-stat-footer{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:9px;margin-top:4px}.sp-dept-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}.sp-dept-row{align-items:center;display:flex;gap:8px}.sp-dept-dot{border-radius:var(--radius-sm);flex-shrink:0;height:10px;width:10px}.sp-dept-name{color:#64748b;color:var(--text-secondary,#64748b);flex:1 1;font-size:var(--text-xs)}.sp-dept-count{color:#1e293b;color:var(--text-primary,#1e293b);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:800}.sp-modal-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:1300}.sp-modal{background:#fff;background:var(--card-bg,#fff);border-radius:var(--radius-3xl);box-shadow:0 20px 60px #00000040;max-height:85vh;overflow-y:auto;padding:26px;width:90%}.sp-modal h3{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-lg);font-weight:800;margin:0 0 18px}.sp-modal-body{display:flex;flex-direction:column;gap:16px}.sp-modal-row-2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.sp-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);display:block;font-weight:700;letter-spacing:.7px;margin-bottom:4px;text-transform:uppercase}.sp-input,.sp-label{font-size:var(--text-sm)}.sp-input{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);box-sizing:border-box;color:#1e293b;color:var(--text-primary,#1e293b);padding:9px 12px;width:100%}.sp-shift-pills{display:flex;flex-wrap:wrap;gap:6px}.sp-shift-pill{background:#0000;border:1.5px solid #e2e8f0;border:1.5px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;padding:6px 14px;transition:all .15s}.sp-shift-pill:hover{opacity:.85}.sp-day-pills{display:flex;flex-wrap:wrap;gap:6px}.sp-pill{background:#0000;border:1.5px solid #e2e8f0;border:1.5px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;font-size:var(--text-xs);font-weight:700;padding:6px 12px;transition:all .15s}.sp-pill.active{background:#6366f11a;border-color:#6366f1;border-color:var(--primary-color,#6366f1);color:#6366f1;color:var(--primary-color,#6366f1)}.sp-pill.active.gold{background:var(--color-orange-50);border-color:var(--color-orange);color:var(--color-orange)}.sp-modal-preview{background:#6366f114;border-radius:var(--radius-xl);color:#6366f1;color:var(--primary-color,#6366f1);font-size:var(--text-xs);line-height:1.5;padding:12px 14px}.sp-modal-actions{display:flex;gap:10px}.sp-modal-actions .sp-btn{flex:1 1;justify-content:center}.sp-swap-preview{align-items:center;background:var(--color-orange-50);border-radius:var(--radius-xl);color:var(--color-orange);display:flex;flex-wrap:wrap;font-size:var(--text-xs);gap:8px;padding:12px 14px}.sp-swap-badge{border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:800;padding:2px 8px}.sp-swap-arrow{font-size:var(--text-base)}.sp-swap-day{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs);margin-left:4px}.sp-table thead{top:0;z-index:4}.sp-table .sp-td-emp,.sp-table .sp-th-emp,.sp-table thead{background:#fff;background:var(--card-bg,#fff);position:sticky}.sp-table .sp-td-emp,.sp-table .sp-th-emp{box-shadow:2px 0 4px -2px #00000014;left:0;z-index:2}.sp-table tbody tr.alt .sp-td-emp{background:#f8fafcf2;background:var(--table-alt,#f8fafcf2)}.sp-table tbody tr:hover .sp-td-emp{background:#f8fafc;background:var(--surface-hover,#f8fafc)}.sp-table thead .sp-th-emp{z-index:5}.sp-table .sp-td-dept,.sp-table .sp-th-dept{background:#fff;background:var(--card-bg,#fff);box-shadow:2px 0 4px -2px #0000000d;left:180px;position:sticky;z-index:1}.sp-table tbody tr.alt .sp-td-dept{background:#f8fafcf2;background:var(--table-alt,#f8fafcf2)}.sp-table tbody tr:hover .sp-td-dept{background:#f8fafc;background:var(--surface-hover,#f8fafc)}.sp-table thead .sp-th-dept{z-index:3}.sp-emp-cell{max-width:152px;overflow:hidden}.sp-emp-name{max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:1024px){.sp-header{align-items:flex-start;flex-direction:column;gap:10px}.sp-header-actions{justify-content:flex-start;width:100%}}@media (max-width:768px){.sp-modal-row-2{grid-template-columns:1fr}.sp-toolbar{align-items:stretch}.sp-header,.sp-toolbar{flex-direction:column;gap:8px}.sp-header{align-items:flex-start}.sp-table-wrap{-webkit-overflow-scrolling:touch;max-height:calc(100vh - 280px);overflow-x:auto}.sp-btn{font-size:11px;padding:6px 10px}}@media (max-width:480px){.sp-root{padding:8px}.sp-btn{font-size:10px;gap:4px;padding:6px 8px}.sp-btn svg{height:12px;width:12px}}.sp-table-v2{table-layout:fixed}.sp-table-v2 .sp-th-emp{min-width:200px;width:200px}.sp-th-day-v2{background:#f1f5f9;background:var(--table-header-bg,#f1f5f9);font-size:11px;padding:10px 4px;text-align:center;white-space:nowrap}.sp-th-day-v2.sun{background:#fef2f2}.sp-th-day-name{color:#1e293b;color:var(--text-primary,#1e293b);font-size:12px;font-weight:800;letter-spacing:.5px}.sp-th-day-date{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:10px;font-weight:500;margin-top:2px}.sp-dept-badge-sm{border-radius:8px;display:inline-block;font-size:9px;font-weight:700;margin-top:2px;padding:1px 6px;white-space:nowrap}.sp-td-cell-v2{padding:4px 3px;text-align:center;vertical-align:middle}.sp-td-cell-v2.off-day{background:#fef2f208}.sp-shift-cell-v2{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:1px;justify-content:center;min-height:52px;padding:6px 4px;transition:all .15s ease}.sp-shift-cell-v2:hover{box-shadow:0 2px 8px #00000014;transform:scale(1.04)}.sp-shift-cell-v2.is-off{background:#f8fafc;background:var(--table-row-alt,#f8fafc);border:1px dashed #e2e8f0;border:1px dashed var(--border-color,#e2e8f0)}.sp-cell-code{font-family:var(--font-mono);font-size:15px;font-weight:800;line-height:1.1}.sp-cell-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:9px;font-weight:600;letter-spacing:.3px;line-height:1.1;text-transform:uppercase}.sp-cell-time{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-family:var(--font-mono);font-size:8px;font-weight:500;line-height:1.1}.sp-td-summary{padding:6px 8px;vertical-align:middle}.sp-summary-mini{display:flex;flex-direction:column;gap:4px}.sp-summary-row{align-items:center;display:flex;gap:6px;justify-content:space-between}.sp-sum-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:10px;font-weight:500}.sp-sum-val{color:#1e293b;color:var(--text-primary,#1e293b);font-family:var(--font-mono);font-size:12px;font-weight:800}.sp-sum-val.green{color:#10b981;color:var(--color-green,#10b981)}.sp-sum-val.amber{color:#d97706}.sr-root{animation:sr-fade-up .28s ease-out;display:flex;flex-direction:column;gap:14px}@keyframes sr-fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.sr-page-error{align-items:center;background:#fef2f2;border:1px solid #ef444433;border-radius:14px;color:#b91c1c;display:flex;font-size:14px;font-weight:500;gap:10px;padding:20px 24px}.sr-header{align-items:flex-start;background:radial-gradient(ellipse at top right,#2563eb24 0,#0000 50%),radial-gradient(ellipse at bottom left,#6366f114 0,#0000 50%),#fff;background:radial-gradient(ellipse at top right,#2563eb24 0,#0000 50%),radial-gradient(ellipse at bottom left,#6366f114 0,#0000 50%),var(--surface-primary,#fff);border:1px solid #2563eb1f;border-radius:18px;box-shadow:0 2px 8px #2563eb0f,0 1px 3px #0000000a;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;overflow:hidden;padding:24px 28px;position:relative}.sr-header:before{background:linear-gradient(90deg,#1d4ed8,#6366f1 50%,#3b82f6);border-radius:18px 18px 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.sr-header-left{align-items:flex-start;display:flex;flex:1 1;gap:16px;min-width:0}.sr-header-icon{align-items:center;background:linear-gradient(135deg,#1e3a8a,#2563eb 60%,#3b82f6);border-radius:14px;box-shadow:0 6px 20px #2563eb59,0 2px 6px #0000001a;color:#fff;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.sr-eyebrow{color:#2563eb;font-size:10px;font-weight:800;letter-spacing:.14em;margin-bottom:4px;text-transform:uppercase}.sr-title{align-items:center;color:#0f172a;color:var(--text-primary,#0f172a);display:flex;flex-wrap:wrap;font-size:21px;font-weight:800;gap:10px;line-height:1.25;margin:0}.sr-subtitle{color:#64748b;color:var(--text-secondary,#64748b);font-size:13px;line-height:1.6;margin:6px 0 10px;max-width:560px}.sr-header-chips{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.sr-scenario{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;font-weight:700;padding:3px 11px}.sr-scenario--a{background:#fef3c7;border:1px solid #f59e0b44;color:#92400e}.sr-scenario--b{background:#d1fae5;border:1px solid #10b98144;color:#065f46}.sr-header-right{align-items:flex-end;display:flex;flex-direction:column;gap:10px}.sr-month-nav{align-items:center;display:flex;gap:6px}.sr-header-actions{align-items:center;display:flex;gap:8px}.sr-btn{align-items:center;border:1px solid #0000;border-radius:10px;cursor:pointer;display:inline-flex;font:inherit;font-size:13px;font-weight:600;gap:6px;height:36px;padding:0 16px;transition:background .14s,box-shadow .14s,opacity .14s,transform .1s;white-space:nowrap}.sr-btn:active{transform:scale(.97)}.sr-btn--ghost{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-color:#e2e8f0;border-color:var(--border-default,#e2e8f0);color:#0f172a;color:var(--text-primary,#0f172a)}.sr-btn--ghost:hover{background:#f1f5f9;box-shadow:0 1px 4px #0000000d}.sr-btn--primary{background:linear-gradient(135deg,#1d4ed8,#2563eb,#3b82f6);box-shadow:0 2px 10px #2563eb4d;color:#fff}.sr-btn--primary:hover{box-shadow:0 4px 16px #2563eb61;opacity:.92}.sr-btn--primary:disabled{box-shadow:none;cursor:not-allowed;opacity:.45}.sr-btn--sm{border-radius:8px;font-size:12px;height:30px;padding:0 12px}.sr-icon-btn{align-items:center;background:#0000;border:none;border-radius:10px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;display:inline-flex;height:36px;justify-content:center;transition:background .14s,color .14s,transform .1s;width:36px}.sr-icon-btn:hover{background:#f1f5f9;background:var(--surface-hover,#f1f5f9);color:#0f172a;color:var(--text-primary,#0f172a)}.sr-icon-btn:active{transform:scale(.92)}.sr-icon-btn--border{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0)}.sr-icon-btn--active{background:#2563eb14;border-color:#2563eb47;color:#2563eb}.sr-select,.sr-year-input{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:10px;color:#0f172a;color:var(--text-primary,#0f172a);font:inherit;font-size:13px;height:36px;padding:0 10px;transition:border-color .15s}.sr-select:focus,.sr-year-input:focus{border-color:#2563eb80;box-shadow:0 0 0 3px #2563eb14;outline:none}.sr-year-input{font-weight:700;text-align:center;width:78px}.sr-input{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:10px;color:#0f172a;color:var(--text-primary,#0f172a);font:inherit;font-size:13px;height:36px;padding:0 12px;width:200px}.sr-input:focus{border-color:#2563eb80;box-shadow:0 0 0 3px #2563eb14;outline:none}.sr-settings{animation:sr-fade-up .2s ease-out;background:#fff;background:var(--surface-primary,#fff);border:1px solid #2563eb26;border-radius:14px;box-shadow:0 4px 20px #2563eb14;overflow:hidden}.sr-settings-head{align-items:center;background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-default,#e2e8f0);color:#0f172a;color:var(--text-primary,#0f172a);display:flex;font-size:13px;font-weight:700;justify-content:space-between;padding:12px 18px}.sr-settings-body{align-items:center;display:flex;flex-wrap:wrap;gap:28px;padding:16px 20px}.sr-settings-row{align-items:center;display:flex;gap:8px}.sr-settings-icon{font-size:15px}.sr-settings-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:12px;font-weight:600;min-width:52px}.sr-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.sr-dot--blue{background:#3b82f6}.sr-dot--purple{background:#8b5cf6}.sr-dot--indigo{background:#4f46e5}.sr-stepper-group{align-items:center;border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:9px;display:flex;gap:0;overflow:hidden}.sr-stepper-btn{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:none;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;flex-shrink:0;font-size:16px;font-weight:500;height:32px;line-height:1;transition:background .12s,color .12s;width:28px}.sr-stepper-btn:hover{background:#e2e8f0}.sr-stepper,.sr-stepper-btn:hover{color:#0f172a;color:var(--text-primary,#0f172a)}.sr-stepper{background:#fff;background:var(--surface-primary,#fff);border:none;border-left:1px solid #e2e8f0;border-left:1px solid var(--border-default,#e2e8f0);border-right:1px solid #e2e8f0;border-right:1px solid var(--border-default,#e2e8f0);font:inherit;font-size:13px;font-weight:700;height:32px;outline:none;text-align:center;width:46px}.sr-settings-foot{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-default,#e2e8f0);display:flex;justify-content:flex-end;padding:12px 18px}.sr-summary{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:12px;overflow:hidden}.sr-summary--ok{border-color:#10b98140}.sr-summary--warn{border-color:#f59e0b4d}.sr-sum-row1{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:10px 16px}.sr-summary--ok .sr-sum-row1{background:#10b9810a}.sr-summary--warn .sr-sum-row1{background:#f59e0b0d}.sr-sum-left{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.sr-sum-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:11.5px;font-weight:700;gap:5px;padding:4px 10px;white-space:nowrap}.sr-sum-badge--ok{background:#10b9811f;color:#047857}.sr-sum-badge--warn{background:#f59e0b24;color:#b45309}.sr-vtag{animation:sr-pulse 2s ease-in-out infinite;border-radius:999px;font-size:11px;font-weight:700;padding:3px 9px;white-space:nowrap}.sr-vtag--red{background:#ef44441c;color:#b91c1c}.sr-vtag--orange{background:#ea580c1c;color:#c2410c}.sr-vtag--amber{background:#f59e0b1c;color:#92400e}@keyframes sr-pulse{0%,to{opacity:1}50%{opacity:.55}}.sr-sum-stats{flex-wrap:wrap;gap:6px}.sr-sstat,.sr-sum-stats{align-items:center;display:flex}.sr-sstat{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:8px;gap:4px;padding:4px 10px}.sr-sstat--blue{background:#2563eb12;border-color:#2563eb2e;color:#1d4ed8}.sr-sstat--green{background:#10b98112;border-color:#10b9812e;color:#047857}.sr-sstat--red{background:#ef444414;border-color:#ef444433;color:#b91c1c}.sr-sstat--amber{background:#f59e0b14;border-color:#f59e0b33;color:#92400e}.sr-sstat-val{color:inherit;font-size:14px;font-weight:800;line-height:1}.sr-sstat-lbl{color:#64748b;color:var(--text-secondary,#64748b);font-size:10.5px;font-weight:600;white-space:nowrap}.sr-sstat--amber .sr-sstat-lbl,.sr-sstat--blue .sr-sstat-lbl,.sr-sstat--green .sr-sstat-lbl,.sr-sstat--red .sr-sstat-lbl{color:inherit;opacity:.8}.sr-sstat-pct{color:#059669;font-size:10px;font-weight:700;margin-left:2px}.sr-sstat-sep{background:#e2e8f0;background:var(--border-default,#e2e8f0);flex-shrink:0;height:20px;margin:0 2px;width:1px}.sr-sum-row2{align-items:center;background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-default,#e2e8f0);display:flex;flex-wrap:wrap;gap:8px;padding:7px 16px}.sr-ld{align-items:center;border-radius:5px;display:inline-flex;font-size:9.5px;font-weight:800;height:19px;justify-content:center;min-width:24px;padding:0 5px}.sr-ld--m{background:#2563eb21;color:#1d4ed8}.sr-ld--e{background:#8b5cf621;color:#6d28d9}.sr-ld--n{background:#4f46e521;color:#3730a3}.sr-ld--wo{background:#10b98121;color:#047857}.sr-ld--nh{background:#f59e0b21;color:#b45309}.sr-ld--xx{background:#ef444421;color:#b91c1c}.sr-sum-lbl{color:#64748b;color:var(--text-secondary,#64748b);font-size:11px;font-weight:600;margin-right:4px}.sr-sum-sep{background:#e2e8f0;background:var(--border-default,#e2e8f0);flex-shrink:0;height:14px;width:1px}.sr-sum-note{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:10px;font-style:italic;font-weight:500;margin-left:auto}.sr-error-bar{align-items:center;background:#fef2f2;border:1px solid #ef444433;border-radius:10px;color:#b91c1c;display:flex;font-size:13px;gap:8px;padding:11px 16px}.sr-rotation-tag{background:#2563eb14;color:#2563eb;font-size:11px;gap:5px;padding:3px 9px}.sr-chip,.sr-rotation-tag{align-items:center;border-radius:999px;display:inline-flex;font-weight:700}.sr-chip{font-size:11.5px;gap:4px;padding:3px 10px}.sr-chip--blue{background:#2563eb1a;color:#1d4ed8}.sr-chip--blue-soft{background:#2563eb12;border:1px solid #2563eb26;color:#2563eb;font-size:11px}.sr-chip--purple{background:#8b5cf61a;color:#6d28d9}.sr-chip--purple-soft{background:#8b5cf612;border:1px solid #8b5cf626;color:#7c3aed;font-size:11px}.sr-chip--slate{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);color:#64748b;color:var(--text-secondary,#64748b)}.sr-tabbar{align-items:center;background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:13px;display:flex;flex-wrap:wrap;gap:4px;padding:4px}.sr-tab{align-items:center;background:#0000;border:none;border-radius:9px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;display:inline-flex;font:inherit;font-size:13px;font-weight:600;gap:6px;height:34px;padding:0 16px;transition:background .14s,color .14s,box-shadow .14s;white-space:nowrap}.sr-tab--active{background:#fff;background:var(--surface-primary,#fff);box-shadow:0 1px 4px #00000014;color:#0f172a;color:var(--text-primary,#0f172a)}.sr-tab:not(.sr-tab--active):hover{background:#0000000a}.sr-tab-count{align-items:center;background:#2563eb1a;border-radius:999px;color:#2563eb;display:inline-flex;font-size:10px;font-weight:800;height:18px;justify-content:center;min-width:20px;padding:0 5px}.sr-tabbar-filters{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-left:auto}.sr-filter-chips{align-items:center;display:flex;gap:4px}.sr-filter-chip{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:999px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;font:inherit;font-size:11.5px;font-weight:600;height:26px;padding:0 10px;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.sr-filter-chip:hover{background:#f1f5f9;border-color:#94a3b8}.sr-filter-chip--active{background:#2563eb14;border-color:#2563eb4d;color:#1d4ed8}.sr-search-wrap{align-items:center;display:flex;position:relative}.sr-search-icon{color:#94a3b8;color:var(--text-tertiary,#94a3b8);flex-shrink:0;left:10px;pointer-events:none;position:absolute}.sr-search{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:9px;color:#0f172a;color:var(--text-primary,#0f172a);font:inherit;font-size:12.5px;height:30px;min-width:200px;padding:0 28px 0 30px;transition:border-color .15s,box-shadow .15s}.sr-search:focus{border-color:#2563eb73;box-shadow:0 0 0 3px #2563eb12;outline:none}.sr-search-clear{align-items:center;background:#94a3b8;background:var(--text-tertiary,#94a3b8);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:10px;height:16px;justify-content:center;position:absolute;right:8px;transition:background .12s;width:16px}.sr-search-clear:hover{background:#64748b;background:var(--text-secondary,#64748b)}.sr-search-count{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:11px;font-weight:600;white-space:nowrap}.sr-panel{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:14px;box-shadow:0 1px 4px #0000000d;overflow:hidden}.sr-empty-state{align-items:center;color:#64748b;color:var(--text-secondary,#64748b);display:flex;flex-direction:column;font-size:14px;font-weight:500;gap:12px;justify-content:center;padding:60px 20px}.sr-table-wrap{overflow-x:auto}.sr-table{border-collapse:collapse;width:100%}.sr-table td,.sr-table th{border-top:1px solid #f1f5f9;border-top:1px solid var(--border-light,#f1f5f9);font-size:13px;padding:11px 13px;text-align:left;vertical-align:top;white-space:nowrap}.sr-table th{background:#f8fafc;background:var(--surface-secondary,#f8fafc);color:#64748b;color:var(--text-secondary,#64748b);font-size:11px;font-weight:700;letter-spacing:.07em;position:sticky;text-transform:uppercase;top:0;z-index:1}.sr-table tbody tr{transition:background .1s}.sr-table tbody tr:hover td{background:rgba(37,99,235,.025)}.sr-row-gap td{background:#fef2f2b3!important}.sr-row-today td{background:#fbbf240d!important}.sr-row-weekend td{background:rgba(0,0,0,.012)!important}.sr-th-shift{display:flex;flex-direction:column;gap:2px}.sr-shift-badge{align-items:center;border-radius:4px;display:inline-flex;font-size:9px;font-weight:800;height:17px;justify-content:center;margin-right:4px;vertical-align:middle;width:18px}.sr-shift-badge--m{background:#2563eb21;color:#1d4ed8}.sr-shift-badge--e{background:#8b5cf621;color:#6d28d9}.sr-shift-badge--n{background:#4f46e521;color:#3730a3}.sr-time-sub{color:#94a3b8;color:var(--text-tertiary,#94a3b8);display:block;font-size:9px;font-weight:500;letter-spacing:0;margin-top:1px;text-transform:none}.sr-date-cell{gap:7px}.sr-date-block,.sr-date-cell{align-items:center;display:flex}.sr-date-block{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border:1px solid #0000;border-radius:9px;flex-direction:column;min-width:36px;padding:4px 7px}.sr-date-block--today{background:#fbbf2424;border-color:#d977064d}.sr-date-num{color:#0f172a;color:var(--text-primary,#0f172a);font-size:15px;font-weight:800;line-height:1}.sr-date-mon{font-size:8.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.sr-date-mon,.sr-day-chip{color:#64748b;color:var(--text-secondary,#64748b)}.sr-day-chip{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border-radius:5px;font-size:10px;font-weight:700;padding:2px 6px}.sr-day-chip--weekend{background:#6366f114;color:#4f46e5}.sr-today-tag{background:#d977061f;border-radius:999px;color:#b45309;font-size:9.5px;font-weight:800;letter-spacing:.04em;padding:1px 7px}.sr-cov-ok{background:#2563eb08}.sr-cov-gap{background:#ef44440d}.sr-cov-names{color:#0f172a;color:var(--text-primary,#0f172a);font-size:12px;font-weight:600;line-height:1.55;margin-bottom:4px}.sr-cov-names--wo{color:#047857}.sr-cov-names--xx{color:#b91c1c}.sr-cov-empty{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:12px}.sr-mini-bar-wrap{align-items:center;display:flex;gap:6px;margin-top:3px}.sr-mini-bar-track{background:#e2e8f0;background:var(--border-default,#e2e8f0);border-radius:999px;flex:1 1;height:4px;min-width:40px;overflow:hidden}.sr-mini-bar-fill{border-radius:999px;height:100%;transition:width .35s cubic-bezier(.4,0,.2,1)}.sr-mini-bar-label{font-size:10px;font-weight:700;white-space:nowrap}.sr-mini-bar-label--met{color:#059669}.sr-mini-bar-label--gap{color:#dc2626}.sr-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;font-weight:700;gap:4px;padding:3px 9px}.sr-pill--ok{background:#10b9811c;color:#047857}.sr-pill--danger{background:#ef44441c;color:#b91c1c}.sr-grid-wrap{max-height:640px;overflow-x:auto;overflow-y:auto}.sr-grid-wrap::-webkit-scrollbar{height:6px;width:6px}.sr-grid-wrap::-webkit-scrollbar-track{background:#0000}.sr-grid-wrap::-webkit-scrollbar-thumb{background:#e2e8f0;background:var(--border-default,#e2e8f0);border-radius:999px}.sr-grid-wrap::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sr-grid{border-collapse:collapse;white-space:nowrap}.sr-grid td,.sr-grid th{border-top:1px solid #f1f5f9;border-top:1px solid var(--border-light,#f1f5f9);font-size:12px;padding:8px 6px;text-align:center}.sr-grid th{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-bottom:1.5px solid #e2e8f0;border-bottom:1.5px solid var(--border-default,#e2e8f0);color:#64748b;color:var(--text-secondary,#64748b);font-size:10.5px;font-weight:700;letter-spacing:.05em;position:sticky;text-transform:uppercase;top:0;z-index:2}.sr-grid th span{color:#94a3b8;color:var(--text-tertiary,#94a3b8);display:block;font-size:8.5px;font-weight:500;letter-spacing:0;margin-top:2px;text-transform:none}.sr-col-count{align-items:center;background:#2563eb17;border-radius:999px;color:#2563eb;display:inline-flex;font-size:9.5px;font-weight:800;height:16px;justify-content:center;margin-left:5px;min-width:20px;padding:0 5px;vertical-align:middle}.sr-sticky-col{background:#fff;background:var(--surface-primary,#fff);border-right:1px solid #e2e8f0;border-right:1px solid var(--border-default,#e2e8f0);box-shadow:2px 0 6px #0000000a;left:0;min-width:220px;position:sticky;text-align:left!important;z-index:3}.sr-grid thead .sr-sticky-col{background:#f8fafc;background:var(--surface-secondary,#f8fafc);z-index:4}.sr-wknd-col{background:#f8fafc!important;background:var(--surface-secondary,#f8fafc)!important;opacity:.8}.sr-today-col{background:#fbbf241f!important;border-left:1.5px solid #d977064d!important;border-right:1.5px solid #d977064d!important}.sr-total-hd{background:#f8fafc!important;background:var(--surface-secondary,#f8fafc)!important;border-left:1.5px solid #e2e8f0;border-left:1.5px solid var(--border-default,#e2e8f0);color:#64748b;color:var(--text-secondary,#64748b);min-width:44px}.sr-emp{gap:9px;padding:4px 14px 4px 12px}.sr-emp,.sr-emp-avatar{align-items:center;display:flex}.sr-emp-avatar{border-radius:9px;box-shadow:0 2px 6px #0000001f;color:#fff;flex-shrink:0;font-size:13px;font-weight:800;height:32px;justify-content:center;width:32px}.sr-emp-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.sr-emp-name{color:#0f172a;color:var(--text-primary,#0f172a);font-size:13px;font-weight:700}.sr-emp-meta{color:#64748b;color:var(--text-secondary,#64748b);font-size:10px}.sr-emp-pct-bar{background:#e2e8f0;background:var(--border-default,#e2e8f0);border-radius:999px;height:2px;margin-top:2px;overflow:hidden}.sr-emp-pct-fill{border-radius:999px;height:100%;transition:width .4s ease}.sr-type-badge{border-radius:6px;flex-shrink:0;font-size:10px;font-weight:800;letter-spacing:.04em;padding:2px 7px}.sr-type-badge--general{background:#2563eb1a;color:#1d4ed8}.sr-type-badge--rotational{background:#8b5cf61a;color:#6d28d9}.sr-cell{border-radius:0;font-size:10.5px;font-weight:800;letter-spacing:.02em;min-width:34px;transition:background .08s;width:34px}.sr-cell--present{background:#2563eb17;color:#1d4ed8}.sr-cell--off{background:#10b9811a;color:#047857}.sr-cell--holiday{background:#f59e0b1a;color:#b45309}.sr-cell--restricted{background:#ef44441a;color:#b91c1c}.sr-cell--blank{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.sr-cell--weekend{opacity:.65}.sr-cell--today{background:#fbbf241f!important;outline:1.5px solid #d9770673;outline-offset:-1.5px}.sr-total{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-left:1px solid #f1f5f9;border-left:1px solid var(--border-light,#f1f5f9);font-size:12px;font-weight:700}.sr-total--worked{color:#1d4ed8}.sr-total--xx{color:#b91c1c}.sr-total--comp{color:#d97706;font-weight:800}.sr-roster-row:hover td{background:rgba(37,99,235,.025)}.sr-roster-row:hover .sr-sticky-col{background:#f0f9ffb3}.sr-backdrop{align-items:center;animation:sr-bk-in .18s ease-out;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a80;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:9000}@keyframes sr-bk-in{0%{opacity:0}to{opacity:1}}.sr-modal{animation:sr-modal-in .22s cubic-bezier(.34,1.56,.64,1);background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:20px;box-shadow:0 28px 70px #00000029,0 8px 22px #00000014;max-width:500px;overflow:hidden;width:100%}@keyframes sr-modal-in{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.sr-modal-header{align-items:center;background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-default,#e2e8f0);display:flex;justify-content:space-between;padding:18px 22px}.sr-modal-title{align-items:center;color:#0f172a;color:var(--text-primary,#0f172a);display:flex;font-size:15px;font-weight:700;gap:9px}.sr-modal-body{display:flex;flex-direction:column;gap:16px;padding:20px 22px}.sr-modal-desc{color:#64748b;color:var(--text-secondary,#64748b);font-size:13px;line-height:1.65;margin:0}.sr-chip-row{display:flex;flex-wrap:wrap;gap:7px}.sr-emp-preview{display:flex;flex-direction:column;gap:7px}.sr-emp-preview-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase}.sr-emp-preview-list{display:flex;flex-wrap:wrap;gap:5px;max-height:80px;overflow-y:auto}.sr-emp-chip{border-radius:6px;font-size:11.5px;font-weight:600;padding:2px 9px}.sr-emp-chip--general{background:#2563eb14;border:1px solid #2563eb26;color:#1d4ed8}.sr-emp-chip--rotational{background:#8b5cf614;border:1px solid #8b5cf626;color:#6d28d9}.sr-field{display:flex;flex-direction:column;gap:7px}.sr-field-label{color:#64748b;color:var(--text-secondary,#64748b);font-size:10.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase}.sr-modal-footer{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-default,#e2e8f0);display:flex;gap:8px;justify-content:flex-end;padding:16px 22px}@keyframes sr-spin{to{transform:rotate(1turn)}}.sr-spin{animation:sr-spin .75s linear infinite}.sr-guards-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:16px}.sr-guards-title{align-items:center;color:#0f172a;color:var(--text-primary,#0f172a);display:flex;font-size:15px;font-weight:700;gap:8px;margin-bottom:4px}.sr-guards-subtitle{font-size:12px;line-height:1.5;max-width:560px}.sr-guards-loading,.sr-guards-subtitle{color:#64748b;color:var(--text-secondary,#64748b)}.sr-guards-loading{align-items:center;display:flex;font-size:13px;gap:10px;justify-content:center;padding:40px 24px}.sr-guards-table td,.sr-guards-table th{font-size:12.5px;padding:10px 12px;white-space:nowrap}.sr-guard-row:hover{background:#f8fafc;background:var(--surface-hover,#f8fafc)}.sr-designation-badge{align-items:center;background:#2563eb14;border:1px solid #2563eb26;border-radius:6px;color:#1d4ed8;display:inline-flex;font-size:11.5px;font-weight:600;padding:2px 9px}.sr-prev-desig{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:11.5px;font-style:italic}.sr-icon-btn--danger{border-color:#dc262633;color:#dc2626}.sr-icon-btn--danger:hover:not(:disabled){background:#dc26260f;border-color:#dc262659;color:#b91c1c}.sr-icon-btn--danger:disabled{cursor:not-allowed;opacity:.45}.sr-shift-badge--wo-sm{background:#94a3b826;border-color:#94a3b84d;color:#475569}.sr-guard-picker{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:10px;max-height:240px;overflow-y:auto}.sr-guard-picker-empty{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:13px;padding:24px;text-align:center}.sr-guard-pick-row{align-items:center;background:none;border:none;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-subtle,#f1f5f9);cursor:pointer;display:flex;gap:10px;padding:9px 12px;text-align:left;transition:background .15s;width:100%}.sr-guard-pick-row:last-child{border-bottom:none}.sr-guard-pick-row:hover{background:#fff;background:var(--surface-hover,#fff)}.sr-guard-pick-row--active{background:#2563eb0f!important;border-left:2px solid #2563eb}.sr-emp-avatar--sm{align-items:center;background:linear-gradient(135deg,#1d4ed8,#93c5fd);border-radius:7px;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:28px;justify-content:center;width:28px}.sr-guard-pick-info{display:flex;flex:1 1;flex-direction:column;min-width:0}.sr-guard-pick-name{color:#0f172a;color:var(--text-primary,#0f172a);font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sr-guard-pick-meta{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:11px}.sr-guard-checkbox{align-items:center;background:#fff;background:var(--surface-primary,#fff);border:1.5px solid #cbd5e1;border:1.5px solid var(--border-default,#cbd5e1);border-radius:5px;color:#fff;display:flex;flex-shrink:0;height:18px;justify-content:center;transition:border-color .15s,background .15s;width:18px}.sr-guard-checkbox--checked{background:#2563eb;border-color:#2563eb}.sr-guard-selection-bar{align-items:center;background:#2563eb0d;border:1px solid #2563eb1f;border-radius:8px;display:flex;gap:12px;margin-top:10px;padding:8px 12px}.sr-guard-selection-count{align-items:center;color:#1d4ed8;display:flex;font-size:12px;font-weight:600;gap:5px;white-space:nowrap}.sr-btn--outline{background:#fff;background:var(--surface-primary,#fff);border:1.5px solid #cbd5e1;border:1.5px solid var(--border-default,#cbd5e1);color:#0f172a;color:var(--text-primary,#0f172a)}.sr-btn--outline:hover{background:#f8fafc;background:var(--surface-hover,#f8fafc)}@media (max-width:1100px){.sr-header{align-items:stretch;flex-direction:column}.sr-header-right{align-items:flex-start;flex-direction:row;flex-wrap:wrap}}@media (max-width:760px){.sr-kpi-row{grid-template-columns:repeat(2,1fr)}.sr-tabbar{flex-wrap:wrap}.sr-tabbar-filters{margin-left:0;width:100%}.sr-search{flex:1 1;min-width:0}.sr-grid-wrap{max-height:480px}.sr-header{padding:16px}}@media (max-width:480px){.sr-kpi-row{grid-template-columns:1fr}.sr-filter-chips{flex-wrap:wrap}}.shifts-page{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.sp-topnav{background:var(--surface-primary);border-bottom:1px solid var(--border-default);height:50px;padding:0 20px}.sp-brand,.sp-topnav{align-items:center;display:flex;flex-shrink:0}.sp-brand{border-right:1px solid var(--border-default);gap:8px;margin-right:4px;padding-right:18px}.sp-brand-icon{align-items:center;background:var(--color-primary);border-radius:7px;display:flex;flex-shrink:0;height:27px;justify-content:center;width:27px}.sp-brand-name{color:var(--text-primary);font-size:12px;font-weight:700;line-height:1.25;white-space:nowrap}.sp-brand-path{color:var(--text-tertiary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:10px;line-height:1.25}.sp-nav-tabs{display:flex;height:100%}.sp-tab{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:12px;font-weight:500;height:50px;padding:0 18px;transition:color .12s,background .12s;white-space:nowrap}.sp-tab:hover:not(.active){background:var(--surface-secondary);color:var(--text-primary)}.sp-tab.active{background:var(--color-primary-100);border-bottom-color:var(--color-primary);border-radius:var(--radius-xl);color:var(--color-primary-dark);font-weight:700}.sp-content{flex:1 1;min-height:0;overflow:hidden}.lm-root,.sp-content{display:flex;flex-direction:column}.lm-root{animation:lm-fadein .3s ease;gap:10px}@keyframes lm-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.lm-loading{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-base);padding:60px;text-align:center}.lm-toast{animation:lm-fadein .2s;border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:600;padding:10px 20px;position:fixed;right:20px;top:20px;z-index:9999}.lm-toast.success{background:var(--color-green-50);border:1px solid var(--color-green-100);color:var(--color-green-600)}.lm-toast.error{background:var(--color-red-50);border:1px solid var(--color-red-light);color:var(--color-red-dark)}.lm-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.lm-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-2xl);font-weight:800;margin:0}.lm-subtitle{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-xs);margin:2px 0 0}.lm-btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:700;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.lm-btn.accent{background:var(--color-teal);color:var(--text-inverse)}.lm-btn.accent:hover{background:var(--color-teal-dark)}.lm-btn.outline{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);color:#1e293b;color:var(--text-primary,#1e293b)}.lm-btn.approve-full{background:#d1fae5;color:var(--color-green-600);flex:1 1}.lm-btn.reject-full{background:#fee2e2;color:var(--color-red-dark);flex:1 1}.lm-btn:hover{opacity:.88}.lm-kpi-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.lm-kpi{background:#fff;background:var(--card-bg,#fff);border:1px solid;border-radius:var(--radius-xl);gap:8px;padding:8px 10px}.lm-kpi,.lm-kpi-icon{align-items:center;display:flex}.lm-kpi-icon{border-radius:var(--radius-xl);flex-shrink:0;height:36px;justify-content:center;width:36px}.lm-kpi-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs);font-weight:600;letter-spacing:.5px}.lm-kpi-val{font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:800}.lm-tabs{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:var(--radius-xl);display:flex;gap:3px;padding:3px}.lm-tab{align-items:center;background:#0000;border:none;border-radius:var(--radius-lg);color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:600;gap:5px;padding:6px 12px;transition:all .15s;white-space:nowrap}.lm-tab:hover{color:#64748b;color:var(--text-secondary,#64748b)}.lm-tab.active,.lm-tab:hover{background:#fff;background:var(--surface-primary,#fff)}.lm-tab.active{box-shadow:0 1px 3px #0000000f;color:var(--color-teal);font-weight:700}.lm-tab-icon{font-size:var(--text-base)}.lm-tab-label{font-size:var(--text-xs)}.lm-filters{flex-wrap:wrap}.lm-filters,.lm-search-wrap{align-items:center;display:flex;gap:8px}.lm-search-wrap{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);color:#64748b;color:var(--text-secondary,#64748b);flex:1 1;min-width:200px;padding:8px 12px}.lm-search{border:none;color:#1e293b;color:var(--text-primary,#1e293b);flex:1 1;outline:none}.lm-filter-btn,.lm-search{background:#0000;font-size:var(--text-sm)}.lm-filter-btn{border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;font-weight:700;padding:7px 12px;transition:all .15s}.lm-filter-btn.active.all{background:#6366f114;border-color:#6366f1;border-color:var(--primary-color,#6366f1);color:#6366f1;color:var(--primary-color,#6366f1)}.lm-filter-btn.active.pending{background:#ffb5471f;border-color:var(--color-gold);color:var(--color-gold)}.lm-filter-btn.active.approved{background:#22c55e1f;border-color:var(--color-success);color:var(--color-success)}.lm-filter-btn.active.rejected{background:#ff4d6d1f;border-color:var(--color-pink);color:var(--color-pink)}.lm-select{border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-xs);padding:7px 10px}.lm-select,.lm-table-wrap{background:#fff;background:var(--card-bg,#fff)}.lm-table-wrap{border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);overflow:auto}.lm-table{border-collapse:collapse;min-width:700px;width:100%}.lm-table thead tr{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0)}.lm-table th{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-sm);font-weight:700;padding:7px 10px;text-align:left;white-space:nowrap}.lm-table tbody tr{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);cursor:pointer;transition:background .15s}.lm-table tbody tr:hover{background:#f8fafc;background:var(--surface-hover,#f8fafc)}.lm-table tbody tr.alt{background:#f8fafc80;background:var(--table-alt,#f8fafc80)}.lm-td-emp{padding:6px 10px}.lm-emp-cell{gap:8px}.lm-emp-avatar,.lm-emp-cell{align-items:center;display:flex}.lm-emp-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:var(--text-inverse);flex-shrink:0;font-size:var(--text-2xs);font-weight:700;height:28px;justify-content:center;width:28px}.lm-emp-name{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-xs);font-weight:700}.lm-emp-code{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-family:var(--font-mono);font-size:var(--text-2xs)}.lm-type-badge{border-radius:var(--radius-3xl);font-size:var(--text-2xs);font-weight:700;padding:3px 8px}.lm-td-dur{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);white-space:nowrap}.lm-td-days,.lm-td-dur{font-family:var(--font-mono);padding:6px 10px}.lm-td-days{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-base);font-weight:800;text-align:center}.lm-td-reason{max-width:160px;padding:6px 10px}.lm-reason-text{color:#64748b;color:var(--text-secondary,#64748b);overflow:hidden;text-overflow:ellipsis}.lm-reason-text,.lm-td-applied{font-size:var(--text-sm);white-space:nowrap}.lm-td-applied{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-family:var(--font-mono);padding:6px 10px}.lm-status-badge{border-radius:var(--radius-3xl);display:inline-block;font-size:var(--text-2xs);font-weight:700;padding:3px 10px}.lm-action-btns{display:flex;gap:5px}.lm-act-btn{border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:700;padding:4px 9px;transition:all .15s}.lm-act-btn.approve{background:#d1fae5;color:var(--color-green-600)}.lm-act-btn.reject{background:#fee2e2;color:var(--color-red-dark)}.lm-act-btn:hover{opacity:.8}.lm-acted-by{font-size:var(--text-2xs)}.lm-acted-by,.lm-empty{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.lm-empty{font-size:var(--text-sm);padding:24px;text-align:center}.lm-balance-table{min-width:800px}.lm-root .v3-tbl{min-width:950px}.lm-root .v3-tw{overflow-x:auto}.lm-root .v3-toolbar{padding:8px 14px}.lm-root .v3-card-h{padding:10px 14px}.lm-root .v3-g4{gap:8px}.lm-root .v3-kpi{padding:8px 10px}.lm-balance-table th,.lm-td-balance{text-align:center}.lm-td-balance{padding:8px 10px}.lm-bal-val{color:#1e293b;color:var(--text-primary,#1e293b);font-family:var(--font-mono);font-size:var(--text-base);font-weight:800}.lm-bal-total{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs)}.lm-bal-bar{border-radius:var(--radius-full);height:3px;margin:3px auto 0;overflow:hidden;width:48px}.lm-td-bal-empty{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-sm);padding:10px;text-align:center}.lm-bal-avatar{align-items:center;border-radius:var(--radius-xl);display:flex;flex-shrink:0;font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:800;height:28px;justify-content:center;width:28px}.lm-calendar-wrap{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:var(--radius-2xl);box-shadow:0 1px 4px #0000000a;padding:14px}.lm-cal-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-md);font-weight:800;margin:0 0 14px}.lm-cal-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.lm-cal-legend-item{align-items:center;border:1px solid;border-radius:var(--radius-3xl);display:flex;font-size:var(--text-sm);font-weight:700;gap:5px;padding:3px 10px}.lm-cal-dot{border-radius:50%;height:8px;width:8px}.lm-cal-header{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.lm-cal-head{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-sm);font-weight:700;padding:6px 0;text-align:center}.lm-cal-head.sun{color:#ef4444}.lm-cal-grid{grid-gap:3px;display:grid;gap:3px;grid-template-columns:repeat(7,1fr)}.lm-cal-cell{background:#f8fafc;background:var(--surface-hover,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);min-height:64px;padding:4px 6px}.lm-cal-cell.empty{background:#0000;border:none}.lm-cal-cell.today{background:#6366f114;border-color:#6366f1;border-color:var(--primary-color,#6366f1)}.lm-cal-day{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);font-weight:600;margin-bottom:3px}.lm-cal-day.today{color:#6366f1;color:var(--primary-color,#6366f1);font-weight:800}.lm-cal-entry{border-radius:var(--radius-sm);font-size:var(--text-2xs);font-weight:700;margin-bottom:2px;overflow:hidden;padding:1px 4px;text-overflow:ellipsis;white-space:nowrap}.lm-cal-more{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs)}.lm-policy-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.lm-policy-card{background:#fff;background:var(--surface-primary,#fff);border:1px solid;border-radius:var(--radius-2xl);box-shadow:0 1px 4px #0000000a;padding:18px;transition:transform .15s}.lm-policy-card:hover{transform:translateY(-2px)}.lm-policy-head{align-items:center;display:flex;gap:10px;margin-bottom:12px}.lm-policy-icon{align-items:center;border-radius:var(--radius-xl);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.lm-policy-name{font-size:var(--text-base);font-style:italic;font-weight:800}.lm-policy-entitlement{font-size:var(--text-sm);font-weight:700}.lm-policy-desc,.lm-policy-entitlement{color:#64748b;color:var(--text-secondary,#64748b)}.lm-policy-desc{font-size:var(--text-xs);line-height:1.6;margin-bottom:12px}.lm-policy-details{display:flex;flex-direction:column;gap:5px}.lm-policy-row{display:flex;font-size:var(--text-sm);justify-content:space-between}.lm-policy-key{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.lm-policy-val{color:#1e293b;color:var(--text-primary,#1e293b);font-weight:700}.lm-policy-val.green{color:var(--color-green-600)}.lm-modal-overlay{align-items:center;animation:lm-fadein .15s;background:#00000059;display:flex;inset:0;justify-content:center;position:fixed;z-index:1300}.lm-modal{animation:lm-fadein .2s;background:#fff;background:var(--surface-primary,#fff);border-radius:var(--radius-2xl);box-shadow:0 20px 60px #0003;max-height:90vh;overflow-y:auto;padding:24px;width:90%}.lm-modal h3{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-lg);font-weight:800;margin:0 0 16px}.lm-modal-body{display:flex;flex-direction:column;gap:14px}.lm-modal-row-2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.lm-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-sm);font-weight:700;letter-spacing:.7px;margin-bottom:2px;text-transform:uppercase}.lm-input,.lm-textarea{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);box-sizing:border-box;color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);padding:9px 12px;width:100%}.lm-textarea{resize:vertical}.lm-type-pills{display:flex;flex-wrap:wrap;gap:6px}.lm-pill{background:#0000;border:1.5px solid #e2e8f0;border:1.5px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;font-size:var(--text-sm);font-weight:700;padding:6px 12px;transition:all .15s}.lm-pill.active{border-color:#6366f1;border-color:var(--primary-color,#6366f1)}.lm-duration-preview{background:#6366f114;border-radius:var(--radius-lg);color:#6366f1;color:var(--primary-color,#6366f1);font-size:var(--text-xs);padding:8px 12px}.lm-holiday-excl{color:var(--color-orange);font-size:var(--text-sm);margin-left:4px}.lm-modal-actions{display:flex;gap:10px}.lm-modal-actions .lm-btn{flex:1 1}.lm-detail-head{align-items:center;background:#f8fafc;background:var(--surface-hover,#f8fafc);border-radius:var(--radius-xl);display:flex;gap:12px;padding:14px}.lm-detail-info{flex:1 1}.lm-detail-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.lm-detail-item{background:#f8fafc;background:var(--surface-hover,#f8fafc);border-radius:var(--radius-lg);padding:10px 12px}.lm-detail-item.full{grid-column:1/-1}.lm-detail-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs);font-weight:700;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.lm-detail-value{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);font-weight:700}.lm-reject-box{border:1px solid #dc262633;border-radius:var(--radius-lg)}.lm-reject-box,.lm-reject-notice{background:var(--color-red-50);padding:12px}.lm-reject-notice{border-radius:var(--radius-lg);color:var(--color-red-dark);font-size:var(--text-xs)}.lm-compoff-wrap{display:flex;flex-direction:column;gap:14px}.lm-compoff-header{align-items:center;display:flex;justify-content:space-between}.lm-compoff-title{font-size:var(--text-sm)}.lm-compoff-title,.lm-td-mono{color:#1e293b;color:var(--text-primary,#1e293b);font-weight:700}.lm-td-mono{font-family:var(--font-mono);font-size:var(--text-xs)}.lm-td-mono.green{color:var(--color-green-600)}.lm-td-mono.muted{color:var(--text-tertiary)}.lm-hours-accent{color:#6366f1;color:var(--accent,#6366f1);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:800}.lm-permission-wrap{display:flex;flex-direction:column;gap:14px}.lm-permission-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between}.lm-permission-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);font-weight:700}.lm-permission-subtitle{color:var(--text-tertiary);font-size:var(--text-sm);margin-top:2px}.lm-btn.gold{background:#d977061f;border:none;border-radius:var(--radius-lg);color:var(--color-orange);cursor:pointer;font-size:var(--text-xs);font-weight:700;padding:8px 16px;transition:background .15s}.lm-btn.gold:hover{background:#d9770638}.lm-permission-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.lm-empty-card{color:var(--text-tertiary);font-size:var(--text-sm);grid-column:1/-1;padding:40px;text-align:center}.lm-permission-card{background:#fff;background:var(--surface-primary,#fff);border:1px solid;border-radius:var(--radius-xl);padding:14px;transition:box-shadow .15s,transform .15s}.lm-permission-card:hover{box-shadow:0 2px 12px #0000000f;transform:translateY(-1px)}.lm-pm-card-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.lm-pm-card-tags{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.lm-pm-type-badge{border-radius:var(--radius-3xl);font-size:var(--text-2xs);font-weight:700;padding:3px 8px}.lm-pm-date{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm)}.lm-pm-date,.lm-pm-hours{font-family:var(--font-mono)}.lm-pm-hours{font-size:var(--text-xs);font-weight:800}.lm-pm-reason{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);margin-bottom:10px}.lm-pm-card-actions{display:flex;gap:6px}.lm-act-btn-full{border:none;border-radius:var(--radius-md);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:700;padding:5px 0;transition:opacity .15s}.lm-act-btn-full:hover{opacity:.85}.lm-act-btn-full.approve{background:#0596691f;color:var(--color-green-600)}.lm-act-btn-full.reject{background:#dc26261f;color:var(--color-red-dark)}.lm-pm-acted{color:var(--text-tertiary);font-size:var(--text-2xs)}.lm-pm-policy-warn{background:#d9770614;border:1px solid #d9770633;border-radius:var(--radius-lg);color:var(--color-orange);font-size:var(--text-sm);margin-bottom:4px;padding:9px 12px}@media (max-width:768px){.lm-header{align-items:flex-start;flex-direction:column;gap:8px}.lm-kpi-grid{grid-template-columns:repeat(2,1fr)}.lm-cal-grid,.lm-cal-header{font-size:10px;grid-template-columns:repeat(7,1fr)}.lm-detail-grid,.lm-modal-row-2{grid-template-columns:1fr}.lm-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.lm-table{min-width:600px}.lm-toolbar{align-items:stretch;flex-direction:column;gap:8px}.lm-search{width:100%}}@media (max-width:480px){.lm-kpi-grid{grid-template-columns:1fr}.lm-modal{padding:16px;width:95%}.lm-title{font-size:var(--text-lg)}}.inv-root{--inv-bg:#0a0f1e;--inv-bg-2:#080d18;--inv-bg-3:#060a14;--inv-bg-card:#ffffff08;--inv-border:#ffffff12;--inv-border-md:#ffffff1a;--inv-text-1:#e2e8f0;--inv-text-2:#cbd5e1;--inv-text-3:#94a3b8;--inv-text-4:#64748b;--inv-text-5:#475569;--inv-accent:#0ea5e9;--inv-accent-lt:#38bdf8;--inv-accent-bg:#0ea5e91f;--inv-accent-bdr:#0ea5e959;--inv-success:#4ade80;--inv-success-bg:#4ade801f;--inv-danger:#f87171;--inv-danger-bg:#ef44441f;--inv-warn:#f59e0b;--inv-scroll-thumb:#ffffff1a;--inv-bg-input:#ffffff0d;--inv-bg-select:#1e293b;--inv-bg-hover:#ffffff0a;--inv-card-alt:hsla(0,0%,100%,.025);--inv-divider:#ffffff14;--inv-brd-subtle:#ffffff0d;--inv-row-border:#ffffff0a;--inv-btn-2-bg:#ffffff0f;--inv-btn-2-hov:#ffffff1f;--inv-header-bg:var(--gs-header-bg-color,var(--inv-bg-2));--inv-header-border:var(--gs-header-border-color,var(--inv-border));--inv-header-text:var(--gs-header-text-color,var(--inv-text-1));--inv-header-muted:var(--gs-header-muted-color,var(--inv-text-4));--inv-header-chip-bg:var(--gs-header-chip-bg-color,var(--inv-bg-hover));--inv-header-active-bg:var(--gs-header-active-bg-color,var(--inv-accent-bg));--inv-header-active-text:var(--gs-header-active-text-color,var(--inv-accent-lt));--inv-header-btn-bg:var(--gs-header-button-bg-color,var(--inv-accent));--inv-header-btn-hover-bg:var(--gs-header-button-hover-bg-color,#0284c7);--inv-header-btn-disabled-bg:var(--gs-header-button-disabled-bg-color,#94a3b859);--inv-header-btn-text:var(--gs-header-button-text-color,#fff);--inv-header-font-family:var(--gs-header-font-family,"Segoe UI",system-ui,-apple-system,sans-serif);--inv-header-font-size:var(--gs-header-font-size,13px);background:var(--inv-bg);color:var(--inv-text-1);display:flex;flex-direction:column;font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:13px;height:100%;overflow:hidden;position:relative}.inv-root,.inv-root *,.inv-root :after,.inv-root :before{box-sizing:border-box}.inv-root input[type=number]::-webkit-inner-spin-button{opacity:.4}.inv-root input,.inv-root select,.inv-root textarea{transition:border-color .15s,outline .15s}.inv-root input:focus,.inv-root select:focus,.inv-root textarea:focus{border-color:var(--inv-accent-bdr)!important;outline:none}.inv-root ::-webkit-scrollbar{height:5px;width:5px}.inv-root ::-webkit-scrollbar-track{background:#0000}.inv-root ::-webkit-scrollbar-thumb{background:var(--inv-scroll-thumb);border-radius:3px}[data-theme=light] .inv-root{--inv-bg:#f0f4f8;--inv-bg-2:#e8edf5;--inv-bg-3:#dce4ef;--inv-bg-card:#fff;--inv-border:#00000017;--inv-border-md:#00000024;--inv-text-1:#0f172a;--inv-text-2:#334155;--inv-text-3:#475569;--inv-text-4:#64748b;--inv-text-5:#94a3b8;--inv-accent:#0284c7;--inv-accent-lt:#0369a1;--inv-accent-bg:#0284c71a;--inv-accent-bdr:#0284c74d;--inv-success:#16a34a;--inv-success-bg:#16a34a1a;--inv-danger:#dc2626;--inv-danger-bg:#dc26261a;--inv-warn:#d97706;--inv-scroll-thumb:#0000002e;--inv-bg-input:#0000000a;--inv-bg-select:#fff;--inv-bg-hover:#0000000a;--inv-card-alt:rgba(0,0,0,.025);--inv-divider:#0000001a;--inv-brd-subtle:#00000012;--inv-row-border:#0000000f;--inv-btn-2-bg:#0000000f;--inv-btn-2-hov:#0000001f}.inv-header{align-items:center;background:var(--inv-header-bg);border-bottom:1px solid var(--inv-header-border);display:flex;flex-shrink:0;font-family:var(--inv-header-font-family);font-size:var(--inv-header-font-size);gap:12px;height:56px;justify-content:space-between;padding:0 24px;z-index:10}.inv-header-left,.inv-header-right{align-items:center;display:flex;gap:8px}.inv-header-divider{background:var(--inv-header-border);flex-shrink:0;height:28px;width:1px}.inv-brand{align-items:center;display:flex;gap:10px}.inv-brand-logo{border-radius:4px;height:32px;max-width:80px;object-fit:contain}.inv-brand-icon{align-items:center;background:linear-gradient(135deg,#0ea5e9,#6366f1);border-radius:8px;display:flex;font-size:16px;height:32px;justify-content:center;width:32px}.inv-brand-name{color:var(--inv-header-text);font-size:14px;font-weight:900;letter-spacing:-.3px}.inv-brand-tag{font-size:9px;letter-spacing:1px;margin-top:-2px}.inv-brand-tag,.inv-nav-btn{color:var(--inv-header-muted)}.inv-nav-btn{background:#0000;border:none;border-radius:7px;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px;position:relative;transition:all .15s}.inv-nav-btn:hover{background:var(--inv-header-chip-bg);color:var(--inv-header-text)}.inv-nav-btn.active{background:var(--inv-header-active-bg);color:var(--inv-header-active-text)}.inv-nav-dot{background:var(--inv-success);border-radius:50%;height:5px;position:absolute;right:4px;top:4px;width:5px}.inv-mode-btn{background:var(--inv-header-chip-bg);border:1px solid var(--inv-header-border);border-radius:6px;color:var(--inv-header-muted);cursor:pointer;font-size:10px;font-weight:600;padding:5px 10px;transition:all .15s}.inv-mode-btn.active{background:var(--inv-header-active-bg);border-color:var(--inv-header-active-text);color:var(--inv-header-active-text)}.inv-status-select{background:var(--inv-header-chip-bg);border:1px solid var(--inv-header-border);border-radius:7px;color:var(--inv-header-text);cursor:pointer;font-size:11px;outline:none;padding:6px 10px}.inv-header .inv-btn--primary{background:var(--inv-header-btn-bg);color:var(--inv-header-btn-text)}.inv-header .inv-btn--primary:hover{background:var(--inv-header-btn-hover-bg)}.inv-header .inv-btn--primary:disabled{background:var(--inv-header-btn-disabled-bg);color:var(--inv-header-btn-text)}.inv-breadcrumb{align-items:center;background:var(--inv-card-alt);border-bottom:1px solid var(--inv-brd-subtle);display:flex;flex-shrink:0;gap:12px;overflow-x:auto;padding:6px 24px;white-space:nowrap}.inv-back-btn{background:none;border:none;border-radius:4px;color:var(--inv-text-5);cursor:pointer;font-size:11px;padding:2px 6px;transition:background .15s}.inv-back-btn:hover{background:var(--inv-brd-subtle)}.inv-breadcrumb-sep{color:var(--inv-text-5)}.inv-breadcrumb-tabs{display:flex;gap:5px}.inv-tab{align-items:center;background:#0000;border:1px solid var(--inv-border-md);border-radius:20px;color:var(--inv-text-4);cursor:pointer;display:inline-flex;font-size:10px;font-weight:600;gap:5px;padding:3px 10px;transition:all .15s;white-space:nowrap}.inv-tab.active{background:var(--inv-accent-bg);border-color:var(--inv-accent);color:var(--inv-accent-lt)}.inv-tab-dot{border-radius:50%;flex-shrink:0;height:5px;width:5px}.inv-tab-more{color:var(--inv-text-5);font-size:10px;padding:3px 6px}.inv-tab-new{background:#0ea5e90f;border:1px dashed var(--inv-accent-bdr);border-radius:20px;color:var(--inv-accent-lt);cursor:pointer;flex-shrink:0;font-size:10px;font-weight:600;margin-left:auto;padding:3px 10px;transition:background .15s}.inv-tab-new:hover{background:var(--inv-accent-bg)}.inv-content{display:flex;flex:1 1;overflow:hidden}.inv-scroll-area{flex:1 1;overflow-y:auto}.inv-settings-bg{background:var(--inv-bg-2)}.inv-editor-layout{display:flex;flex:1 1;min-width:0;overflow:hidden}.inv-form-panel{background:var(--inv-bg-2);border-right:1px solid var(--inv-brd-subtle);flex-shrink:0;isolation:isolate;overflow-x:hidden;overflow-y:auto;padding:20px;width:440px}.inv-form-panel--full{margin:0 auto;max-width:800px;width:100%}.inv-form-top-bar{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:16px}.inv-form-inv-num{color:var(--inv-text-1);font-size:14px;font-weight:800}.inv-form-updated{color:var(--inv-text-5);font-size:10px;margin-top:1px}.inv-form-top-right{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.inv-form-total{color:var(--inv-accent);font-size:13px;font-weight:800}.inv-preview-panel{align-items:center;background:var(--inv-bg-3);display:flex;flex:1 1;flex-direction:column;gap:20px;min-width:0;overflow:auto;padding:24px 20px}.inv-preview-panel--full{padding:40px}.inv-tmpl-bar{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:8px;justify-content:center;width:100%}.inv-tmpl-label{color:var(--inv-text-5);font-size:10px;letter-spacing:1px;white-space:nowrap}.inv-tmpl-btn{background:#0000;border:1px solid var(--inv-border-md);border-radius:6px;color:var(--inv-text-4);cursor:pointer;font-size:10px;font-weight:600;padding:4px 10px;transition:all .15s}.inv-tmpl-btn.active{background:var(--inv-accent-bg);border-color:var(--inv-accent);color:var(--inv-accent-lt)}.inv-preview-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:4px;padding-bottom:24px}.inv-no-invoice{align-items:center;color:var(--inv-text-5);display:flex;flex:1 1;flex-direction:column;gap:16px;justify-content:center}.inv-no-invoice-icon{font-size:48px}.inv-no-invoice-title{color:var(--inv-text-4);font-size:18px;font-weight:700}.inv-btn{align-items:center;border-radius:8px;cursor:pointer;display:inline-flex;font-weight:600;gap:6px;text-decoration:none;transition:all .15s;white-space:nowrap}.inv-btn:disabled{cursor:not-allowed;opacity:.5}.inv-btn--sm{font-size:10px;padding:5px 10px}.inv-btn--md{font-size:11px;padding:8px 16px}.inv-btn--lg{font-size:13px;padding:12px 24px}.inv-btn--primary{background:var(--inv-accent);border:none;color:#fff}.inv-btn--primary:hover{background:#0284c7}.inv-btn--secondary{background:var(--inv-btn-2-bg);border:1px solid var(--inv-border-md);color:var(--inv-text-2)}.inv-btn--secondary:hover{background:var(--inv-btn-2-hov)}.inv-btn--danger{background:var(--inv-danger-bg);border:1px solid #ef444440;color:var(--inv-danger)}.inv-btn--success{background:var(--inv-success-bg);border:1px solid #4ade8040;color:var(--inv-success)}.inv-btn--ghost{background:#0000;border:1px solid #0000;color:var(--inv-text-4)}.inv-field{display:flex;flex-direction:column;gap:5px;min-width:0}.inv-label{color:var(--inv-text-4);font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;-webkit-user-select:none;user-select:none}.inv-input{background:var(--inv-bg-input);border:1px solid var(--inv-border);border-radius:8px;color:var(--inv-text-1);font-size:12px;min-width:0;outline:none;overflow:hidden;padding:8px 11px;text-overflow:ellipsis;width:100%}.inv-input:hover{background:var(--inv-bg-hover);border-color:var(--inv-border-md)}.inv-input:focus{background:#0ea5e90f;border-color:var(--inv-accent-bdr)!important;outline:2px solid #0ea5e926;outline-offset:0}.inv-select{appearance:auto;background:var(--inv-bg-select);border:1px solid var(--inv-border);border-radius:8px;color:var(--inv-text-1);cursor:pointer;font-size:12px;min-width:0;outline:none;padding:8px 11px;width:100%}.inv-select:hover{border-color:var(--inv-border-md)}.inv-select:focus{border-color:var(--inv-accent-bdr)!important;outline:2px solid #0ea5e926;outline-offset:0}.inv-textarea{background:var(--inv-bg-input);border:1px solid var(--inv-border);border-radius:8px;color:var(--inv-text-1);font-family:inherit;font-size:11px;line-height:1.6;min-width:0;outline:none;padding:9px 11px;resize:vertical;width:100%}.inv-textarea:hover{border-color:var(--inv-border-md)}.inv-textarea:focus{background:#0ea5e90a;border-color:var(--inv-accent-bdr)!important;outline:2px solid #0ea5e926;outline-offset:0}.inv-mono{font-family:Courier New,monospace!important;font-size:11px!important}.inv-toggle-wrap{align-items:center;cursor:pointer;display:inline-flex;gap:8px;-webkit-user-select:none;user-select:none}.inv-toggle{background:var(--inv-border-md);border-radius:10px;flex-shrink:0;height:19px;position:relative;transition:background .2s;width:34px}.inv-toggle--on{background:var(--inv-accent)}.inv-toggle-thumb{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000004d;height:14px;left:2.5px;position:absolute;top:2.5px;transition:left .2s;width:14px}.inv-toggle--on .inv-toggle-thumb{left:17px}.inv-toggle-label{color:var(--inv-text-3);font-size:11px}.inv-toggle-row{display:flex;flex-wrap:wrap;gap:16px}.inv-status-badge{align-items:center;border:1px solid #0000;border-radius:20px;display:inline-flex;gap:5px;padding:3px 10px}.inv-status-dot{border-radius:50%;height:6px;width:6px}.inv-status-label{font-size:10px;font-weight:700;letter-spacing:.5px}.inv-editor-form{display:flex;flex-direction:column}.inv-section{background:var(--inv-bg-card);border:1px solid var(--inv-border);border-radius:14px;margin-bottom:14px;padding:20px;position:relative}.inv-section-hdr{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px;pointer-events:none}.inv-section-hdr--toggle{cursor:pointer;pointer-events:auto}.inv-section-hdr--toggle .inv-section-title{pointer-events:none}.inv-section-hdr--toggle:hover .inv-section-title{color:#60a5fa}.inv-section-title{color:var(--inv-accent-lt);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.inv-section-caret{color:var(--inv-text-5);display:inline-block;font-size:12px;pointer-events:none;transition:transform .2s}.inv-section-caret.open{transform:rotate(180deg)}.inv-section-body{pointer-events:auto}.inv-grid-2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.inv-grid-3{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr}.inv-grid-2>*,.inv-grid-3>*{min-width:0}.inv-col-span-2{grid-column:1/-1}.inv-stack{display:flex;flex-direction:column;gap:12px}.inv-mb-2{margin-bottom:8px}.inv-mb-3{margin-bottom:12px}.inv-mt-2{margin-top:8px}.inv-mt-3{margin-top:14px}.inv-item-hdr{grid-gap:5px;align-items:center;color:var(--inv-text-4);display:grid;font-size:9px;font-weight:700;gap:5px;grid-template-columns:1fr 56px 56px 84px 64px 64px 84px 30px;letter-spacing:.8px;margin-bottom:4px;padding:0 2px;text-transform:uppercase}.inv-item-hdr>*{min-width:0}.inv-item-row{grid-gap:5px;align-items:center;display:grid;gap:5px;grid-template-columns:1fr 56px 56px 84px 64px 64px 84px 30px;margin-bottom:5px}.inv-item-row>*{min-width:0}.inv-item-num{font-size:11px!important;padding-left:5px!important;padding-right:5px!important;text-align:right}.inv-item-desc{font-size:12px}.inv-item-total{color:var(--inv-text-1);font-size:12px;font-weight:700;overflow:hidden;padding-right:2px;text-align:right;text-overflow:ellipsis;white-space:nowrap}.inv-item-remove{align-items:center;background:#0000;border:1px solid #ef444433;border-radius:6px;color:var(--inv-danger);cursor:pointer;display:flex;flex-shrink:0;font-size:10px;height:26px;justify-content:center;padding:0;transition:background .15s;width:26px}.inv-item-remove:hover{background:var(--inv-danger-bg)}.inv-btn-add-item{background:#0000;border:1px dashed var(--inv-border-md);border-radius:8px;color:var(--inv-accent-lt);cursor:pointer;font-size:11px;font-weight:600;margin-top:8px;padding:8px 14px;text-align:center;transition:background .15s;width:100%}.inv-btn-add-item:hover{background:var(--inv-accent-bg)}.inv-totals{background:var(--inv-card-alt);border:1px solid var(--inv-border);border-radius:10px;display:flex;flex-direction:column;gap:4px;margin-top:14px;padding:12px 16px}.inv-totals-row{color:var(--inv-text-3);display:flex;font-size:11px;justify-content:space-between;padding:2px 0}.inv-totals-discount span:last-child{color:var(--inv-danger)}.inv-totals-grand{border-top:1px solid var(--inv-border-md);color:var(--inv-text-1);font-size:13px;font-weight:800;margin-top:6px;padding-top:8px}.inv-pill-group{display:flex;flex-wrap:wrap;gap:6px}.inv-pill{background:#0000;border:1px solid var(--inv-border-md);border-radius:6px;color:var(--inv-text-3);cursor:pointer;font-size:11px;font-weight:600;padding:5px 10px;transition:all .15s}.inv-pill.active{background:var(--inv-accent-bg);border-color:var(--inv-accent);color:var(--inv-accent-lt)}.inv-link{background:none;border:none;color:var(--inv-accent-lt);cursor:pointer;font-size:10px;font-weight:600;padding:0;text-decoration:underline}.inv-muted{color:var(--inv-text-5)}.inv-italic{font-style:italic}.inv-overdue{color:var(--inv-danger)!important}.inv-logo-hint{align-items:center;background:var(--inv-card-alt);border:1px solid var(--inv-brd-subtle);border-radius:8px;display:flex;gap:10px;padding:10px}.inv-logo-hint-img{border:1px solid var(--inv-border);border-radius:4px;height:36px;object-fit:contain}.inv-logo-hint-placeholder{align-items:center;background:var(--inv-bg-hover);border:1px dashed var(--inv-border-md);border-radius:4px;display:flex;font-size:18px;height:36px;justify-content:center;width:36px}.inv-logo-hint-text{flex:1 1}.inv-logo-hint-name{color:var(--inv-text-1);font-size:11px;font-weight:600}.inv-logo-hint-sub{color:var(--inv-text-5);font-size:10px;margin-top:1px}.inv-list-page{margin:0 auto;max-width:1200px;padding:28px 32px}.inv-stats-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:16px}.inv-stat-card{background:var(--inv-bg-card);border:1px solid #0000;border-radius:10px;overflow:hidden;padding:8px 10px;position:relative}.inv-stat-icon{font-size:18px;opacity:.18;position:absolute;right:10px;top:8px}.inv-stat-label{color:var(--inv-text-4);font-size:9px;font-weight:600;letter-spacing:.5px;margin-bottom:4px}.inv-stat-value{font-size:20px;font-weight:900;line-height:1}.inv-stat-sub{color:var(--inv-text-3);font-size:9px;margin-top:3px}.inv-list-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:18px}.inv-filter-pills{display:flex;flex-wrap:wrap;gap:6px}.inv-list-controls{align-items:center;display:flex;gap:8px}.inv-search{background:var(--inv-bg-input);border:1px solid var(--inv-border-md);border-radius:8px;color:var(--inv-text-1);font-size:11px;outline:none;padding:7px 12px;transition:border-color .15s;width:200px}.inv-search:focus{border-color:var(--inv-accent-bdr)}.inv-sort{cursor:pointer;min-width:140px}.inv-table{background:var(--inv-card-alt);border:1px solid var(--inv-border);border-radius:14px;overflow:hidden}.inv-table-hdr{grid-gap:0;background:var(--inv-bg-card);border-bottom:1px solid var(--inv-border);display:grid;gap:0;grid-template-columns:1.2fr 2fr 1fr 1fr 1fr 1.2fr auto;padding:10px 20px}.inv-table-hdr-cell{color:var(--inv-text-5);font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.inv-table-hdr-cell.right{text-align:right}.inv-table-row{grid-gap:0;align-items:center;border-bottom:1px solid var(--inv-row-border);cursor:pointer;display:grid;gap:0;grid-template-columns:1.2fr 2fr 1fr 1fr 1fr 1.2fr auto;padding:14px 20px;transition:background .15s}.inv-table-row:last-child{border-bottom:none}.inv-table-row:hover{background:#0ea5e90d}.inv-table-row--alt{background:var(--inv-card-alt)}.inv-table-num{color:var(--inv-accent-lt);font-size:12px;font-weight:700}.inv-table-client{color:var(--inv-text-1);font-size:12px;font-weight:600}.inv-table-email{color:var(--inv-text-4);font-size:10px}.inv-table-date{color:var(--inv-text-3);font-size:11px}.inv-table-amount{color:var(--inv-text-1);font-size:13px;font-weight:700;text-align:right}.inv-table-actions{display:flex;gap:4px;min-width:130px}.inv-action-btn{border-radius:5px;cursor:pointer;font-size:9px;font-weight:600;padding:4px 8px;transition:background .15s}.inv-action-edit{background:#0ea5e914;border:1px solid #0ea5e94d;color:var(--inv-accent-lt)}.inv-action-copy{background:#0000;border:1px solid var(--inv-border-md);color:var(--inv-text-3)}.inv-action-del{background:#0000;border:1px solid #ef444433;color:var(--inv-danger)}.inv-action-edit:hover{background:#0ea5e92e}.inv-action-copy:hover{background:var(--inv-btn-2-bg)}.inv-action-del:hover{background:var(--inv-danger-bg)}.inv-empty-state{align-items:center;color:var(--inv-text-5);display:flex;flex-direction:column;gap:8px;padding:60px 0;text-align:center}.inv-empty-icon{font-size:40px;margin-bottom:4px}.inv-empty-title{color:var(--inv-text-4);font-size:16px;font-weight:700}.inv-empty-sub{font-size:12px;margin-bottom:12px}.inv-profile-page{margin:0 auto;max-width:800px;padding:28px 32px}.inv-profile-header{margin-bottom:28px}.inv-profile-title{color:var(--inv-text-1);font-size:22px;font-weight:900;letter-spacing:-.5px}.inv-profile-sub{color:var(--inv-text-5);font-size:12px;margin-top:4px}.inv-profile-card{background:var(--inv-bg-card);border:1px solid var(--inv-border);border-radius:16px;margin-bottom:18px;padding:24px}.inv-profile-card-title{color:var(--inv-accent);font-size:11px;font-weight:700;letter-spacing:1px;margin-bottom:16px;text-transform:uppercase}.inv-logo-area{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px}.inv-logo-preview{align-items:center;background:var(--inv-bg-hover);border:1px solid var(--inv-border-md);border-radius:12px;display:flex;flex-shrink:0;height:80px;justify-content:center;overflow:hidden;width:140px}.inv-logo-img{max-height:100%;max-width:100%;object-fit:contain}.inv-logo-empty{text-align:center}.inv-logo-empty-icon{font-size:28px;margin-bottom:4px}.inv-logo-empty-label{color:var(--inv-text-5);font-size:9px}.inv-logo-controls{flex:1 1;min-width:200px}.inv-logo-status{color:var(--inv-text-1);font-size:13px;font-weight:700;margin-bottom:6px}.inv-logo-hint-text-sm{color:var(--inv-text-4);font-size:11px;line-height:1.6;margin-bottom:12px}.inv-logo-hint-text-sm strong{color:var(--inv-text-3)}.inv-logo-btn-row{display:flex;flex-wrap:wrap;gap:8px}.inv-upload-btn{align-items:center;background:var(--inv-accent-bg);border:1px solid var(--inv-accent-bdr);border-radius:8px;color:var(--inv-accent-lt);cursor:pointer;display:inline-flex;font-size:12px;font-weight:700;gap:7px;padding:9px 16px;transition:background .15s}.inv-upload-btn:hover{background:#0ea5e933}.inv-logo-remove-btn{background:var(--inv-danger-bg);border:1px solid #ef444459;border-radius:8px;color:var(--inv-danger);cursor:pointer;font-size:12px;font-weight:600;padding:9px 14px;transition:background .15s}.inv-logo-remove-btn:hover{background:#ef444433}.inv-drop-zone{border:1px dashed var(--inv-border-md);border-radius:8px;color:var(--inv-text-5);cursor:pointer;font-size:10px;margin-top:10px;padding:10px 14px;text-align:center;transition:border-color .2s}.inv-drop-zone.drag-over,.inv-drop-zone:hover{border-color:var(--inv-accent)}.inv-logo-mini-preview{flex-shrink:0}.inv-mini-preview-label{color:var(--inv-text-5);font-size:9px;letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}.inv-mini-card{border-radius:8px;box-shadow:0 4px 20px #0006;overflow:hidden;width:200px}.inv-mini-hdr{align-items:center;background:#1e293b;display:flex;justify-content:space-between;padding:12px 14px}.inv-mini-logo{display:block;height:28px;object-fit:contain}.inv-mini-company{color:#fff;font-size:11px;font-weight:900}.inv-mini-email{color:#fff6;font-size:8px;margin-top:2px}.inv-mini-right{text-align:right}.inv-mini-inv-title{color:#0ea5e9;font-size:13px;font-weight:900}.inv-mini-inv-num{color:#ffffff80;font-size:8px}.inv-mini-body{background:#fff;padding:8px 14px}.inv-mini-bill-lbl{color:#64748b;font-size:8px;font-weight:700;margin-bottom:3px}.inv-mini-bill-co{color:#1e293b;font-size:9px;font-weight:600}.inv-mini-note{color:#94a3b8;font-size:8px;margin-top:8px}.inv-profile-footer{display:flex;gap:10px;justify-content:flex-end}.inv-save-btn{align-items:center;background:var(--inv-accent);border:none;border-radius:9px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:800;gap:8px;padding:10px 28px;transition:background .2s}.inv-save-btn:hover{background:#0284c7}.inv-save-btn--saved{background:#4ade80;color:#052e16}.inv-toast{animation:inv-slide-in .25s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0ea5e9e6;border-radius:10px;bottom:24px;box-shadow:0 8px 32px #0006;color:#fff;font-size:12px;font-weight:700;letter-spacing:.3px;padding:12px 20px;position:fixed;right:24px;z-index:1000}.inv-toast--danger{background:#ef4444e6}@keyframes inv-slide-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1100px){.inv-form-panel{width:400px}}@media (max-width:960px){.inv-stats-grid{grid-template-columns:1fr 1fr}.inv-form-panel{width:360px}.inv-grid-3{grid-template-columns:1fr 1fr}.inv-item-hdr,.inv-item-row{gap:4px;grid-template-columns:1fr 50px 50px 70px 58px 58px 70px 26px}}@media (max-width:780px){.inv-list-page{padding:16px}.inv-stats-grid{gap:8px;grid-template-columns:1fr 1fr}.inv-editor-layout{flex-direction:column}.inv-form-panel{border-bottom:1px solid var(--inv-brd-subtle);border-right:none;max-height:60vh;width:100%}.inv-preview-panel{min-height:400px}.inv-grid-2,.inv-grid-3{grid-template-columns:1fr 1fr}}@media (max-width:560px){.inv-grid-2,.inv-grid-3{grid-template-columns:1fr}.inv-col-span-2{grid-column:1}.inv-item-hdr{display:none}.inv-item-row{background:var(--inv-card-alt);border:1px solid var(--inv-border);border-radius:8px;gap:6px;grid-template-columns:1fr 1fr;margin-bottom:8px;padding:10px}.inv-item-desc{grid-column:1/-1}.inv-item-remove,.inv-item-total{grid-row:auto}.inv-header{gap:8px;height:auto;padding:10px 16px}.inv-header,.inv-header-left,.inv-header-right{flex-wrap:wrap}.inv-list-toolbar{align-items:stretch;flex-direction:column}.inv-list-controls{flex-wrap:wrap}.inv-search{width:100%}.inv-profile-page{padding:16px}.inv-logo-area{flex-direction:column}.inv-logo-mini-preview{display:none}}.zp-page{color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif);padding:20px 28px}.zp-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:18px}.zp-title{color:#222;font-size:20px;font-weight:600;margin:0}.zp-header-right{align-items:center;display:flex;gap:8px}.zp-add-dropdown{position:relative}.zp-btn-add{align-items:center;background:#36f;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 18px;transition:background .15s}.zp-btn-add:hover{background:#2952cc}.zp-dropdown-menu{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e0e0e0;border:1px solid var(--border-default,#e0e0e0);border-radius:4px;box-shadow:0 4px 16px #0000001f;min-width:160px;overflow:hidden;position:absolute;right:0;top:calc(100% + 4px);z-index:100}.zp-dropdown-item{background:none;border:none;color:#333;cursor:pointer;display:block;font-size:13px;padding:9px 16px;text-align:left;transition:background .1s;width:100%}.zp-dropdown-item:hover{background:#f5f5f5}.zp-btn-help{background:#ff9800;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:14px;font-weight:700;height:30px;width:30px}.zp-tabs{border-bottom:2px solid #e8e8e8;display:flex;gap:0;margin-bottom:0}.zp-tab{background:#0000;border:none;color:#666;cursor:pointer;font-size:13px;font-weight:500;padding:10px 20px;position:relative;transition:color .15s}.zp-tab:hover{color:#333}.zp-tab.active{color:#222;font-weight:600}.zp-tab.active:after{background:#36f;bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.zp-search-row{background:#fafafa;border-bottom:1px solid #e8e8e8;display:flex;justify-content:center;padding:12px 0}.zp-search-inline{position:relative;width:320px}.zp-search-icon{color:#999;left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.zp-search-inline input{background:#fff;background:var(--surface-primary,#fff);border:1px solid #ddd;border-radius:4px;box-sizing:border-box;color:#555;color:var(--text-secondary,#555);font-size:13px;outline:none;padding:7px 12px 7px 32px;width:100%}.zp-search-inline input:focus{border-color:#36f;box-shadow:0 0 0 2px #3366ff1a}.zp-info-banner{align-items:flex-start;background:#e8f4fd;border:1px solid #b3d9f2;border-radius:4px;color:#1a6fb5;display:flex;font-size:12.5px;gap:8px;line-height:1.5;margin:12px 0;padding:12px 16px}.zp-info-icon{flex-shrink:0;font-size:16px;margin-top:1px}.zp-table-wrap{background:#fff;background:var(--surface-primary,#fff);overflow-x:auto}.zp-table{border-collapse:collapse;font-size:13px;width:100%}.zp-table th{border-bottom:1px solid #e8e8e8;color:#666;font-size:11px;font-weight:700;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.zp-table td{border-bottom:1px solid #f0f0f0;color:#444;padding:14px 16px;vertical-align:middle}.zp-table tr:hover td{background:#fafafa}.zp-table tr:last-child td{border-bottom:1px solid #e8e8e8}.zp-link{color:#36f;cursor:pointer;font-weight:500;text-decoration:none}.zp-link:hover{text-decoration:underline}.zp-status-active{color:#22a06b;font-weight:500}.zp-status-inactive{color:#999;font-weight:500}.zp-epf-cond{color:#999;font-size:10px;font-weight:400}.zp-action-cell{text-align:center;width:40px}.zp-row-action{background:none;border:none;color:#bbb;cursor:pointer;font-size:16px;line-height:1;padding:2px;transition:color .15s}.zp-row-action:hover{color:#e53935}.zp-footer{align-items:center;border-top:1px solid #e8e8e8;color:#666;display:flex;justify-content:space-between;padding:12px 16px}.zp-footer,.zp-footer-left .zp-link{font-size:12px}.zp-footer-right{align-items:center;display:flex;gap:12px}.zp-per-page select{background:#fff;background:var(--surface-primary,#fff);border:1px solid #ddd;border-radius:3px;color:#555;font-size:11px;padding:3px 6px}.zp-page-nav{align-items:center;display:flex;font-size:12px;gap:6px}.zp-page-nav button{align-items:center;background:none;border:1px solid #ddd;border-radius:3px;color:#555;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;width:24px}.zp-page-nav button:disabled{cursor:default;opacity:.4}.zp-page-nav button:not(:disabled):hover{background:#f0f0f0}.zp-empty,.zp-loading{color:#aaa;font-size:13px;padding:40px;text-align:center}.zp-overlay{align-items:flex-start;background:#00000059;display:flex;inset:0;justify-content:center;padding-top:60px;position:fixed;z-index:1000}.zp-modal{background:#fff;background:var(--surface-primary,#fff);border-radius:6px;box-shadow:0 8px 32px #0000002e;max-height:calc(100vh - 120px);max-width:680px;overflow-y:auto;width:90%}.zp-modal-header{align-items:center;border-bottom:1px solid #e8e8e8;display:flex;justify-content:space-between;padding:16px 24px}.zp-modal-header h3{color:#333;font-size:17px;font-weight:600;margin:0}.zp-modal-close{background:none;border:none;color:#999;cursor:pointer;padding:4px}.zp-modal-close:hover{color:#333}.zp-modal-body{padding:20px 24px}.zp-modal-sep{border-top:1px solid #e8e8e8;margin:16px 0}.zp-form-section{border-top:1px solid #f0f0f0;color:#888;font-size:11px;font-weight:700;letter-spacing:.5px;margin:16px 0 8px;padding-top:12px;text-transform:uppercase}.zp-form-section:first-child{border-top:none;margin-top:0;padding-top:0}.zp-form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:14px}.zp-form-group{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.zp-label{color:#444;font-size:13px;font-weight:600}.zp-req{color:#e53935}.zp-input,.zp-select{background:#fff;background:var(--surface-primary,#fff);border:1px solid #ddd;border-radius:4px;box-sizing:border-box;color:#333;color:var(--text-primary,#333);font-size:13px;outline:none;padding:8px 12px;transition:border-color .15s}.zp-input:focus,.zp-select:focus{border-color:#36f;box-shadow:0 0 0 2px #3366ff1a}.zp-check-row{display:flex;flex-wrap:wrap;gap:16px 28px;margin-bottom:12px}.zp-checkbox{align-items:center;color:#444;cursor:pointer;display:flex;font-size:13px;gap:6px}.zp-checkbox input[type=checkbox]{accent-color:#36f}.zp-modal-footer{align-items:center;display:flex;gap:10px}.zp-btn-save{background:#36f;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 24px}.zp-btn-save:hover{background:#2952cc}.zp-btn-cancel{background:#fff;background:var(--surface-primary,#fff);border:1px solid #ddd;border:1px solid var(--border-default,#ddd);border-radius:4px;color:#333;color:var(--text-primary,#333);cursor:pointer;font-size:13px;padding:8px 18px}.zp-btn-cancel:hover{background:#f5f5f5}.zp-req-note{color:#e53935;font-size:11px;font-style:italic;margin-left:auto}@media (max-width:768px){.zp-page{padding:12px 16px}.zp-form-row{grid-template-columns:1fr}.zp-tabs{overflow-x:auto}.zp-header{flex-wrap:wrap;gap:8px}}@media (max-width:480px){.zp-form-row{grid-template-columns:1fr}.zp-header{align-items:flex-start;flex-direction:column;gap:8px}.zp-search-inline{width:100%}.zp-search-row{padding:8px 12px}.zp-modal-footer{flex-wrap:wrap;gap:8px}}.pr-root{--pr-bg:#080d18;--pr-bg-2:#0c1222;--pr-bg-card:#ffffff0a;--pr-bg-card-alt:#ffffff05;--pr-bg-hover:#ffffff0a;--pr-border:#ffffff14;--pr-border-md:#ffffff1f;--pr-brd-subtle:#ffffff0d;--pr-text-1:#e2e8f0;--pr-text-2:#cbd5e1;--pr-text-3:#94a3b8;--pr-text-4:#64748b;--pr-text-5:#475569;--pr-blue:#2563eb;--pr-blue-lt:#60a5fa;--pr-blue-bg:#2563eb1f;--pr-blue-bdr:#2563eb4d;--pr-green:#059669;--pr-green-bg:#0596691f;--pr-amber:#d97706;--pr-amber-bg:#d977061f;--pr-red:#dc2626;--pr-red-bg:#dc26261f;--pr-purple:#4f46e5;--pr-purple-bg:#4f46e51f;--pr-scroll-thumb:#ffffff1a;--pr-input-bg:#ffffff0d;--pr-select-bg:#1a2235;--pr-divider:#ffffff12;--pr-row-hover:#0ea5e90d;--pr-btn2-bg:#ffffff0f;--pr-btn2-hov:#ffffff1c;background:var(--pr-bg);color:var(--pr-text-1);display:flex;flex-direction:column;font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:13px;height:100%;overflow:hidden}.pr-root,.pr-root *,.pr-root :after,.pr-root :before{box-sizing:border-box}.pr-root ::-webkit-scrollbar{height:5px;width:5px}.pr-root ::-webkit-scrollbar-track{background:#0000}.pr-root ::-webkit-scrollbar-thumb{background:var(--pr-scroll-thumb);border-radius:3px}.pr-root input,.pr-root select,.pr-root textarea{font-family:inherit;transition:border-color .15s,outline .15s}[data-theme=light] .pr-root{--pr-bg:#f0f4f8;--pr-bg-2:#e8edf5;--pr-bg-card:#fff;--pr-bg-card-alt:#f8fafc;--pr-bg-hover:#0000000a;--pr-border:#00000017;--pr-border-md:#00000024;--pr-brd-subtle:#0000000f;--pr-text-1:#0f172a;--pr-text-2:#1e293b;--pr-text-3:#475569;--pr-text-4:#64748b;--pr-text-5:#94a3b8;--pr-blue:#2563eb;--pr-blue-lt:#1d4ed8;--pr-blue-bg:#2563eb17;--pr-blue-bdr:#2563eb47;--pr-green:#059669;--pr-green-bg:#05966917;--pr-amber:#d97706;--pr-amber-bg:#d9770617;--pr-red:#dc2626;--pr-red-bg:#dc262617;--pr-purple:#4f46e5;--pr-purple-bg:#4f46e517;--pr-scroll-thumb:#0000002e;--pr-input-bg:#0000000a;--pr-select-bg:#fff;--pr-divider:#00000014;--pr-row-hover:#0284c70d;--pr-btn2-bg:#0000000f;--pr-btn2-hov:#0000001c}.pr-topbar{background:var(--pr-bg-2);border-bottom:1px solid var(--pr-border);flex-shrink:0;height:56px;justify-content:space-between;padding:0 24px}.pr-topbar,.pr-topbar-left{align-items:center;display:flex;gap:12px}.pr-topbar-right{gap:8px}.pr-brand,.pr-topbar-right{align-items:center;display:flex}.pr-brand{gap:10px}.pr-brand-icon{align-items:center;background:linear-gradient(135deg,#2563eb,#4f46e5);border-radius:9px;display:flex;flex-shrink:0;font-size:16px;height:34px;justify-content:center;width:34px}.pr-brand-name{color:var(--pr-text-1);font-size:15px;font-weight:900;letter-spacing:-.3px}.pr-brand-tag{color:var(--pr-text-5);font-size:9px;letter-spacing:1px;margin-top:-2px}.pr-co-badge{background:var(--pr-blue-bg);border:1px solid var(--pr-blue-bdr);border-radius:6px;color:var(--pr-blue-lt);font-size:11px;font-weight:600;padding:4px 10px}.pr-co-select{background:var(--pr-select-bg);border:1px solid var(--pr-border-md);border-radius:8px;color:var(--pr-text-1);cursor:pointer;font-size:12px;min-width:200px;outline:none;padding:6px 10px}.pr-co-select:focus{border-color:var(--pr-blue-bdr)}.pr-tabs{align-items:flex-end;background:var(--pr-bg-2);border-bottom:1px solid var(--pr-border);display:flex;flex-shrink:0;gap:2px;padding:0 24px}.pr-tab{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:var(--pr-text-4);cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:7px;margin-bottom:-1px;padding:12px 16px;transition:all .15s;white-space:nowrap}.pr-tab:hover{color:var(--pr-text-2)}.pr-tab.active{border-bottom-color:var(--pr-blue);color:var(--pr-blue)}.pr-tab-icon{font-size:14px}.pr-content{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:24px 28px}.pr-stats-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:16px}.pr-stat-card{background:var(--pr-bg-card);border:1px solid var(--pr-border);border-radius:10px;overflow:hidden;padding:8px 10px;position:relative;transition:border-color .15s}.pr-stat-card:hover{border-color:var(--pr-border-md)}.pr-stat-card:before{background:var(--pr-blue);background:var(--pr-card-accent,var(--pr-blue));border-radius:14px 14px 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.pr-stat-icon{font-size:26px;opacity:.15;position:absolute;right:14px;top:12px}.pr-stat-label{color:var(--pr-text-4);font-size:9px;font-weight:700;letter-spacing:.6px;margin-bottom:4px;text-transform:uppercase}.pr-stat-value{font-size:20px;font-weight:900;line-height:1}.pr-stat-sub{color:var(--pr-text-4);font-size:9px;margin-top:4px}.pr-card{background:var(--pr-bg-card);border:1px solid var(--pr-border);border-radius:14px;margin-bottom:18px;overflow:hidden}.pr-card-hdr{border-bottom:1px solid var(--pr-border);flex-wrap:wrap;gap:10px;justify-content:space-between;padding:14px 20px}.pr-card-hdr,.pr-card-title{align-items:center;display:flex}.pr-card-title{color:var(--pr-text-1);font-size:13px;font-weight:700;gap:8px}.pr-card-subtitle{color:var(--pr-text-4);font-size:11px;margin-top:2px}.pr-card-body{padding:20px}.pr-card-body-0{padding:0}.pr-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:10px;font-weight:700;gap:5px;letter-spacing:.4px;padding:3px 10px}.pr-badge-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.pr-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:11px;font-weight:700;gap:6px;padding:8px 16px;transition:all .15s;white-space:nowrap}.pr-btn:disabled{cursor:not-allowed;opacity:.45}.pr-btn--sm{font-size:10px;padding:5px 10px}.pr-btn--lg{font-size:13px;padding:11px 22px}.pr-btn--primary{background:var(--pr-blue);color:#fff}.pr-btn--primary:hover:not(:disabled){filter:brightness(1.12)}.pr-btn--success{background:var(--pr-green-bg);border:1px solid #4ade8040;color:var(--pr-green)}.pr-btn--success:hover:not(:disabled){filter:brightness(1.1)}.pr-btn--danger{background:var(--pr-red-bg);border:1px solid #f8717140;color:var(--pr-red)}.pr-btn--danger:hover:not(:disabled){filter:brightness(1.1)}.pr-btn--amber{background:var(--pr-amber-bg);border:1px solid #fbbf2440;color:var(--pr-amber)}.pr-btn--amber:hover:not(:disabled){filter:brightness(1.1)}.pr-btn--purple{background:var(--pr-purple-bg);border:1px solid #a78bfa40;color:var(--pr-purple)}.pr-btn--purple:hover:not(:disabled){filter:brightness(1.1)}.pr-btn--ghost{background:var(--pr-btn2-bg);border:1px solid var(--pr-border-md);color:var(--pr-text-3)}.pr-btn--ghost:hover:not(:disabled){background:var(--pr-btn2-hov);color:var(--pr-text-2)}.pr-btn-group{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.pr-field{display:flex;flex-direction:column;gap:5px;min-width:0}.pr-label{color:var(--pr-text-4);font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;-webkit-user-select:none;user-select:none}.pr-input{background:var(--pr-input-bg);border:1px solid var(--pr-border);border-radius:8px;color:var(--pr-text-1);font-size:12px;min-width:0;outline:none;padding:8px 11px;width:100%}.pr-input:hover{border-color:var(--pr-border-md)}.pr-input:focus{background:#0ea5e90f;border-color:var(--pr-blue-bdr)!important;outline:2px solid #0ea5e91f;outline-offset:0}.pr-select{background:var(--pr-select-bg);border:1px solid var(--pr-border);border-radius:8px;color:var(--pr-text-1);cursor:pointer;font-size:12px;min-width:0;outline:none;padding:8px 11px;width:100%}.pr-select:hover{border-color:var(--pr-border-md)}.pr-select:focus{border-color:var(--pr-blue-bdr)!important}.pr-textarea{background:var(--pr-input-bg);border:1px solid var(--pr-border);border-radius:8px;color:var(--pr-text-1);font-family:inherit;font-size:12px;line-height:1.6;min-width:0;outline:none;padding:9px 11px;resize:vertical;width:100%}.pr-textarea:focus{border-color:var(--pr-blue-bdr)!important}.pr-toggle-wrap{align-items:center;cursor:pointer;display:inline-flex;gap:8px;-webkit-user-select:none;user-select:none}.pr-toggle{background:var(--pr-border-md);border-radius:10px;flex-shrink:0;height:19px;position:relative;transition:background .2s;width:34px}.pr-toggle--on{background:var(--pr-blue)}.pr-toggle-thumb{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000004d;height:14px;left:2.5px;position:absolute;top:2.5px;transition:left .2s;width:14px}.pr-toggle--on .pr-toggle-thumb{left:17px}.pr-toggle-label{color:var(--pr-text-3);font-size:12px}.pr-form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.pr-form-grid-2{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.pr-form-grid-2>*{min-width:0}.pr-form-grid-3{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr 1fr}.pr-form-grid-3>*{min-width:0}.pr-config-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:1fr 1fr}.pr-config-grid>*{min-width:0}.pr-config-section{background:var(--pr-bg-card);border:1px solid var(--pr-border);border-radius:14px;overflow:hidden}.pr-config-section-hdr{align-items:center;background:var(--pr-bg-card-alt);border-bottom:1px solid var(--pr-border);display:flex;gap:10px;padding:12px 18px}.pr-config-section-icon{align-items:center;border-radius:8px;display:flex;font-size:14px;height:30px;justify-content:center;width:30px}.pr-config-section-title{color:var(--pr-text-1);font-size:12px;font-weight:700;letter-spacing:.3px}.pr-config-section-sub{color:var(--pr-text-4);font-size:10px;margin-top:1px}.pr-config-section-body{display:flex;flex-direction:column;gap:12px;padding:16px 18px}.pr-tbl{border-collapse:collapse;width:100%}.pr-tbl thead tr{background:var(--pr-bg-card-alt);border-bottom:1px solid var(--pr-border)}.pr-tbl th{color:var(--pr-text-4);font-size:9px;font-weight:700;letter-spacing:1px;padding:9px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.pr-tbl td.right,.pr-tbl th.right{text-align:right}.pr-tbl td.center,.pr-tbl th.center{text-align:center}.pr-tbl td{border-bottom:1px solid var(--pr-divider);color:var(--pr-text-2);font-size:12px;padding:11px 14px}.pr-tbl tr:last-child td{border-bottom:none}.pr-tbl-row-click:hover td{background:var(--pr-row-hover);cursor:pointer}.pr-tbl-alt td{background:var(--pr-bg-card-alt)}.pr-tbl-input{background:var(--pr-input-bg);border:1px solid var(--pr-border);border-radius:5px;color:var(--pr-text-1);font-size:11px;outline:none;padding:4px 6px;text-align:right;width:80px}.pr-tbl-input:focus{border-color:var(--pr-blue-bdr)}.pr-emp-cell{align-items:center;display:flex;gap:8px}.pr-emp-avatar,.pr-emp-avatar-img{border-radius:50%;flex-shrink:0;height:28px;width:28px}.pr-emp-avatar{align-items:center;background:var(--pr-blue);color:#fff;display:flex;font-size:11px;font-weight:800;justify-content:center}.pr-emp-avatar-img{object-fit:cover}.pr-run-detail{background:var(--pr-bg-2);border:1px solid var(--pr-border);border-radius:16px;margin-top:20px;overflow:hidden}.pr-run-detail-hdr{align-items:center;border-bottom:1px solid var(--pr-border);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:16px 22px}.pr-run-title{color:var(--pr-text-1);font-size:17px;font-weight:800}.pr-run-meta{color:var(--pr-text-4);font-size:11px;margin-top:2px}.pr-run-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(5,1fr);padding:16px 22px}.pr-run-stat{background:var(--pr-bg-card);border:1px solid var(--pr-border);border-radius:10px;padding:12px 14px;text-align:center}.pr-run-stat-label{color:var(--pr-text-4);font-size:9px;font-weight:700;letter-spacing:.8px;margin-bottom:5px;text-transform:uppercase}.pr-run-stat-value{font-size:14px;font-weight:800}.pr-dept-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));padding:16px 22px}.pr-dept-card{background:var(--pr-bg-card);border:1px solid var(--pr-border);border-radius:10px;padding:12px 14px}.pr-dept-name{color:var(--pr-text-2);font-size:11px;font-weight:700;margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pr-dept-gross{color:var(--pr-blue);font-size:14px;font-weight:800}.pr-dept-count{color:var(--pr-text-4);font-size:10px;margin-top:2px}.pr-entries-toolbar{align-items:center;border-bottom:1px solid var(--pr-border);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:12px 22px}.pr-search{background:var(--pr-input-bg);border:1px solid var(--pr-border-md);border-radius:8px;color:var(--pr-text-1);font-size:11px;outline:none;padding:7px 12px;width:200px}.pr-search:focus{border-color:var(--pr-blue-bdr)}.pr-page-nav{align-items:center;display:flex;gap:6px}.pr-page-info{color:var(--pr-text-4);font-size:11px;white-space:nowrap}.pr-steps{gap:0;margin-bottom:24px;overflow:hidden}.pr-step,.pr-steps{align-items:center;display:flex}.pr-step{flex:1 1}.pr-step-dot{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:11px;font-weight:800;height:28px;justify-content:center;transition:all .2s;width:28px}.pr-step-dot--done{background:#059669;color:#dbeafe}.pr-step-dot--active{background:var(--pr-blue);box-shadow:0 0 0 4px #0ea5e933;color:#fff}.pr-step-dot--idle{background:var(--pr-bg-card);border:1px solid var(--pr-border-md);color:var(--pr-text-4)}.pr-step-label{font-size:10px;font-weight:700;margin-left:6px;white-space:nowrap}.pr-step-line{background:var(--pr-border);flex:1 1;height:2px;margin:0 8px}.pr-step-line--done{background:var(--pr-green)}.pr-schedule-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr);padding:20px}.pr-month-card{background:var(--pr-bg-card);border:1px solid var(--pr-border);border-radius:12px;padding:14px 16px;transition:border-color .15s}.pr-month-card:hover{border-color:var(--pr-border-md)}.pr-month-card--set{background:var(--pr-blue-bg);border-color:var(--pr-blue-bdr)}.pr-month-card--paid{border-color:#4ade804d}.pr-month-name{color:var(--pr-text-1);font-size:13px;font-weight:800;margin-bottom:8px}.pr-month-date{color:var(--pr-blue-lt);font-size:11px;font-weight:600}.pr-month-empty{color:var(--pr-text-5);font-size:11px}.pr-month-badge{margin-top:6px}.pr-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:900}.pr-payslip-modal{background:var(--pr-bg-card);border:1px solid var(--pr-border-md);border-radius:18px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;position:relative;width:min(720px,100%)}.pr-payslip-banner{background:linear-gradient(130deg,#0f1e3d,#1a3a5c 50%,#0f2d4a);flex-shrink:0;padding:24px 28px}[data-theme=light] .pr-payslip-banner{background:linear-gradient(130deg,#1e40af,#1d4ed8 50%,#1e3a8a)}.pr-payslip-co-name{color:#fff;font-size:18px;font-weight:900;letter-spacing:-.3px}.pr-payslip-period{color:#fff9;font-size:12px;margin-top:3px}.pr-payslip-header-row{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.pr-payslip-title{color:#ffffff80;font-size:11px;letter-spacing:2px;margin-bottom:6px;text-transform:uppercase}.pr-payslip-emp-name{color:#fff;font-size:15px;font-weight:800}.pr-payslip-emp-head{align-items:center;display:flex;gap:10px;justify-content:flex-end}.pr-payslip-emp-avatar,.pr-payslip-emp-avatar-img{border-radius:50%;flex-shrink:0;height:36px;width:36px}.pr-payslip-emp-avatar{align-items:center;background:#ffffff38;color:#fff;display:flex;font-size:13px;font-weight:800;justify-content:center}.pr-payslip-emp-avatar-img{border:1px solid #ffffff59;object-fit:cover}.pr-payslip-body{flex:1 1;overflow-y:auto;padding:20px 28px}.pr-payslip-emp-grid{grid-gap:10px;background:var(--pr-bg-card-alt);border:1px solid var(--pr-border);border-radius:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:20px;padding:14px}.pr-payslip-emp-item{min-width:0}.pr-payslip-emp-lbl{color:var(--pr-text-4);font-size:9px;font-weight:700;letter-spacing:.8px;margin-bottom:3px;text-transform:uppercase}.pr-payslip-emp-val{color:var(--pr-text-1);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pr-payslip-split{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr;margin-bottom:16px}.pr-payslip-split>*{min-width:0}.pr-payslip-col-title{background:var(--pr-bg-card-alt);border:1px solid var(--pr-border);border-bottom:none;border-radius:6px 6px 0 0;color:var(--pr-text-4);font-size:10px;font-weight:700;letter-spacing:1px;padding:8px 12px;text-transform:uppercase}.pr-payslip-col-rows{border:1px solid var(--pr-border);border-radius:0 0 6px 6px;overflow:hidden}.pr-payslip-row{border-bottom:1px solid var(--pr-divider);color:var(--pr-text-2);display:flex;font-size:11px;justify-content:space-between;padding:7px 12px}.pr-payslip-row:last-child{border-bottom:none}.pr-payslip-row-label{color:var(--pr-text-3)}.pr-payslip-row-value{color:var(--pr-text-1);font-weight:600}.pr-payslip-col-total{background:var(--pr-bg-card-alt);border:1px solid var(--pr-border);border-radius:0 0 8px 8px;border-top:none;font-size:12px;font-weight:800;padding:9px 12px}.pr-payslip-col-total,.pr-payslip-net{display:flex;justify-content:space-between}.pr-payslip-net{align-items:center;background:linear-gradient(90deg,#0ea5e91a,#6366f11a);border:1px solid var(--pr-blue-bdr);border-radius:10px;margin-bottom:16px;padding:14px 18px}.pr-payslip-net-label{color:var(--pr-text-2);font-size:12px;font-weight:700}.pr-payslip-net-value{color:var(--pr-blue);font-size:22px;font-weight:900}.pr-payslip-footer{background:var(--pr-bg-card-alt);border-top:1px solid var(--pr-border);display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;padding:14px 28px}.pr-edit-modal{background:var(--pr-bg-card);border:1px solid var(--pr-border-md);border-radius:18px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:min(620px,100%)}.pr-edit-modal-hdr{align-items:center;border-bottom:1px solid var(--pr-border);display:flex;flex-shrink:0;justify-content:space-between;padding:16px 22px}.pr-edit-modal-title{color:var(--pr-text-1);font-size:14px;font-weight:800}.pr-edit-modal-body{flex:1 1;overflow-y:auto;padding:20px 22px}.pr-edit-modal-footer{border-top:1px solid var(--pr-border);display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;padding:14px 22px}.pr-edit-section-title{color:var(--pr-blue);font-size:10px;font-weight:700;letter-spacing:1px;margin-bottom:10px;margin-top:16px;text-transform:uppercase}.pr-edit-section-title:first-child{margin-top:0}.pr-empty{align-items:center;color:var(--pr-text-5);display:flex;flex-direction:column;gap:10px;justify-content:center;padding:52px 0;text-align:center}.pr-empty-icon{font-size:40px;opacity:.5}.pr-empty-title{color:var(--pr-text-4);font-size:15px;font-weight:700}.pr-empty-sub{color:var(--pr-text-5);font-size:11px}.pr-divider{border:none;border-top:1px solid var(--pr-border);margin:16px 0}.pr-loading{color:var(--pr-text-4);font-size:12px;padding:32px 0;text-align:center}.pr-monospace{font-family:Courier New,monospace}.pr-chip{align-items:center;background:var(--pr-blue-bg);border:1px solid var(--pr-blue-bdr);border-radius:5px;color:var(--pr-blue-lt);display:inline-flex;font-size:9px;font-weight:700;gap:4px;letter-spacing:.5px;padding:2px 8px}.pr-overview-grid{grid-gap:18px;align-items:start;display:grid;gap:18px;grid-template-columns:1fr 340px}.pr-overview-grid>*{min-width:0}.pr-icon-btn{align-items:center;background:#0000;border:1px solid var(--pr-border-md);border-radius:6px;color:var(--pr-text-3);cursor:pointer;display:inline-flex;font-size:13px;height:28px;justify-content:center;padding:0;transition:all .15s;width:28px}.pr-icon-btn:hover{background:var(--pr-btn2-bg);color:var(--pr-text-1)}@media (max-width:1200px){.pr-stats-grid{grid-template-columns:repeat(2,1fr)}.pr-config-grid,.pr-overview-grid{grid-template-columns:1fr}.pr-run-stats{grid-template-columns:repeat(3,1fr)}}@media (max-width:900px){.pr-content{padding:16px}.pr-schedule-grid{grid-template-columns:repeat(3,1fr)}.pr-payslip-split{grid-template-columns:1fr}.pr-form-grid-3,.pr-payslip-emp-grid{grid-template-columns:1fr 1fr}}@media (max-width:600px){.pr-stats-grid{grid-template-columns:1fr}.pr-schedule-grid{grid-template-columns:1fr 1fr}.pr-tabs{overflow-x:auto}.pr-tab{font-size:11px;padding:10px 12px}.pr-form-grid-2,.pr-form-grid-3,.pr-payslip-emp-grid{grid-template-columns:1fr}.pr-run-stats{grid-template-columns:1fr 1fr}.pr-header{flex-wrap:wrap;gap:6px;height:auto}.pr-content,.pr-header{padding:10px}.pr-tbl-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}}.prs-root{--prs-bg:#080d18;--prs-bg-2:#0c1222;--prs-bg-card:#ffffff0a;--prs-bg-card-h:#ffffff0f;--prs-border:#ffffff14;--prs-border-md:#ffffff1f;--prs-text-1:#e2e8f0;--prs-text-2:#cbd5e1;--prs-text-3:#94a3b8;--prs-text-4:#64748b;--prs-blue:#2563eb;--prs-blue-bg:#2563eb1f;--prs-green:#059669;--prs-green-bg:#0596691f;--prs-amber:#d97706;--prs-amber-bg:#d977061f;--prs-red:#dc2626;--prs-red-bg:#dc26261f;--prs-purple:#4f46e5;--prs-purple-bg:#4f46e51f;--prs-cyan:#0891b2;--prs-cyan-bg:#0891b21f;--prs-info-blue-border:#2563eb4d;--prs-info-amber-bg:#d9770614;--prs-info-amber-border:#d977062e;--prs-input-bg:#ffffff0d;--prs-shadow:0 2px 12px #0000004d;background:var(--prs-bg);color:var(--prs-text-1);display:flex;flex-direction:column;font-family:Inter,Segoe UI,system-ui,sans-serif;font-size:13px;height:100%;min-height:100%;overflow:hidden}.dashboard-main:has(.prs-root){max-width:100%;overflow:hidden;padding:0}.home-grid:has(.prs-root){gap:0;height:100%}[data-theme=light] .prs-root{--prs-bg:#f0f4f8;--prs-bg-2:#fff;--prs-bg-card:#fff;--prs-bg-card-h:#f8fafc;--prs-border:#e2e8f0;--prs-border-md:#cbd5e1;--prs-text-1:#0f172a;--prs-text-2:#334155;--prs-text-3:#64748b;--prs-text-4:#94a3b8;--prs-blue:#2563eb;--prs-blue-bg:#2563eb1f;--prs-green:#059669;--prs-green-bg:#0596691f;--prs-amber:#d97706;--prs-amber-bg:#d977061f;--prs-red:#dc2626;--prs-red-bg:#dc26261f;--prs-purple:#4f46e5;--prs-purple-bg:#4f46e51f;--prs-cyan:#0891b2;--prs-cyan-bg:#0891b21f;--prs-info-blue-border:#2563eb4d;--prs-info-amber-bg:#d9770614;--prs-info-amber-border:#d9770638;--prs-input-bg:#f1f5f9;--prs-shadow:0 2px 12px #0000000f}.prs-header{background:var(--prs-bg-2);border-bottom:1px solid var(--prs-border);flex-shrink:0;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:18px 28px}.prs-header,.prs-header-left{align-items:center;display:flex}.prs-header-left{gap:14px}.prs-header-logo{align-items:center;background:linear-gradient(135deg,var(--prs-blue-bg),var(--prs-purple-bg));border:1px solid var(--prs-border);border-radius:8px;display:flex;font-size:18px;height:36px;justify-content:center;width:36px}.prs-header-title{color:var(--prs-text-1);font-size:18px;font-weight:900;letter-spacing:-.3px}.prs-header-sub{color:var(--prs-text-4);font-size:11px;margin-top:1px}.prs-search-wrap{flex:0 1 360px;min-width:200px;position:relative}.prs-search{background:var(--prs-input-bg);border:1px solid var(--prs-border-md);border-radius:24px;color:var(--prs-text-1);font-size:13px;outline:none;padding:9px 14px 9px 36px;transition:border-color .2s,box-shadow .2s;width:100%}.prs-search:focus{border-color:var(--prs-blue);box-shadow:0 0 0 3px #0ea5e91f}.prs-search::placeholder{color:var(--prs-text-4)}.prs-search-icon{font-size:14px;left:12px}.prs-search-icon,.prs-search-shortcut{color:var(--prs-text-4);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.prs-search-shortcut{background:var(--prs-bg-card);border:1px solid var(--prs-border);border-radius:4px;font-size:10px;padding:1px 5px;right:14px}.prs-close-btn{align-items:center;background:var(--prs-bg-card);border:1px solid var(--prs-border-md);border-radius:8px;color:var(--prs-text-2);cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:6px;padding:7px 16px;transition:background .15s,border-color .15s}.prs-close-btn:hover{background:var(--prs-bg-card-h);border-color:var(--prs-red);color:var(--prs-red)}.prs-close-x{color:var(--prs-red);font-size:14px;font-weight:700}.prs-grid{display:flex;flex-wrap:wrap;gap:20px;padding:0 0 28px}.prs-category{background:var(--prs-bg-card);border:1px solid var(--prs-border);border-radius:14px;flex:1 1 180px;max-width:280px;min-width:180px;overflow:hidden;transition:border-color .2s,box-shadow .2s}.prs-category:hover{border-color:var(--prs-border-md);box-shadow:var(--prs-shadow)}.prs-cat-hdr{border-bottom:1px solid var(--prs-border);gap:10px;padding:18px 20px 14px}.prs-cat-hdr,.prs-cat-icon{align-items:center;display:flex}.prs-cat-icon{border-radius:8px;flex-shrink:0;font-size:15px;height:32px;justify-content:center;width:32px}.prs-cat-title{color:var(--prs-text-1);font-size:14px;font-weight:800;letter-spacing:-.2px}.prs-cat-links{display:flex;flex-direction:column;padding:8px 0}.prs-link{align-items:center;background:none;border:none;color:var(--prs-text-2);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px;padding:10px 20px;text-align:left;transition:background .15s,color .15s;width:100%}.prs-link:hover{background:var(--prs-bg-card-h);color:var(--prs-blue)}.prs-link-icon{flex-shrink:0;font-size:14px;opacity:0;text-align:center;transition:opacity .15s;width:20px}.prs-link:hover .prs-link-icon{opacity:1}.prs-link-text{flex:1 1}.prs-link-arrow{color:var(--prs-text-4);font-size:10px;opacity:0;transition:opacity .15s,transform .15s}.prs-link:hover .prs-link-arrow{opacity:1;transform:translateX(2px)}.prs-link-badge{background:var(--prs-green-bg);border-radius:4px;color:var(--prs-green);font-size:9px;font-weight:700;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.prs-detail{flex:1 1;flex-direction:column;min-height:0;min-width:0;overflow:hidden}.prs-detail,.prs-detail-bar{background:var(--prs-bg-2);display:flex}.prs-detail-bar{align-items:center;border-bottom:1px solid var(--prs-border);flex-shrink:0;gap:10px;padding:14px 28px}.prs-back-btn{align-items:center;background:var(--prs-bg-card);border:1px solid var(--prs-border);border-radius:8px;color:var(--prs-text-2);cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:6px;padding:6px 12px;transition:background .15s}.prs-back-btn:hover{background:var(--prs-bg-card-h);color:var(--prs-blue)}.prs-detail-title{color:var(--prs-text-1);font-size:15px;font-weight:800}.prs-detail-icon{font-size:16px}.prs-detail-body{flex:1 1;min-height:0;overflow-y:auto;padding:16px 28px 60px}.prs-layout{display:grid;flex:1 1;grid-template-columns:280px 1fr;grid-template-rows:minmax(0,1fr);min-height:0;overflow:hidden}.prs-layout--no-nav{grid-template-columns:1fr}.prs-sidebar{background:var(--prs-bg-2);border-right:1px solid var(--prs-border);min-height:0;overflow-y:auto}.prs-sidebar-wrap{padding:12px 0 60px}.prs-side-section{padding:0 0 8px}.prs-side-section-title{color:var(--prs-text-4);font-size:11px;font-weight:800;letter-spacing:.6px;padding:10px 16px;text-transform:uppercase}.prs-side-cat{margin-bottom:2px}.prs-side-cat-btn{align-items:center;background:#0000;border:none;color:var(--prs-text-2);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 14px;text-align:left;width:100%}.prs-side-cat-btn:hover{background:var(--prs-bg-card-h)}.prs-side-cat-chevron{color:var(--prs-text-4);transform:rotate(-90deg);transition:transform .15s ease;width:14px}.prs-side-cat-btn.open .prs-side-cat-chevron{transform:rotate(0deg)}.prs-side-links{display:flex;flex-direction:column;gap:2px;padding:0 8px 6px 26px}.prs-side-link{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--prs-text-2);cursor:pointer;display:flex;font-size:13px;justify-content:space-between;padding:8px 10px;text-align:left}.prs-side-link:hover{background:var(--prs-bg-card-h);color:var(--prs-blue)}.prs-side-link.active{background:var(--prs-blue);color:#fff;font-weight:700}.prs-panel{background:var(--prs-bg-card);border:1px solid var(--prs-border);border-radius:8px;box-shadow:0 1px 3px #0000000a;margin-bottom:16px}.prs-panel-hdr{align-items:center;border-bottom:1px solid var(--prs-border);display:flex;justify-content:space-between;padding:18px 24px 14px}.prs-panel-title{color:var(--prs-text-1);font-size:15px;font-weight:600;letter-spacing:-.1px}.prs-panel-sub{color:var(--prs-text-3);font-size:12px;line-height:1.4;margin-top:3px}.prs-panel-body{gap:16px;padding:20px 24px}.prs-field,.prs-panel-body{display:flex;flex-direction:column}.prs-field{gap:6px}.prs-label{color:var(--prs-text-2);font-size:13px;font-weight:600;letter-spacing:0;text-transform:none}.prs-input{background:var(--prs-input-bg);border:1px solid var(--prs-border-md);border-radius:6px;box-sizing:border-box;color:var(--prs-text-1);font-size:13px;outline:none;padding:9px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.prs-input:focus{border-color:var(--prs-blue);box-shadow:0 0 0 3px #4d9fff1a}.prs-select{background:var(--prs-input-bg);border:1px solid var(--prs-border-md);border-radius:6px;box-sizing:border-box;color:var(--prs-text-1);font-size:13px;outline:none;padding:9px 12px;transition:border-color .15s;width:100%}.prs-select:focus{border-color:var(--prs-blue)}.prs-form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.prs-form-row3{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr}.prs-toggle-row{align-items:center;border-bottom:1px solid var(--prs-border);display:flex;gap:16px;justify-content:space-between;padding:12px 0}.prs-toggle-row:last-child{border-bottom:none}.prs-toggle-info{flex:1 1;min-width:0}.prs-toggle-name{color:var(--prs-text-1);font-size:13px;font-weight:600;line-height:1.4}.prs-toggle-desc{color:var(--prs-text-3);font-size:12px;line-height:1.4;margin-top:3px}.prs-toggle{background:var(--prs-border-md);border-radius:11px;cursor:pointer;flex-shrink:0;height:22px;position:relative;transition:background .2s;width:40px}.prs-toggle--on{background:var(--prs-blue)}.prs-toggle-thumb{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000002e;height:18px;left:2px;position:absolute;top:2px;transition:left .2s;width:18px}.prs-toggle--on .prs-toggle-thumb{left:20px}.prs-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:6px;justify-content:center;line-height:1.4;padding:8px 20px;transition:background .15s,opacity .15s,transform .08s}.prs-btn:active{transform:scale(.98)}.prs-btn--primary{background:var(--prs-blue);color:#fff}.prs-btn--primary:hover{opacity:.9}.prs-btn--green{background:var(--prs-green);color:#fff}.prs-btn--green:hover{opacity:.9}.prs-btn--red{background:#ef4444;background:var(--prs-red,#ef4444);color:#fff}.prs-btn--red:hover{opacity:.9}.prs-btn--danger{background:#ef4444;background:var(--prs-red,#ef4444);color:#fff}.prs-btn--danger:hover{opacity:.9}.prs-btn--xs{border-radius:4px;font-size:11px;padding:3px 8px}.prs-btn--ghost{background:#0000;border:1px solid var(--prs-border-md);color:var(--prs-text-2)}.prs-btn--ghost:hover{background:var(--prs-bg-card-h);color:var(--prs-text-1)}.prs-btn-bar{display:flex;gap:10px;justify-content:flex-end;padding-top:12px}.prs-no-results{color:var(--prs-text-4);padding:60px 20px;text-align:center}.prs-no-results-icon{font-size:40px;margin-bottom:12px;opacity:.4}.prs-no-results-title{color:var(--prs-text-3);font-size:15px;font-weight:700;margin-bottom:4px}.prs-no-results-sub{color:var(--prs-text-4);font-size:12px}@media (max-width:1200px){.prs-category{max-width:260px}}@media (max-width:900px){.prs-grid{gap:14px}.prs-section{padding:20px 20px 0}.prs-header{padding:14px 20px}.prs-form-row,.prs-form-row3{grid-template-columns:1fr}.prs-category{max-width:none}.prs-layout{grid-template-columns:1fr}.prs-sidebar{display:none}.prs-detail-body{padding:20px 16px}}@media (max-width:600px){.prs-category{flex:1 1 100%;max-width:none}}.prs-hub-body{flex:1 1;overflow-y:auto;padding-bottom:60px}.prs-section{padding:28px 28px 0}.prs-section-title{border-bottom:1px solid var(--prs-border);color:var(--prs-text-1);font-size:15px;font-weight:800;letter-spacing:-.2px;margin-bottom:18px;padding-bottom:12px}.prs-section .prs-grid{padding:0 0 28px}.prs-badge{align-items:center;border-radius:4px;display:inline-flex;flex-shrink:0;font-size:10px;font-weight:600;letter-spacing:.3px;padding:3px 8px;text-transform:uppercase}.prs-badge--green{background:var(--prs-green-bg);color:var(--prs-green)}.prs-badge--blue{background:var(--prs-blue-bg);color:var(--prs-blue)}.prs-badge--amber{background:var(--prs-amber-bg);color:var(--prs-amber)}.prs-badge--purple{background:var(--prs-purple-bg);color:var(--prs-purple)}.prs-badge--red{background:var(--prs-red-bg);color:var(--prs-red)}.prs-info-box{align-items:flex-start;background:var(--prs-blue-bg);border:1px solid var(--prs-info-blue-border);border-radius:6px;color:var(--prs-text-2);display:flex;font-size:13px;gap:10px;line-height:1.6;margin-bottom:16px;padding:14px 18px}.prs-info-box:before{align-items:center;background:var(--prs-blue);border-radius:50%;color:#fff;content:"i";display:flex;flex-shrink:0;font-family:Georgia,Times New Roman,serif;font-size:12px;font-style:italic;font-weight:700;height:20px;justify-content:center;margin-top:1px;width:20px}.prs-info-row{background:var(--prs-info-amber-bg);border:1px solid var(--prs-info-amber-border);border-radius:6px;color:var(--prs-text-3);display:flex;font-size:11px;gap:8px;line-height:1.5;margin-top:12px;padding:10px 14px}.prs-formula-box{background:var(--prs-bg);border:1px solid var(--prs-border-md);border-radius:8px;margin-top:8px;padding:14px 16px}.prs-formula-title{color:var(--prs-text-4);font-size:10px;font-weight:700;letter-spacing:.8px;margin-bottom:8px;text-transform:uppercase}.prs-formula{color:var(--prs-blue);font-family:monospace;font-size:12px;font-weight:600}.prs-formula-note{color:var(--prs-text-4);font-size:10px;margin-top:6px}.prs-pt-slabs{border:1px solid var(--prs-border);border-radius:8px;margin-top:12px;overflow:hidden}.prs-pt-slabs-title{background:var(--prs-bg);border-bottom:1px solid var(--prs-border);color:var(--prs-text-3);font-size:11px;font-weight:700;padding:10px 14px}.prs-slab-table{border-collapse:collapse;font-size:11px;width:100%}.prs-slab-table th{background:var(--prs-bg-card-h);color:var(--prs-text-3);font-weight:700;letter-spacing:.4px;padding:8px 14px;text-align:left}.prs-slab-table td{border-top:1px solid var(--prs-border);color:var(--prs-text-2);padding:8px 14px}.prs-preview-box{align-items:center;background:var(--prs-bg);border:1px dashed var(--prs-border-md);border-radius:6px;display:flex;font-size:12px;gap:8px;margin-top:8px;padding:8px 12px}.prs-preview-label{color:var(--prs-text-4);font-weight:600}.prs-preview-value{color:var(--prs-blue);font-family:monospace;font-weight:800}.prs-hint{color:var(--prs-text-3);font-size:11px;line-height:1.4;margin-top:3px}.prs-detail-breadcrumb,.prs-detail-sep{color:var(--prs-text-4);font-size:11px}.prs-detail-sep{margin:0 2px}.prs-zoho-toolbar{align-items:center;border-bottom:1px solid var(--prs-border);display:flex;justify-content:space-between;margin-bottom:16px;padding:0 0 16px}.prs-zoho-toolbar-left{align-items:center;display:flex;gap:8px}.prs-zoho-table{border-collapse:collapse;font-size:13px;width:100%}.prs-zoho-table thead th{border-bottom:2px solid var(--prs-border);color:var(--prs-text-4);font-size:11px;font-weight:700;letter-spacing:.5px;padding:6px 14px;text-align:left;text-transform:uppercase}.prs-zoho-table tbody tr{border-bottom:1px solid var(--prs-border);transition:background .1s}.prs-zoho-table tbody tr:hover{background:var(--prs-bg-card-h)}.prs-zoho-table tbody td{padding:4px 14px;vertical-align:middle}.prs-zoho-user-cell{align-items:center;display:flex;gap:10px}.prs-zoho-avatar{align-items:center;background:var(--prs-blue);color:#fff;display:flex;font-size:12px;font-weight:700;justify-content:center}.prs-zoho-avatar,.prs-zoho-avatar-img{border-radius:50%;flex-shrink:0;height:28px;width:28px}.prs-zoho-avatar-img{object-fit:cover}.prs-zoho-user-name{color:var(--prs-text-1);font-size:13px;font-weight:600}.prs-zoho-user-email{color:var(--prs-text-3);font-size:11px}.prs-zoho-more-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--prs-text-3);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:14px;justify-content:center;padding:4px 6px;transition:background .15s}.prs-zoho-more-btn:hover{background:var(--prs-bg-card-h);color:var(--prs-blue)}.prs-zoho-page-title{color:var(--prs-text-1);font-size:18px;font-weight:700;margin-bottom:20px}.prs-zoho-form-card{background:var(--prs-bg-card);border:1px solid var(--prs-border);border-radius:10px;max-width:720px;padding:24px}.prs-zoho-modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.prs-zoho-modal{background:var(--prs-bg-card);border:1px solid var(--prs-border);border-radius:12px;box-shadow:0 16px 48px #00000040;max-width:520px;min-width:400px;padding:28px}.prs-zoho-modal-title{color:var(--prs-text-1);font-size:17px;font-weight:700;margin-bottom:20px}.prs-zoho-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 24px;text-align:center}.prs-zoho-empty-icon{font-size:56px;margin-bottom:16px;opacity:.6}.prs-zoho-empty-title{color:var(--prs-text-1);font-size:17px;font-weight:700;margin-bottom:8px}.prs-zoho-empty-sub{color:var(--prs-text-3);font-size:13px;line-height:1.5;margin-bottom:20px;max-width:420px}.prs-zoho-empty-actions{display:flex;gap:10px}.prs-zoho-perm-section{margin-top:20px}.prs-zoho-perm-title{color:var(--prs-text-1);font-size:14px;font-weight:700;margin-bottom:12px}.prs-zoho-perm-cat{border:1px solid var(--prs-border);border-radius:8px;margin-bottom:8px;overflow:hidden}.prs-zoho-perm-cat-btn{align-items:center;background:var(--prs-bg-2);border:none;color:var(--prs-text-2);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 14px;text-align:left;transition:background .15s;width:100%}.prs-zoho-perm-cat-btn:hover{background:var(--prs-bg-card-h)}.prs-zoho-perm-cat-btn .prs-side-cat-chevron{transform:rotate(-90deg);transition:transform .15s}.prs-zoho-perm-cat-btn.open .prs-side-cat-chevron{transform:rotate(0deg)}.prs-zoho-perm-grid{background:var(--prs-bg-card);border-top:1px solid var(--prs-border);display:flex;flex-wrap:wrap;gap:10px;padding:14px 16px}.prs-zoho-perm-check{align-items:center;color:var(--prs-text-2);cursor:pointer;display:flex;font-size:12px;gap:6px;padding:4px 0}.prs-zoho-perm-check input[type=checkbox]{accent-color:var(--prs-blue);cursor:pointer;height:16px;width:16px}.prs-zoho-cards{display:flex;flex-wrap:wrap;gap:16px}.prs-zoho-loc-card{background:var(--prs-bg-card);border:1px solid var(--prs-border);border-radius:10px;flex:1 1 280px;max-width:360px;padding:18px 20px}.prs-zoho-loc-card-hdr{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:6px}.prs-zoho-loc-name{color:var(--prs-text-1);font-size:15px;font-weight:700}.prs-zoho-loc-actions{display:flex;gap:4px}.prs-zoho-loc-addr{color:var(--prs-text-3);font-size:12px;line-height:1.4;margin-bottom:4px}.prs-zoho-loc-meta{color:var(--prs-text-4);font-size:12px}.prs-zoho-appearance-row{display:flex;flex-wrap:wrap;gap:20px}.prs-zoho-theme-card{border:2px solid var(--prs-border);border-radius:10px;cursor:pointer;flex:1 1 200px;max-width:260px;padding:10px;transition:border-color .15s}.prs-zoho-theme-card.selected,.prs-zoho-theme-card:hover{border-color:var(--prs-blue)}.prs-zoho-theme-preview{border-radius:6px;display:flex;height:80px;margin-bottom:8px;overflow:hidden}.prs-zoho-theme-preview.dark .prs-zoho-theme-sidebar{background:#1a1a2e;width:60px}.prs-zoho-theme-preview.dark .prs-zoho-theme-content{background:#262640;flex:1 1;padding:12px}.prs-zoho-theme-preview.light .prs-zoho-theme-sidebar{background:#f0f2f5;width:60px}.prs-zoho-theme-preview.light .prs-zoho-theme-content{background:#fff;border-left:1px solid #e0e0e0;flex:1 1;padding:12px}.prs-zoho-theme-line{border-radius:4px;height:8px;margin-bottom:6px}.prs-zoho-theme-preview.dark .prs-zoho-theme-line{background:#3a3a5c}.prs-zoho-theme-preview.light .prs-zoho-theme-line{background:#e0e0e0}.prs-zoho-theme-line.short{width:60%}.prs-zoho-theme-label{color:var(--prs-text-2);font-size:13px;font-weight:600;text-align:center}.prs-zoho-accent-row{display:flex;flex-wrap:wrap;gap:12px}.prs-zoho-accent-swatch{align-items:center;border:3px solid #0000;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:40px;justify-content:center;transition:transform .15s,border-color .15s;width:40px}.prs-zoho-accent-swatch:hover{transform:scale(1.1)}.prs-zoho-accent-swatch.selected{border-color:var(--prs-text-1);box-shadow:0 0 0 2px var(--prs-bg-card)}.prs-zoho-logo-upload{background:var(--prs-bg-2);border:2px dashed var(--prs-border);border-radius:10px;gap:12px;justify-content:center;margin-bottom:16px;min-height:80px;padding:20px}.prs-zoho-logo-placeholder,.prs-zoho-logo-upload{align-items:center;display:flex;flex-direction:column}.prs-zoho-logo-placeholder{color:var(--prs-text-4);font-size:13px;gap:6px}.prs-zoho-logo-placeholder span:first-child{font-size:28px}.prs-zoho-plan-card{align-items:center;display:flex;flex-wrap:wrap;gap:16px;padding:16px 0}.prs-zoho-plan-label{color:var(--prs-text-4);font-size:12px;font-weight:600}.prs-zoho-plan-name{color:var(--prs-text-1);font-size:16px;font-weight:700}.prs-zoho-usage-row{display:flex;flex-wrap:wrap;gap:24px}.prs-zoho-usage-item{display:flex;flex-direction:column;gap:4px}.prs-zoho-usage-label{color:var(--prs-text-4);font-size:12px;font-weight:600}.prs-zoho-usage-value{color:var(--prs-text-1);font-size:15px;font-weight:700}.prs-zoho-feature-title{color:var(--prs-text-4);font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.prs-invite-modal{background:var(--prs-bg-card);border:1px solid var(--prs-border);border-radius:12px;box-shadow:0 16px 48px #0000004d;display:flex;flex-direction:column;max-width:640px;min-width:560px;padding:0;width:100%}.prs-invite-modal--wide{max-width:780px;min-width:640px}.prs-error-msg{background:#fef2f2;background:var(--prs-red-bg,#fef2f2);border-radius:6px;color:#dc2626;color:var(--prs-red,#dc2626);font-size:13px;margin-bottom:12px;padding:10px 14px}.prs-form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:640px){.prs-form-grid{grid-template-columns:1fr}.prs-invite-modal--wide{max-width:95vw;min-width:auto}}.prs-invite-header{align-items:center;border-bottom:1px solid var(--prs-border);display:flex;justify-content:space-between;padding:20px 28px 16px}.prs-invite-title{color:var(--prs-text-1);font-size:18px;font-weight:700}.prs-invite-header-right{align-items:center;display:flex;gap:16px}.prs-invite-preview{align-items:center;color:var(--prs-blue);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:4px}.prs-invite-preview:hover{text-decoration:underline}.prs-invite-close{background:#0000;border:none;border-radius:4px;color:var(--prs-text-3);cursor:pointer;font-size:18px;line-height:1;padding:4px 6px}.prs-invite-close:hover{background:var(--prs-bg-card-h);color:var(--prs-text-1)}.prs-invite-form{display:flex;flex-direction:column;gap:20px;padding:24px 28px}.prs-invite-row{grid-gap:16px;align-items:start;display:grid;gap:16px;grid-template-columns:100px 1fr}.prs-invite-label{color:var(--prs-text-2);font-size:14px;font-weight:600;padding-top:8px;text-align:left}.prs-invite-req{color:#e53935;margin-left:1px}.prs-invite-role-wrap{position:relative;width:100%}.prs-invite-role-trigger{align-items:center;background:var(--prs-bg);border:1px solid var(--prs-border);border-radius:6px;color:var(--prs-text-2);cursor:pointer;display:flex;font-size:14px;justify-content:space-between;padding:8px 12px;text-align:left;transition:border-color .15s;width:100%}.prs-invite-role-trigger.open,.prs-invite-role-trigger:focus{border-color:var(--prs-blue);outline:none}.prs-invite-role-chevron{color:var(--prs-text-4);font-size:10px}.prs-invite-role-dropdown{background:var(--prs-bg-card);border:1px solid var(--prs-border);border-radius:8px;box-shadow:0 8px 24px #0003;left:0;overflow:hidden;position:absolute;right:0;top:calc(100% + 4px);z-index:100}.prs-invite-role-search-wrap{align-items:center;border-bottom:1px solid var(--prs-border);display:flex;gap:6px;padding:8px 10px}.prs-invite-role-search-icon{color:var(--prs-text-4);font-size:14px}.prs-invite-role-search{background:var(--prs-bg);border:1px solid var(--prs-border);border-radius:4px;color:var(--prs-text-1);flex:1 1;font-size:13px;outline:none;padding:6px 8px}.prs-invite-role-search:focus{border-color:var(--prs-blue)}.prs-invite-role-options{max-height:180px;overflow-y:auto}.prs-invite-role-option{background:#0000;border:none;color:var(--prs-text-2);cursor:pointer;font-size:14px;padding:10px 14px;text-align:left;transition:background .1s;width:100%}.prs-invite-role-option:hover{background:var(--prs-bg-card-h)}.prs-invite-role-option.selected{background:var(--prs-blue);color:#fff;font-weight:600}.prs-invite-role-empty{color:var(--prs-text-4);font-size:13px;padding:12px 14px;text-align:center}.prs-invite-footer{align-items:center;border-top:1px solid var(--prs-border);display:flex;gap:10px;padding:16px 28px 20px}.prs-zoho-card-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.prs-zoho-list-card{align-items:center;background:var(--prs-bg-2);border:1px solid var(--prs-border);border-radius:8px;display:flex;justify-content:space-between;padding:14px 16px;transition:border-color .15s}.prs-zoho-list-card:hover{border-color:var(--prs-border-md)}.prs-zoho-list-card-title{align-items:center;color:var(--prs-text-1);display:flex;font-size:14px;font-weight:600;gap:8px}.prs-zoho-list-card-sub{color:var(--prs-text-3);font-size:12px;line-height:1.4;margin-top:3px}.prs-zoho-list-card-url{color:var(--prs-text-3);font-family:monospace;font-size:11px;margin-top:4px}.prs-zoho-list-card-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.prs-zoho-list-card-actions{display:flex;flex-shrink:0;gap:4px}.prs-zoho-list-card-icon-row{align-items:center;display:flex;gap:12px}.prs-zoho-list-card-icon{flex-shrink:0;font-size:24px}.prs-zoho-inline-form{border-top:1px solid var(--prs-border);margin-top:16px;padding-top:16px}.prs-zoho-inline-form-title{color:var(--prs-text-1);font-size:13px;font-weight:600;margin-bottom:12px}.prs-zoho-guide-text{color:var(--prs-text-2);font-size:13px;line-height:1.8}.prs-zoho-guide-text p{margin:0 0 8px}.prs-zoho-guide-text p:last-child{margin-bottom:0}.prs-zoho-var-tags{display:flex;flex-wrap:wrap;gap:8px}.prs-zoho-var-tag{background:var(--prs-bg-2);border:1px solid var(--prs-border);border-radius:4px;color:var(--prs-text-2);font-family:monospace;font-size:12px;padding:4px 10px}.prs-zoho-var-tag--removable{align-items:center;display:flex;font-family:inherit;font-size:13px;font-weight:600;gap:6px}.prs-zoho-tag-remove{background:none;border:none;color:var(--prs-text-3);cursor:pointer;font-size:12px;line-height:1;padding:0}.prs-zoho-tag-remove:hover{color:var(--prs-red)}.prs-zoho-backup-row{align-items:center;display:flex;gap:12px;padding:12px 0}.prs-zoho-backup-date{font-weight:600}.prs-zoho-backup-meta{color:var(--prs-text-3);font-size:12px}.prs-table{border-collapse:collapse;font-size:13px;width:100%}.prs-table th{color:var(--prs-text-3);font-size:11px;font-weight:600;letter-spacing:.04em;text-align:left;text-transform:uppercase;white-space:nowrap}.prs-table td,.prs-table th{border-bottom:1px solid var(--prs-border);padding:8px 10px}.prs-table td{color:var(--prs-text-1);vertical-align:middle}.prs-table tbody tr:last-child td{border-bottom:none}.prs-table tbody tr:hover td{background:rgba(0,0,0,.025);background:var(--prs-hover,rgba(0,0,0,.025))}@media (max-width:480px){.prs-header{align-items:flex-start;flex-direction:column;gap:8px;padding:12px 14px}.prs-section{padding:14px 14px 0}.prs-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.prs-grid{gap:10px}}.ff-root{background:var(--surface-secondary);display:flex;flex-direction:column;font-family:inherit;height:100%;min-height:0;overflow:hidden}.ff-page-hdr{background:var(--surface-primary);border-bottom:1px solid var(--border-default);flex-shrink:0;justify-content:space-between;padding:16px 24px}.ff-page-hdr,.ff-page-hdr-left{align-items:center;display:flex}.ff-page-hdr-left{gap:12px}.ff-page-icon{align-items:center;background:var(--color-primary);border-radius:9px;color:#fff;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.ff-page-title{color:var(--text-primary);font-size:15px;font-weight:700;line-height:1.3}.ff-page-sub{color:var(--text-tertiary);font-size:11px;margin-top:1px}.ff-page-hdr-right{align-items:center;display:flex;gap:8px}.ff-btn{align-items:center;border:1px solid #0000;border-radius:7px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:12px;font-weight:600;gap:6px;padding:7px 14px;transition:opacity .12s,background .12s,box-shadow .12s;white-space:nowrap}.ff-btn:disabled{cursor:not-allowed;opacity:.55}.ff-btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.ff-btn-primary:hover:not(:disabled){box-shadow:0 2px 8px #00897b40;opacity:.88}.ff-btn-ghost{background:#0000;border-color:var(--border-default);color:var(--text-secondary)}.ff-btn-ghost:hover:not(:disabled){background:var(--surface-secondary);color:var(--text-primary)}.ff-btn-sm{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:6px;color:var(--text-secondary);font-size:11px;font-weight:600;padding:5px 10px}.ff-btn-sm:hover:not(:disabled){background:var(--surface-secondary)}.ff-kpi-grid{grid-gap:0;background:var(--surface-primary);border-bottom:1px solid var(--border-default);display:grid;flex-shrink:0;gap:0;grid-template-columns:repeat(5,1fr)}.ff-kpi-card{align-items:center;border-right:1px solid var(--border-default);display:flex;gap:12px;padding:14px 20px;transition:background .12s}.ff-kpi-card:last-child{border-right:none}.ff-kpi-card[style*="cursor: pointer"]:hover{background:var(--surface-secondary)}.ff-kpi-icon{align-items:center;border-radius:9px;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.ff-kpi-body{min-width:0}.ff-kpi-val{color:var(--text-primary);font-size:20px;font-weight:700;line-height:1.2}.ff-kpi-lbl{color:var(--text-tertiary);font-size:10px;font-weight:500;margin-top:1px;white-space:nowrap}.ff-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:9999}.ff-modal{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:14px;box-shadow:0 20px 60px #00000038;display:flex;flex-direction:column;max-height:90vh;max-width:100%;overflow:hidden;width:560px}.ff-modal-hdr{border-bottom:1px solid var(--border-default);flex-shrink:0;justify-content:space-between;padding:18px 20px 14px}.ff-modal-hdr,.ff-modal-title{align-items:center;display:flex}.ff-modal-title{color:var(--text-primary);font-size:14px;font-weight:700;gap:8px}.ff-modal-close{align-items:center;background:#0000;border:none;border-radius:6px;color:var(--text-tertiary);cursor:pointer;display:flex;height:28px;justify-content:center;transition:background .12s,color .12s;width:28px}.ff-modal-close:hover{background:var(--surface-secondary);color:var(--text-primary)}.ff-modal-body{display:flex;flex:1 1;flex-direction:column;gap:20px;overflow-y:auto;padding:20px}.ff-modal-ftr{align-items:center;background:var(--surface-secondary);border-top:1px solid var(--border-default);display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;padding:14px 20px}.ff-form-section{display:flex;flex-direction:column;gap:12px}.ff-form-section-title{border-bottom:1px solid var(--border-default);color:var(--text-tertiary);font-size:11px;font-weight:700;letter-spacing:.06em;padding-bottom:6px;text-transform:uppercase}.ff-form-grid{grid-gap:12px;display:grid;gap:12px}.ff-form-grid-1{grid-template-columns:1fr}.ff-form-grid-2{grid-template-columns:1fr 1fr}.ff-field{display:flex;flex-direction:column;gap:5px}.ff-field-full{grid-column:1/-1}.ff-label{color:var(--text-secondary);font-size:11px;font-weight:600}.ff-req{color:#dc2626;margin-left:2px}.ff-input{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:7px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:12px;height:34px;padding:0 10px;transition:border-color .12s,box-shadow .12s;width:100%}.ff-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #00897b1f;outline:none}.ff-input-sm{font-size:11px;height:30px}.ff-input-wrap{align-items:center;display:flex;position:relative}.ff-input-prefix{color:var(--text-tertiary);font-size:12px;font-weight:600;left:10px;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none}.ff-input-prefixed{padding-left:22px}.ff-workspace{flex:1 1;min-height:0}.ff-list-pane,.ff-workspace{display:flex;overflow:hidden}.ff-list-pane{background:var(--surface-primary);flex:1 1;flex-direction:column;min-width:0;transition:flex .2s ease}.ff-list-pane--narrow{border-right:1px solid var(--border-default);flex:0 0 52%;min-width:400px}.ff-toolbar{background:var(--surface-primary);border-bottom:1px solid var(--border-default);flex-wrap:wrap;gap:12px;padding:12px 16px}.ff-search-wrap,.ff-toolbar{align-items:center;display:flex;flex-shrink:0}.ff-search-wrap{position:relative}.ff-search-icon{color:var(--text-tertiary);left:9px;pointer-events:none;position:absolute}.ff-search{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:7px;color:var(--text-primary);font-family:inherit;font-size:12px;height:32px;padding:0 28px 0 30px;transition:border-color .12s,box-shadow .12s,width .2s;width:200px}.ff-search:focus{background:var(--surface-primary);border-color:var(--color-primary);box-shadow:0 0 0 3px #00897b1f;outline:none;width:240px}.ff-search-clear{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-tertiary);cursor:pointer;display:flex;justify-content:center;padding:2px;position:absolute;right:8px}.ff-search-clear:hover{background:var(--border-default);color:var(--text-primary)}.ff-status-chips{display:flex;flex-wrap:wrap}.ff-chip,.ff-status-chips{align-items:center;gap:4px}.ff-chip{background:#0000;border:1px solid var(--border-default);border-radius:20px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:11px;font-weight:500;padding:4px 10px;transition:background .12s,color .12s,border-color .12s}.ff-chip:hover:not(.ff-chip--active){background:var(--surface-secondary);color:var(--text-primary)}.ff-chip--active{font-weight:700}.ff-chip-count{background:#00000014;border-radius:8px;display:inline-flex;font-size:10px;font-weight:700;height:16px;min-width:16px;padding:0 4px}.ff-chip-count,.ff-loader{align-items:center;justify-content:center}.ff-loader{color:var(--text-tertiary);font-size:13px;padding:40px}.ff-empty,.ff-loader{display:flex;flex:1 1}.ff-empty{align-items:center;flex-direction:column;gap:4px;justify-content:center;padding:48px 24px;text-align:center}.ff-empty-title{color:var(--text-secondary);font-size:13px;font-weight:600}.ff-empty-sub{color:var(--text-tertiary);font-size:12px;margin-top:2px}.ff-table-wrap{flex:1 1;min-height:0;overflow:auto}.ff-table{border-collapse:collapse;font-size:12px;width:100%}.ff-th{background:var(--surface-secondary);border-bottom:1px solid var(--border-default);color:var(--text-tertiary);font-size:10px;font-weight:700;letter-spacing:.05em;padding:9px 12px;position:sticky;text-align:left;text-transform:uppercase;top:0;white-space:nowrap;z-index:1}.ff-th-r{text-align:right}.ff-th-c{text-align:center}.ff-tr{border-bottom:1px solid var(--border-default);cursor:pointer;transition:background .1s}.ff-tr:hover{background:var(--surface-secondary)}.ff-tr--active{background:#00897b0f!important}.ff-td{color:var(--text-primary);padding:10px 12px;vertical-align:middle}.ff-td-dept,.ff-td-mono{color:var(--text-secondary);font-size:11px}.ff-td-amount,.ff-td-mono{font-family:monospace;font-family:var(--font-mono,monospace)}.ff-td-amount{font-size:12px;font-weight:600;text-align:right}.ff-td-muted{color:var(--text-tertiary);font-family:inherit;font-size:11px;font-style:italic;font-weight:400}.ff-td-actions{text-align:center}.ff-emp-cell{align-items:center;display:flex;gap:8px}.ff-emp-name{color:var(--text-primary);font-size:12px;font-weight:600;line-height:1.3}.ff-emp-code{color:var(--text-tertiary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:10px}.ff-avatar{flex-shrink:0}.ff-status-badge{border:1px solid;border-radius:12px;display:inline-block;font-size:10px;font-weight:700;padding:3px 9px;white-space:nowrap}.ff-row-acts{gap:2px}.ff-act-btn,.ff-row-acts{align-items:center;display:flex;justify-content:center}.ff-act-btn{background:#0000;border:none;border-radius:5px;color:var(--text-tertiary);cursor:pointer;height:26px;transition:background .1s,color .1s;width:26px}.ff-act-btn:hover{background:var(--surface-secondary);color:var(--text-primary)}.ff-detail-pane{background:var(--surface-primary);border-left:1px solid var(--border-default);display:flex;flex:0 0 48%;flex-direction:column;max-width:520px;min-width:360px;overflow-y:auto}.ff-det-hdr{border-bottom:1px solid var(--border-default);flex-shrink:0;justify-content:space-between;padding:16px 18px 12px}.ff-det-hdr,.ff-det-hdr-left{align-items:center;display:flex}.ff-det-hdr-left{gap:10px;min-width:0}.ff-det-avatar{flex-shrink:0}.ff-det-name{color:var(--text-primary);font-size:14px;font-weight:700;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ff-det-meta{color:var(--text-tertiary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:11px;margin-top:1px}.ff-det-close{align-items:center;background:#0000;border:none;border-radius:6px;color:var(--text-tertiary);cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;transition:background .1s,color .1s;width:28px}.ff-det-close:hover{background:var(--surface-secondary);color:var(--text-primary)}.ff-pipeline{align-items:flex-start;border-bottom:1px solid var(--border-default);display:flex;flex-shrink:0;gap:0;padding:16px 18px}.ff-pipe-step{flex-direction:column;flex-shrink:0;gap:5px}.ff-pipe-dot,.ff-pipe-step{align-items:center;display:flex}.ff-pipe-dot{background:var(--surface-secondary);border:2px solid var(--border-default);border-radius:50%;height:20px;justify-content:center;transition:background .15s,border-color .15s;width:20px}.ff-pipe-step.current .ff-pipe-dot,.ff-pipe-step.done .ff-pipe-dot{border-color:inherit}.ff-pipe-label{color:var(--text-tertiary);font-size:10px;font-weight:500;transition:color .15s;white-space:nowrap}.ff-pipe-step.done .ff-pipe-label{color:var(--text-secondary)}.ff-pipe-line{background:var(--border-default);flex:1 1;height:2px;margin:9px 2px 0;min-width:20px;transition:background .15s}.ff-pipe-line.done{background:#059669}.ff-cancelled-banner{background:#fef2f2;border-bottom:1px solid #fecaca;color:#dc2626;font-size:12px;font-weight:600;gap:7px;padding:10px 18px}.ff-cancelled-banner,.ff-det-dates{align-items:center;display:flex;flex-shrink:0}.ff-det-dates{border-bottom:1px solid var(--border-default);gap:16px;padding:12px 18px}.ff-det-date-item{display:flex;flex-direction:column;gap:2px}.ff-det-date-lbl{color:var(--text-tertiary);font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.ff-det-date-val{color:var(--text-primary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:12px;font-weight:600}.ff-det-date-sep{background:var(--border-default);flex-shrink:0;height:28px;width:1px}.ff-breakdown{flex:1 1;gap:10px;overflow-y:auto;padding:16px 18px}.ff-breakdown,.ff-breakdown-col{display:flex;flex-direction:column}.ff-breakdown-col{border:1px solid var(--border-default);border-radius:9px;gap:1px;overflow:hidden}.ff-breakdown-hdr{font-size:10px;font-weight:700;letter-spacing:.06em;padding:8px 12px;text-transform:uppercase}.ff-breakdown-hdr--earn{background:#f0fdf4;border-bottom:1px solid #bbf7d0;color:#059669}.ff-breakdown-hdr--deduct{background:#fef2f2;border-bottom:1px solid #fecaca;color:#dc2626}.ff-row{align-items:center;background:var(--surface-primary);display:flex;justify-content:space-between;padding:7px 12px}.ff-row:nth-child(2n){background:var(--surface-secondary)}.ff-row-lbl{color:var(--text-secondary);font-size:11px}.ff-row-val{font-weight:600}.ff-row-total,.ff-row-val{color:var(--text-primary);font-family:monospace;font-family:var(--font-mono,monospace);font-size:11px}.ff-row-total{align-items:center;background:var(--surface-secondary);border-top:1px solid var(--border-default);display:flex;font-weight:700;justify-content:space-between;padding:8px 12px}.ff-net-box{background:linear-gradient(135deg,#00897b12,#00897b08);border:1.5px solid #00897b40;border-radius:10px;flex-shrink:0;padding:14px 16px;text-align:center}.ff-net-lbl{font-size:10px;font-weight:700;letter-spacing:.07em;margin-bottom:4px;text-transform:uppercase}.ff-net-lbl,.ff-net-val{color:var(--color-primary)}.ff-net-val{font-family:monospace;font-family:var(--font-mono,monospace);font-size:22px;font-weight:800;line-height:1.2}.ff-net-note{color:var(--text-secondary);font-size:11px;font-style:italic;margin-top:6px}.ff-det-actions{align-items:center;background:var(--surface-secondary);border-top:1px solid var(--border-default);display:flex;flex-shrink:0;flex-wrap:wrap;gap:6px;padding:12px 18px}.ff-edit-form{flex:1 1;overflow-y:auto;padding:16px 18px}.ff-edit-section-title{border-bottom:1px solid var(--border-default);color:var(--text-tertiary);font-size:10px;font-weight:700;letter-spacing:.06em;margin-bottom:10px;padding-bottom:6px;text-transform:uppercase}.ff-edit-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.ff-edit-actions{align-items:center;border-top:1px solid var(--border-default);display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:14px}.ff-kpi-card--alert{position:relative}.ff-kpi-badge{animation:ff-pulse 2s ease-in-out infinite;background:#ea580c;border-radius:8px;color:#fff;font-size:9px;font-weight:700;letter-spacing:.04em;padding:2px 6px;position:absolute;right:10px;text-transform:uppercase;top:8px}@keyframes ff-pulse{0%,to{opacity:1}50%{opacity:.6}}.ff-tab-bar{align-items:center;background:var(--surface-primary);border-bottom:1px solid var(--border-default);display:flex;flex-shrink:0;gap:2px;padding:0 16px}.ff-tab{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:12px;font-weight:500;gap:6px;height:40px;margin-bottom:-1px;padding:0 14px;transition:color .12s,background .12s;white-space:nowrap}.ff-tab:hover:not(.ff-tab--active){background:var(--surface-secondary);color:var(--text-primary)}.ff-tab--active{border-bottom-color:var(--color-primary);color:var(--color-primary);font-weight:700}.ff-tab-count{align-items:center;background:#ea580c;border-radius:9px;color:#fff;display:inline-flex;font-size:10px;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 5px}.ff-tab-count--neutral{background:var(--surface-secondary);border:1px solid var(--border-default);color:var(--text-tertiary)}.ff-tr--exit:hover{background:#fff7ed}.ff-days-badge{border-radius:10px;display:inline-block;font-family:monospace;font-family:var(--font-mono,monospace);font-size:11px;font-weight:700;padding:2px 8px}.ff-days-badge--low{background:#ecfdf5;border:1px solid #a7f3d0;color:#059669}.ff-days-badge--medium{background:#fffbeb;border:1px solid #fde68a;color:#d97706}.ff-days-badge--high{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.ff-btn-initiate{background:#fff7ed;border-color:#fed7aa;color:#ea580c;white-space:nowrap}.ff-btn-initiate:hover:not(:disabled){background:#ea580c;border-color:#ea580c;color:#fff}@media (max-width:900px){.ff-kpi-grid{grid-template-columns:repeat(3,1fr)}.ff-list-pane--narrow{border-right:none;flex:0 0 100%;min-width:0;min-width:auto}.ff-detail-pane{display:none}.ff-workspace{flex-direction:column}}.em-page{--em-teal:var(--color-green-600);--em-teal2:var(--color-green);--em-blue:var(--color-primary);--em-indigo:var(--color-indigo);--em-amber:var(--color-orange);--em-red:var(--color-red);--em-green:var(--color-green-600);--em-purple:var(--color-accent);--em-bg:var(--surface-primary,#f8fafc);--em-card:var(--surface-card,#fff);--em-border:var(--border-default,#e2e8f0);--em-surface:var(--surface-secondary,#f1f5f9);--em-t1:var(--text-primary,#0f172a);--em-t2:var(--text-secondary,#475569);--em-t3:var(--text-muted,#94a3b8);--em-r:10px;--em-r2:16px;--em-font:var(--font-sans,"Instrument Sans",sans-serif);--em-mono:var(--font-mono,"JetBrains Mono",monospace);display:flex;flex-direction:column;font-family:var(--em-font);gap:12px;padding:2px 0}.em-page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.em-tab-bar{border-bottom:2px solid var(--em-border);display:flex;gap:4px;margin-bottom:20px}.em-tab-btn{background:#0000;border:none;border-bottom:3px solid #0000;border-radius:var(--radius-md) var(--radius-md) 0 0;color:var(--em-t2);cursor:pointer;font-size:var(--text-sm);font-weight:600;margin-bottom:-2px;padding:9px 20px;transition:color .15s,border-color .15s,background .15s}.em-tab-btn-active,.em-tab-btn:hover{background:var(--em-surface);color:var(--em-blue)}.em-tab-btn-active{border-bottom-color:var(--em-blue)}.em-page-section-label{color:var(--em-teal);font-size:var(--text-2xs);font-weight:700;letter-spacing:1.2px;margin-bottom:2px;text-transform:uppercase}.em-page-title{color:var(--em-t1);font-size:var(--text-xl);font-weight:700}.em-page-subtitle{color:var(--em-t3);font-size:var(--text-sm);margin-top:2px}.em-status-badge{align-items:center;border-radius:var(--radius-3xl);display:flex;font-size:var(--text-sm);font-weight:700;gap:6px;padding:5px 14px}.em-status-ready{background:var(--color-green-50);border:1px solid var(--color-green-100);color:var(--em-green)}.em-status-error{background:var(--color-red-50);border:1px solid var(--color-red-light);color:var(--em-red)}.em-status-unconfigured{background:var(--color-orange-50);border:1px solid var(--color-orange);color:var(--em-amber)}.em-status-dot{border-radius:50%;display:inline-block;flex-shrink:0;height:7px;width:7px}.em-tabs{border-bottom:1px solid var(--em-border);display:flex;gap:0;margin-bottom:4px}.em-tab{border-bottom:2px solid #0000;color:var(--em-t3);cursor:pointer;font-size:var(--text-xs);font-weight:600;padding:8px 16px;transition:color .15s,border-color .15s;-webkit-user-select:none;user-select:none}.em-tab:hover{color:var(--em-t2)}.em-tab.active{border-bottom-color:var(--em-teal);color:var(--em-teal)}.em-card{background:var(--em-card);border:1px solid var(--em-border);border-radius:var(--em-r2)}.em-card-header{border-bottom:1px solid var(--em-border);flex-wrap:wrap;justify-content:space-between;padding:11px 15px}.em-card-header,.em-card-title{align-items:center;display:flex;gap:8px}.em-card-title{color:var(--em-t1);font-size:var(--text-sm);font-weight:600}.em-card-body{padding:13px 15px}.em-card-footer{background:var(--em-surface);border-radius:0 0 var(--em-r2) var(--em-r2);border-top:1px solid var(--em-border);padding:9px 15px}.em-config-footer{align-items:center;color:var(--em-t3);display:flex;flex-wrap:wrap;font-family:var(--em-mono);font-size:var(--text-2xs);gap:18px}.em-footer-right{margin-left:auto}.em-info-banner{align-items:center;background:var(--color-primary-50);border:1px solid var(--color-primary-200);border-radius:var(--em-r);color:var(--em-blue);display:flex;font-size:var(--text-sm);gap:7px;margin-bottom:16px;padding:9px 13px}.em-form-grid{grid-gap:20px 24px;display:grid;gap:20px 24px;grid-template-columns:1fr 1fr}.em-form-group{display:flex;flex-direction:column;gap:4px}.em-label{color:var(--em-t2);font-weight:600}.em-input,.em-label{font-size:var(--text-sm)}.em-input{background:var(--em-card);border:1.5px solid var(--em-border);border-radius:var(--em-r);color:var(--em-t1);font-family:var(--em-font);outline:none;padding:10px 13px;transition:border-color .2s,box-shadow .2s;width:100%}.em-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.em-input::placeholder{color:var(--em-t3)}select.em-input{cursor:pointer}.em-textarea{min-height:140px;resize:vertical}.em-input-wrapper{position:relative}.em-pass-toggle{color:var(--em-t3);cursor:pointer;font-size:var(--text-sm);position:absolute;right:10px;top:50%;transform:translateY(-50%);-webkit-user-select:none;user-select:none}.em-hint{color:var(--em-t3);font-size:var(--text-2xs);margin-top:3px}.em-link{color:var(--em-teal);cursor:pointer;font-weight:600}.em-link:hover{opacity:.7}.em-form-actions{align-items:center;border-top:1px solid var(--em-border);display:flex;justify-content:space-between;margin-top:18px;padding-top:14px}.em-btn{align-items:center;border:1px solid;border-radius:var(--em-r);cursor:pointer;display:inline-flex;font-family:var(--em-font);font-size:var(--text-sm);font-weight:600;gap:5px;padding:7px 13px;text-decoration:none;transition:all .15s;white-space:nowrap}.em-btn:hover{transform:translateY(-1px)}.em-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.em-btn-primary{background:var(--em-blue);border-color:var(--em-blue);box-shadow:0 1px 3px #2563eb4d;color:var(--text-inverse)}.em-btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.em-btn-outline{background:#0000;border-color:var(--color-primary-200);color:var(--em-blue)}.em-btn-outline:hover:not(:disabled){background:var(--color-primary-50)}.em-btn-ghost{background:var(--em-surface);border-color:var(--em-border);color:var(--em-t2)}.em-btn-ghost:hover:not(:disabled){border-color:var(--border-strong);color:var(--em-t1)}.em-btn-sm{font-size:var(--text-2xs);padding:4px 10px}.em-kpi-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.em-kpi{background:var(--em-card);border:1px solid var(--em-border);border-radius:var(--em-r2);overflow:hidden;padding:8px 10px;position:relative}.em-kpi-top-bar{border-radius:var(--em-r2) var(--em-r2) 0 0;height:2px;left:0;position:absolute;right:0;top:0}.em-kpi-label{color:var(--em-t3);font-size:9px;font-weight:700;letter-spacing:.5px;margin-bottom:2px;text-transform:uppercase}.em-kpi-value{color:var(--em-t1);font-family:var(--em-mono);font-size:20px;font-weight:700}.em-kpi-sub{color:var(--em-t3);font-size:var(--text-2xs)}.em-two-col{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.em-tbar-row{align-items:center;display:flex;gap:10px}.em-tbar-label{color:var(--em-t2);flex:1 1;font-size:var(--text-xs);white-space:nowrap}.em-tbar-track{background:var(--em-border);border-radius:3px;flex:2 1;height:5px;overflow:hidden}.em-tbar-fill{border-radius:3px;height:100%;transition:width .6s ease}.em-tbar-stat{color:var(--em-t3);font-family:var(--em-mono);font-size:var(--text-sm);min-width:55px;text-align:right}.em-delivery-donut-row{align-items:center;display:flex;gap:18px;margin-bottom:14px}.em-delivery-donut-wrap{flex-shrink:0;height:100px;position:relative;width:100px}.em-delivery-donut-wrap svg{transform:rotate(-90deg)}.em-delivery-donut-center{align-items:center;display:flex;flex-direction:column;inset:0;justify-content:center;position:absolute}.em-delivery-donut-pct{color:var(--em-t1);font-family:var(--em-mono);font-size:var(--text-xl);font-weight:700;line-height:1}.em-delivery-donut-label{color:var(--em-t3);font-size:var(--text-2xs);margin-top:1px}.em-delivery-legend{display:flex;flex-direction:column;gap:8px}.em-delivery-legend-item{align-items:center;color:var(--em-t2);display:flex;font-size:var(--text-xs);gap:6px;white-space:nowrap}.em-delivery-legend-dot{border-radius:3px;border-radius:var(--em-r-sm,3px);flex-shrink:0;height:8px;width:8px}.em-latest-label{color:var(--em-t2);font-size:var(--text-sm);font-weight:700;margin-bottom:8px}.em-latest-item{align-items:center;background:var(--em-surface);border:1px solid var(--em-border);border-radius:var(--em-r);display:flex;justify-content:space-between;padding:8px 10px}.em-latest-left{align-items:center;display:flex;gap:7px}.em-latest-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.em-latest-name{color:var(--em-t1);font-size:var(--text-xs);font-weight:600}.em-latest-time{color:var(--em-t3);font-family:var(--em-mono);font-size:var(--text-2xs)}.em-log-controls{align-items:center;display:flex;flex-wrap:wrap;gap:7px}.em-search-input{font-size:var(--text-sm);padding:5px 10px;width:200px}.em-filter-btns{display:flex;gap:4px}.em-log-footer{border-top:1px solid var(--em-border);color:var(--em-t3);display:flex;font-size:var(--text-2xs);justify-content:space-between;padding:8px 13px}.em-table-wrap{max-height:400px;overflow-x:auto;overflow-y:auto}.em-table-wrap::-webkit-scrollbar{height:3px;width:3px}.em-table-wrap::-webkit-scrollbar-thumb{background:var(--border-strong)}.em-table{border-collapse:collapse;font-size:var(--text-xs);width:100%}.em-table th{background:var(--em-surface);color:var(--em-t3);font-size:var(--text-2xs);font-weight:700;letter-spacing:.7px;padding:8px 11px;text-align:left;text-transform:uppercase;white-space:nowrap}.em-table td,.em-table th{border-bottom:1px solid var(--em-border)}.em-table td{color:var(--em-t2);padding:9px 11px;vertical-align:middle}.em-table tr:last-child td{border-bottom:none}.em-table tr:hover td{background:var(--em-surface)}.em-recipient-name{color:var(--em-t1);font-size:var(--text-xs);font-weight:600}.em-recipient-email{color:var(--em-t3);font-size:var(--text-2xs)}.em-subject{color:var(--em-t2);font-size:var(--text-sm)}.em-nowrap{white-space:nowrap}.em-empty-cell{padding:24px}.em-empty{color:var(--em-t3);padding:26px 14px;text-align:center}.em-empty-icon{font-size:var(--text-4xl);margin-bottom:6px}.em-empty-title{color:var(--em-t2);font-size:var(--text-sm);font-weight:600;margin-bottom:3px}.em-badge{align-items:center;border-radius:var(--radius-3xl);display:inline-flex;font-family:var(--em-mono);font-size:var(--text-2xs);font-weight:700;gap:3px;padding:2px 7px;white-space:nowrap}.em-badge-green{background:var(--color-green-50);color:var(--color-green-600)}.em-badge-red{background:var(--color-red-50);color:var(--color-red-dark)}.em-badge-amber{background:var(--color-orange-50);color:var(--color-orange)}.em-badge-blue{background:var(--color-primary-50);color:var(--color-primary)}.em-badge-purple{background:var(--color-accent-50);color:var(--color-accent)}.em-badge-teal{background:var(--color-green-50);color:var(--color-green-600)}.em-badge-indigo{background:var(--color-indigo-50);color:var(--color-indigo)}.em-dot-green{background:var(--color-green-600)}.em-dot-red{background:var(--color-red-dark)}.em-dot-amber{background:var(--color-orange)}.em-dot-teal{background:var(--color-green-600)}.em-green{color:var(--color-green-600)}.em-red{color:var(--color-red-dark)}.em-amber{color:var(--color-orange)}.em-blue{color:var(--color-primary)}.em-teal{color:var(--color-green-600)}.em-t2{color:var(--em-t2)}.em-t3{color:var(--em-t3)}.em-mono{font-family:var(--em-mono)}.em-tmpl-section-header{align-items:center;border-bottom:1px solid var(--em-border);border-top:1px solid var(--em-border);display:flex;font-size:var(--text-2xs);font-weight:700;justify-content:space-between;letter-spacing:1px;padding:8px 15px 4px;text-transform:uppercase}.em-tmpl-section-header:first-of-type{border-top:none}.em-tmpl-section-custom{border-top:1px solid var(--em-border)}.em-tmpl-row{align-items:center;border-bottom:1px solid var(--em-border);cursor:pointer;display:flex;gap:10px;padding:9px 15px;transition:background .12s}.em-tmpl-row:hover{background:var(--em-surface)}.em-tmpl-row:last-child{border-bottom:none}.em-tmpl-row-custom{cursor:default}.em-tmpl-icon{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:22px;justify-content:center;padding:0;width:22px}.em-tmpl-info{flex:1.5 1}.em-tmpl-info-wide{flex:3 1}.em-tmpl-name{color:var(--em-t1);font-size:var(--text-xs);font-weight:600}.em-tmpl-desc{color:var(--em-t3);font-size:var(--text-2xs);margin-top:1px}.em-tmpl-trigger{color:var(--em-t2);flex:2 1;font-size:var(--text-sm)}.em-badge-spacer{display:inline-block;width:52px}.em-edit-btn{flex-shrink:0;margin-left:auto;padding:3px 8px}.em-var-hint{color:var(--em-t3);font-size:var(--text-sm);margin-bottom:12px}.em-var-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr)}.em-var-card{border-radius:var(--em-r);padding:10px}.em-var-blue{background:var(--color-primary-50);border:1px solid var(--color-primary-200)}.em-var-teal{background:var(--color-green-50);border:1px solid var(--color-green-100)}.em-var-purple{background:var(--color-accent-50);border:1px solid var(--color-accent-50)}.em-var-green{background:var(--color-green-50);border:1px solid var(--color-green-100)}.em-var-amber{background:var(--color-orange-50);border:1px solid var(--color-orange)}.em-var-red{background:var(--color-red-50);border:1px solid var(--color-red-light)}.em-var-blue .em-var-token{color:var(--color-primary)}.em-var-teal .em-var-token{color:var(--color-green-600)}.em-var-purple .em-var-token{color:var(--color-accent)}.em-var-green .em-var-token{color:var(--color-green-600)}.em-var-amber .em-var-token{color:var(--color-orange)}.em-var-red .em-var-token{color:var(--color-red-dark)}.em-var-token{font-family:var(--em-mono);font-size:var(--text-2xs);margin-bottom:3px}.em-var-label{color:var(--em-t1);font-size:var(--text-sm);font-weight:600}.em-var-example{color:var(--em-t3);font-size:var(--text-2xs)}.em-modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.em-modal{animation:emModalIn .2s ease;background:var(--em-card);border:1px solid var(--em-border);border-radius:var(--em-r2);box-shadow:0 24px 80px #00000026;max-height:90vh;max-width:540px;overflow-y:auto;width:90%}@keyframes emModalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}.em-modal::-webkit-scrollbar{width:3px}.em-modal-header{align-items:center;border-bottom:1px solid var(--em-border);display:flex;justify-content:space-between;padding:13px 17px}.em-modal-title{color:var(--em-t1);font-size:var(--text-base);font-weight:700}.em-modal-close{align-items:center;background:var(--em-surface);border:1px solid var(--em-border);border-radius:var(--radius-md);color:var(--em-t2);cursor:pointer;display:flex;font-size:var(--text-xs);height:25px;justify-content:center;transition:all .2s;width:25px}.em-modal-close:hover{border-color:var(--color-red-light);color:var(--em-red)}.em-modal-body{padding:16px}.em-modal-footer{border-top:1px solid var(--em-border);display:flex;gap:8px;justify-content:flex-end;padding:11px 17px}@media (max-width:1200px){.em-kpi-row{grid-template-columns:1fr 1fr}.em-var-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:900px){.em-form-grid,.em-two-col{grid-template-columns:1fr}.em-kpi-row{grid-template-columns:1fr 1fr}.em-var-grid{grid-template-columns:repeat(2,1fr)}}.dc-kpis{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-3)}.dc-kpi{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;padding:8px 10px;position:relative;transition:transform .2s,box-shadow .2s}.dc-kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dc-kpi-accent{border-radius:var(--radius-xl) var(--radius-xl) 0 0;height:3px;left:0;position:absolute;right:0;top:0}.dc-kpi-icon{align-items:center;border-radius:var(--radius-lg);display:flex;font-size:14px;height:28px;justify-content:center;margin-bottom:var(--space-1);width:28px}.dc-kpi-label{color:var(--text-tertiary);font-size:9px;font-weight:700;letter-spacing:.6px;margin-bottom:2px;text-transform:uppercase}.dc-kpi-value{color:var(--text-primary);font-family:var(--font-mono);font-size:20px;font-weight:800;line-height:1}.dc-kpi-value.small{font-size:14px}.dc-tabs{border-bottom:1px solid var(--border-default);display:flex;gap:0;margin-bottom:var(--space-4)}.dc-tab{align-items:center;background:#0000;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;gap:6px;padding:var(--space-2) var(--space-4);position:relative;transition:color var(--transition-fast);white-space:nowrap}.dc-tab:hover{color:var(--text-primary)}.dc-tab.active{color:var(--color-teal)}.dc-tab.active:after{background:var(--color-teal);border-radius:2px 2px 0 0;bottom:-1px;content:"";height:2px;left:0;position:absolute;right:0}.dc-tab-count{background:var(--surface-tertiary);border-radius:10px;color:var(--text-secondary);font-family:var(--font-mono);font-size:10px;font-weight:700;padding:1px 6px}.dc-tab.active .dc-tab-count{background:#00c9a71f;color:var(--color-teal)}.dc-table-wrap{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-bottom:var(--space-4);overflow-x:auto}.dc-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.dc-table th{background:var(--surface-secondary);color:var(--text-tertiary);font-size:10px;font-weight:700;letter-spacing:.8px;text-align:left;text-transform:uppercase;white-space:nowrap}.dc-table td,.dc-table th{border-bottom:1px solid var(--border-default);padding:var(--space-2-5) var(--space-3)}.dc-table td{color:var(--text-primary);vertical-align:middle}.dc-table tr:last-child td{border-bottom:none}.dc-table tr:hover td{background:var(--surface-secondary)}.dc-table .dc-name-cell{font-weight:600}.dc-table .dc-sub{color:var(--text-tertiary);font-size:var(--text-xs);font-weight:400}.dc-status{border-radius:10px;display:inline-block;font-size:10px;font-weight:700;letter-spacing:.02em;padding:2px 8px}.dc-status-draft{background:var(--surface-tertiary);color:var(--text-secondary)}.dc-status-submitted{background:#eff6ff;color:#2563eb}.dc-status-proofpend{background:#fef3c7;color:#d97706}.dc-status-proofsub{background:#ede9fe;color:#7c3aed}.dc-status-verified{background:#ecfdf5;color:#059669}.dc-status-rejected{background:#fef2f2;color:#dc2626}.dc-section-badge{background:#ede9fe;border-radius:10px;color:#7c3aed;display:inline-block;font-size:10px;font-weight:700;padding:2px 8px}.dc-summary-grid{grid-gap:var(--space-3-5);display:grid;gap:var(--space-3-5);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-bottom:var(--space-4)}.dc-summary-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;padding:var(--space-3) var(--space-4);position:relative}.dc-summary-card-accent{background:#7c3aed;height:3px;left:0;position:absolute;right:0;top:0}.dc-summary-section{color:#7c3aed;font-size:12px;font-weight:700;margin-bottom:var(--space-2)}.dc-summary-row{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--text-xs);justify-content:space-between;margin-bottom:2px}.dc-summary-row strong{color:var(--text-primary);font-family:var(--font-mono)}.dc-actions{display:flex;gap:4px}.dc-actions button{align-items:center;background:none;border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;display:flex;height:26px;justify-content:center;transition:all var(--transition-fast);width:26px}.dc-actions button:hover{background:var(--surface-tertiary);color:var(--text-primary)}.dc-actions button.danger:hover{background:var(--color-red-50);border-color:var(--color-red-light);color:var(--color-red-dark)}.dc-actions button.approve:hover{background:#ecfdf5;border-color:#6ee7b7;color:#059669}.dc-footer{font-size:var(--text-xs);font-weight:500;justify-content:space-between;padding:var(--space-3) 0}.dc-empty,.dc-footer{align-items:center;color:var(--text-tertiary);display:flex}.dc-empty{flex-direction:column;justify-content:center;padding:var(--space-6) var(--space-4)}.dc-empty p{font-size:var(--text-sm);margin:4px 0 0}.dc-empty p:last-child{font-size:var(--text-xs)}@media (max-width:900px){.dc-kpis{grid-template-columns:repeat(2,1fr)}.dc-summary-grid{grid-template-columns:1fr 1fr}}@media (max-width:600px){.dc-kpis{grid-template-columns:1fr 1fr}.dc-tabs{overflow-x:auto}.dc-summary-grid{grid-template-columns:1fr}.dc-toolbar{align-items:stretch;flex-direction:column;gap:8px}.dc-footer,.dc-header{align-items:flex-start;flex-direction:column;gap:8px}}@media (max-width:480px){.dc-kpis{grid-template-columns:1fr!important}.dc-kpi-value{font-size:20px}.dc-summary-grid{grid-template-columns:1fr}}.cl-kpis{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-3)}.cl-kpi{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;padding:8px 10px;position:relative;transition:transform .2s,box-shadow .2s}.cl-kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.cl-kpi-accent{border-radius:var(--radius-xl) var(--radius-xl) 0 0;height:3px;left:0;position:absolute;right:0;top:0}.cl-kpi-icon{align-items:center;border-radius:var(--radius-lg);display:flex;font-size:14px;height:28px;justify-content:center;margin-bottom:var(--space-1);width:28px}.cl-kpi-label{color:var(--text-tertiary);font-size:9px;font-weight:700;letter-spacing:.6px;margin-bottom:2px;text-transform:uppercase}.cl-kpi-value{color:var(--text-primary);font-family:var(--font-mono);font-size:20px;font-weight:800;line-height:1}.cl-tabs{border-bottom:1px solid var(--border-default);display:flex;gap:0;margin-bottom:var(--space-4)}.cl-tab{align-items:center;background:#0000;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;gap:6px;padding:var(--space-2) var(--space-4);position:relative;transition:color var(--transition-fast);white-space:nowrap}.cl-tab:hover{color:var(--text-primary)}.cl-tab.active{color:var(--color-teal)}.cl-tab.active:after{background:var(--color-teal);border-radius:2px 2px 0 0;bottom:-1px;content:"";height:2px;left:0;position:absolute;right:0}.cl-tab-count{background:var(--surface-tertiary);border-radius:10px;color:var(--text-secondary);font-family:var(--font-mono);font-size:10px;font-weight:700;padding:1px 6px}.cl-tab.active .cl-tab-count{background:#00c9a71f;color:var(--color-teal)}.cl-table-wrap{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);margin-bottom:var(--space-4);overflow-x:auto}.cl-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.cl-table th{background:var(--surface-secondary);color:var(--text-tertiary);font-size:10px;font-weight:700;letter-spacing:.8px;text-align:left;text-transform:uppercase;white-space:nowrap}.cl-table td,.cl-table th{border-bottom:1px solid var(--border-default);padding:var(--space-2-5) var(--space-3)}.cl-table td{color:var(--text-primary);vertical-align:middle}.cl-table tr:last-child td{border-bottom:none}.cl-table tr:hover td{background:var(--surface-secondary)}.cl-table .cl-name-cell{font-weight:600}.cl-table .cl-sub{color:var(--text-tertiary);font-size:var(--text-xs);font-weight:400}.cl-status{border-radius:10px;display:inline-block;font-size:10px;font-weight:700;letter-spacing:.02em;padding:2px 8px}.cl-status-draft{background:var(--surface-tertiary);color:var(--text-secondary)}.cl-status-submitted{background:#eff6ff;color:#2563eb}.cl-status-manager{background:#fef3c7;color:#d97706}.cl-status-hr{background:#ecfdf5;color:#059669}.cl-status-rejected{background:#fef2f2;color:#dc2626}.cl-status-cancelled{background:var(--surface-tertiary);color:var(--text-tertiary)}.cl-status-paidout{background:#ecfdf5;color:#047857}.cl-actions{display:flex;gap:4px}.cl-actions button{align-items:center;background:none;border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;display:flex;height:26px;justify-content:center;transition:all var(--transition-fast);width:26px}.cl-actions button:hover{background:var(--surface-tertiary);color:var(--text-primary)}.cl-actions button.danger:hover{background:var(--color-red-50);border-color:var(--color-red-light);color:var(--color-red-dark)}.cl-actions button.approve:hover{background:#ecfdf5;border-color:#6ee7b7;color:#059669}.cl-footer{font-size:var(--text-xs);font-weight:500;justify-content:space-between;padding:var(--space-3) 0}.cl-empty,.cl-footer{align-items:center;color:var(--text-tertiary);display:flex}.cl-empty{flex-direction:column;justify-content:center;padding:var(--space-6) var(--space-4)}.cl-empty p{font-size:var(--text-sm);margin:4px 0 0}.cl-empty p:last-child{font-size:var(--text-xs)}.cl-approve-box{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-top:12px;padding:12px}.cl-approve-box label{color:var(--text-secondary);display:block;font-size:11px;font-weight:600;margin-bottom:4px}@media (max-width:900px){.cl-kpis{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.cl-kpis{grid-template-columns:1fr 1fr}.cl-tabs{overflow-x:auto}.cl-toolbar{align-items:stretch;flex-direction:column;gap:8px}.cl-footer,.cl-header{align-items:flex-start;flex-direction:column;gap:8px}}@media (max-width:480px){.cl-kpis{grid-template-columns:1fr!important}.cl-kpi-value{font-size:20px}}.rm-root{background:var(--surface-secondary);color:var(--text-primary);font-family:Inter,Segoe UI,system-ui,sans-serif;min-height:100vh}.rm-page-header{background:var(--surface-primary);border-bottom:1px solid var(--border-default);padding:20px 32px}.rm-page-header-inner{align-items:center;display:flex;gap:16px;justify-content:space-between;margin:0 auto;max-width:1200px}.rm-page-header-left{align-items:center;display:flex;gap:14px}.rm-page-icon{align-items:center;background:linear-gradient(135deg,var(--color-primary),#6366f1);border-radius:12px;color:#fff;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.rm-page-title{color:var(--text-primary);font-size:20px;font-weight:700;letter-spacing:-.3px;margin:0 0 2px}.rm-page-sub{color:var(--text-tertiary);font-size:12px;margin:0}.rm-header-actions{align-items:center;display:flex;gap:10px}.rm-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:8px 18px;transition:all .18s;white-space:nowrap}.rm-btn-primary{background:linear-gradient(135deg,var(--color-primary),#6366f1);box-shadow:0 2px 8px #6366f140;color:#fff}.rm-btn-primary:hover{box-shadow:0 4px 14px #6366f159;transform:translateY(-1px)}.rm-btn-primary:disabled{cursor:not-allowed;opacity:.5;transform:none}.rm-btn-ghost{background:var(--surface-primary);border:1px solid var(--border-default);color:var(--text-secondary)}.rm-btn-ghost:hover{background:var(--surface-hover)}.rm-body{margin:0 auto;max-width:1200px;padding:24px 32px 40px}.rm-stats{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.rm-stat-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:12px;overflow:hidden;padding:16px 18px 14px;position:relative;transition:transform .2s,box-shadow .2s}.rm-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.rm-stat-accent{border-radius:12px 12px 0 0;height:3px;left:0;position:absolute;right:0;top:0}.rm-stat-icon{align-items:center;border-radius:9px;display:flex;font-size:16px;height:34px;justify-content:center;margin-bottom:8px;width:34px}.rm-stat-label{color:var(--text-tertiary);font-size:10px;font-weight:700;letter-spacing:.7px;margin-bottom:2px;text-transform:uppercase}.rm-stat-value{font-feature-settings:"tnum";color:var(--text-primary);font-size:22px;font-variant-numeric:tabular-nums;font-weight:800;line-height:1}.rm-error{align-items:center;background:#fef2f2;background:var(--color-red-light,#fef2f2);border:1px solid #ef444433;border-radius:10px;color:var(--color-red);display:flex;font-size:13px;gap:8px;margin-bottom:16px;padding:12px 16px}.rm-loading{display:flex;justify-content:center;padding:80px 0}.rm-role-count{color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:16px}.rm-table-wrap{background:var(--surface-primary);border:1px solid var(--border-default);border-left:3px solid var(--color-primary);border-radius:12px;overflow:hidden}.rm-table{border-collapse:collapse;font-size:13px;width:100%}.rm-table thead{background:var(--surface-secondary)}.rm-table th{border-bottom:1px solid var(--border-default);color:var(--text-tertiary);font-size:11px;font-weight:700;letter-spacing:.6px;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.rm-th-center{text-align:center!important}.rm-table tbody tr{transition:background .12s}.rm-table tbody tr:hover{background:var(--surface-secondary);background:var(--surface-hover,var(--surface-secondary))}.rm-table tbody tr:not(:last-child) td{border-bottom:1px solid var(--border-default)}.rm-table td{color:var(--text-primary);padding:14px 16px;vertical-align:middle}.rm-td-center{text-align:center}.rm-td-name{align-items:center;display:flex;font-weight:600;gap:8px}.rm-name-text{color:var(--text-primary);font-size:14px}.rm-td-desc{color:var(--text-secondary);font-size:13px;max-width:300px}.rm-empty{color:var(--text-tertiary)}.rm-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:700;justify-content:center;min-width:28px;padding:3px 10px}.rm-badge-purple{background:#8b5cf61f;color:#7c3aed}.rm-badge-green{background:#10b9811f;color:#059669}.rm-status-badge{border-radius:20px;display:inline-block;font-size:10px;font-weight:700;letter-spacing:.5px;padding:3px 10px}.rm-status-badge.active{background:#10b9811f;color:#059669}.rm-status-badge.inactive{background:#ef44441f;color:#dc2626}.rm-row-actions{display:flex;gap:4px}.rm-icon-btn,.rm-row-actions{align-items:center;justify-content:center}.rm-icon-btn{background:#0000;border:1px solid #0000;border-radius:8px;color:var(--text-tertiary);cursor:pointer;display:inline-flex;height:32px;transition:all .15s;width:32px}.rm-icon-btn:hover{background:var(--surface-secondary);background:var(--surface-hover,var(--surface-secondary));border-color:var(--border-default);color:var(--text-primary)}.rm-icon-btn.perm:hover{background:#6366f114;border-color:#6366f140;color:var(--color-primary)}.rm-icon-btn.edit:hover{background:#f59e0b14;border-color:#f59e0b40;color:#f59e0b}.rm-icon-btn.delete:hover{background:#ef444414;border-color:#ef444440;color:#ef4444;color:var(--color-red,#ef4444)}.rm-icon-btn:disabled{cursor:not-allowed;opacity:.3;pointer-events:none}.rm-form-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:14px;max-width:680px;padding:28px 32px}.rm-form{display:flex;flex-direction:column;gap:18px}.rm-form-row{grid-gap:18px;display:grid;gap:18px;grid-template-columns:1fr 1fr}.rm-field label{color:var(--text-secondary);display:block;font-size:12px;font-weight:600;letter-spacing:.4px;margin-bottom:5px;text-transform:uppercase}.rm-field input,.rm-field textarea{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:8px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:13px;padding:9px 13px;transition:border-color .15s,box-shadow .15s;width:100%}.rm-field input:focus,.rm-field textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11f;outline:none}.rm-field input:disabled{background:var(--surface-secondary);background:var(--surface-tertiary,var(--surface-secondary));color:var(--text-tertiary);cursor:not-allowed}.rm-field-hint{color:var(--text-tertiary);display:block;font-size:11px;margin-top:4px;text-align:right}.rm-form-actions{align-items:center;border-top:1px solid var(--border-default);display:flex;gap:10px;justify-content:flex-end;margin-top:4px;padding-top:10px}.rm-perm-header-card{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:14px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px;padding:16px 20px}.rm-perm-badge{background:linear-gradient(135deg,var(--color-primary),#6366f1);border-radius:20px;color:#fff;font-size:12px;font-weight:700;padding:4px 12px}.rm-perm-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:14px}.rm-search-wrap{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:8px;color:var(--text-tertiary);display:flex;flex:1 1;gap:8px;max-width:380px;min-width:200px;padding:7px 14px;transition:border-color .15s}.rm-search-wrap:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}.rm-search{background:#0000;border:none;color:var(--text-primary);font-size:13px;outline:none;width:100%}.rm-perm-actions{display:flex;gap:6px}.rm-text-btn{background:#6366f10f;background:var(--color-primary-light,#6366f10f);border:1px solid #6366f133;border-radius:7px;color:var(--color-primary);cursor:pointer;font-size:11.5px;font-weight:600;padding:5px 12px;transition:all .15s}.rm-text-btn:hover{background:#6366f11f;border-color:var(--color-primary)}.rm-perm-grid{display:flex;flex-direction:column;gap:8px}.rm-module{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:12px;overflow:hidden;transition:box-shadow .15s}.rm-module:hover{box-shadow:var(--shadow-sm)}.rm-module-head{align-items:center;background:var(--surface-secondary);cursor:pointer;display:flex;gap:8px;padding:12px 16px;transition:background .15s;-webkit-user-select:none;user-select:none}.rm-module-head:hover{background:var(--surface-secondary);background:var(--surface-hover,var(--surface-secondary))}.rm-module-chevron{color:var(--text-tertiary);display:flex;transition:transform .2s}.rm-module-name{color:var(--text-primary);font-size:13px;font-weight:700}.rm-module-count{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:20px;color:var(--text-tertiary);font-size:11px;font-weight:600;margin-left:auto;padding:2px 9px}.rm-checkbox-label{align-items:center;cursor:pointer;display:flex;gap:8px}.rm-checkbox-label input[type=checkbox]{accent-color:var(--color-primary)}.rm-module-body{grid-gap:2px;background:var(--surface-primary);display:grid;gap:2px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));padding:10px 16px 14px}.rm-perm-item{align-items:flex-start;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:7px 8px;transition:background .12s}.rm-perm-item:hover{background:var(--surface-secondary);background:var(--surface-hover,var(--surface-secondary))}.rm-perm-item input[type=checkbox]{accent-color:var(--color-primary);flex-shrink:0;margin-top:2px}.rm-perm-info{display:flex;flex-direction:column;min-width:0}.rm-perm-name{color:var(--text-primary);font-size:12.5px;font-weight:500}.rm-perm-desc{color:var(--text-tertiary);font-size:11px;line-height:1.3;margin-top:1px}.rm-system-tag{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:20px;color:var(--text-tertiary);flex-shrink:0;font-size:10px;font-weight:600;letter-spacing:.3px;padding:2px 8px}@media (max-width:900px){.rm-table-wrap{overflow-x:auto}.rm-table{min-width:650px}.rm-form-row{grid-template-columns:1fr}.rm-page-header{padding:16px 20px}.rm-body{padding:16px 20px 32px}}@media (max-width:600px){.rm-page-header-inner{align-items:flex-start;flex-direction:column}.rm-perm-toolbar{flex-direction:column}.rm-search-wrap{max-width:none}}.cp-root{--cp-bg:#080d18;--cp-bg-2:#0c1222;--cp-bg-card:#ffffff0a;--cp-bg-ch:#ffffff0f;--cp-border:#ffffff14;--cp-border-md:#ffffff1f;--cp-text-1:#e2e8f0;--cp-text-2:#cbd5e1;--cp-text-3:#94a3b8;--cp-text-4:#64748b;--cp-blue:#0ea5e9;--cp-blue-bg:#0ea5e91f;--cp-green:#4ade80;--cp-green-bg:#4ade801f;--cp-amber:#fbbf24;--cp-amber-bg:#fbbf241f;--cp-red:#f87171;--cp-red-bg:#f871711f;--cp-purple:#a78bfa;--cp-purple-bg:#a78bfa1f;--cp-teal:#2dd4bf;--cp-input-bg:#ffffff0d;background:var(--cp-bg);box-sizing:border-box;color:var(--cp-text-1);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:28px 32px}.cp-page-hdr{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.cp-page-title{color:var(--cp-text-1);font-size:22px;font-weight:700}.cp-page-sub{color:var(--cp-text-3);font-size:13px;margin-top:4px}.cp-tabs{border-bottom:1px solid var(--cp-border);display:flex;gap:4px;margin-bottom:24px;overflow-x:auto;scrollbar-width:none}.cp-tabs::-webkit-scrollbar{display:none}.cp-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--cp-text-3);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:10px 18px;transition:all .2s;white-space:nowrap}.cp-tab:hover{background:var(--cp-bg-card);border-radius:6px 6px 0 0;color:var(--cp-text-1)}.cp-tab--active{border-bottom-color:var(--cp-blue);color:var(--cp-blue)}.cp-content-hdr{align-items:flex-start;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;margin-bottom:16px}.cp-content-title{color:var(--cp-text-1);font-size:16px;font-weight:600}.cp-content-sub{color:var(--cp-text-3);font-size:12px;margin-top:3px}.cp-hdr-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.cp-info-strip{border-radius:6px;font-size:12px;margin-bottom:16px;padding:9px 14px}.cp-info-blue{background:var(--cp-blue-bg);border:1px solid #0ea5e933;color:var(--cp-blue)}.cp-info-green{background:var(--cp-green-bg);border:1px solid #4ade8033;color:var(--cp-green)}.cp-info-purple{background:var(--cp-purple-bg);border:1px solid #a78bfa33;color:var(--cp-purple)}.cp-info-amber{background:var(--cp-amber-bg);border:1px solid #fbbf2433;color:var(--cp-amber)}.cp-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:6px;padding:8px 16px;transition:all .15s;white-space:nowrap}.cp-btn-primary{background:var(--cp-blue);color:#fff}.cp-btn-primary:hover{background:#38bdf8}.cp-btn-ghost{background:var(--cp-bg-card);border:1px solid var(--cp-border-md);color:var(--cp-text-2)}.cp-btn-ghost:hover{background:var(--cp-bg-ch)}.cp-select{background:var(--cp-input-bg);border:1px solid var(--cp-border-md);border-radius:6px;color:var(--cp-text-1);cursor:pointer;font-size:12px;padding:6px 10px}.cp-select:focus{border-color:var(--cp-blue);outline:none}.cp-select-full{width:100%}.cp-input,.cp-search{background:var(--cp-input-bg);border:1px solid var(--cp-border-md);border-radius:6px;color:var(--cp-text-1);font-size:12px;padding:7px 12px}.cp-search{width:200px}.cp-input::placeholder,.cp-search::placeholder{color:var(--cp-text-4)}.cp-input:focus,.cp-search:focus{border-color:var(--cp-blue);outline:none}.cp-input,.cp-textarea{box-sizing:border-box;width:100%}.cp-textarea{background:var(--cp-input-bg);border:1px solid var(--cp-border-md);border-radius:6px;color:var(--cp-text-1);font-family:inherit;font-size:12px;padding:8px 12px;resize:vertical}.cp-textarea:focus{border-color:var(--cp-blue);outline:none}.cp-month-selector{display:flex;gap:6px}.cp-table-wrap{border:1px solid var(--cp-border);border-radius:10px;margin-bottom:20px;overflow-x:auto}.cp-table{border-collapse:collapse;font-size:12px;width:100%}.cp-table th{background:#ffffff08;border-bottom:1px solid var(--cp-border-md);color:var(--cp-text-3);font-size:10px;font-weight:600;letter-spacing:.5px;padding:10px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.cp-table td{border-bottom:1px solid var(--cp-border);color:var(--cp-text-2);padding:11px 12px;vertical-align:middle}.cp-table tbody tr:last-child td{border-bottom:none}.cp-table tbody tr:hover td{background:var(--cp-bg-ch)}.cp-tfoot-row td{background:#ffffff08;border-top:1px solid var(--cp-border-md);color:var(--cp-text-1);font-size:12px;padding:11px 12px}.cp-td-mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:11px}.cp-td-accent{color:var(--cp-blue);font-weight:600}.cp-td-dim{color:var(--cp-text-4)}.cp-row-actions{display:flex;gap:6px}.cp-icon-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:13px;padding:3px 6px;transition:background .15s}.cp-icon-btn:hover{background:var(--cp-bg-ch)}.cp-icon-btn-danger:hover{background:var(--cp-red-bg)}.cp-badge{border-radius:10px;display:inline-block;font-size:10px;font-weight:600;padding:2px 9px;text-transform:capitalize;white-space:nowrap}.cp-badge-filed{background:var(--cp-green-bg);color:var(--cp-green)}.cp-badge-pending{background:var(--cp-amber-bg);color:var(--cp-amber)}.cp-badge-overdue{background:var(--cp-red-bg);color:var(--cp-red)}.cp-badge-exempt{background:#64748b1f;color:var(--cp-text-3)}.cp-type-badge{border-radius:4px;display:inline-block;font-size:10px;font-weight:700;letter-spacing:.5px;padding:2px 9px}.cp-type-pf{background:var(--cp-blue-bg);color:var(--cp-blue)}.cp-type-esi{background:var(--cp-green-bg);color:var(--cp-green)}.cp-type-pt{background:var(--cp-amber-bg);color:var(--cp-amber)}.cp-type-tds{background:var(--cp-purple-bg);color:var(--cp-purple)}.cp-regime-badge{border-radius:4px;display:inline-block;font-size:10px;font-weight:600;padding:2px 8px}.cp-regime-old{background:var(--cp-blue-bg);color:var(--cp-blue)}.cp-regime-new{background:var(--cp-green-bg);color:var(--cp-green)}.cp-emp-cell{align-items:center;display:flex;gap:10px}.cp-emp-avatar{align-items:center;color:#fff;display:flex;font-size:10px;font-weight:700;justify-content:center}.cp-emp-avatar,.cp-emp-avatar-img{border-radius:50%;flex-shrink:0;height:30px;width:30px}.cp-emp-avatar-img{object-fit:cover}.cp-emp-name{color:var(--cp-text-1);font-size:12px;font-weight:500;white-space:nowrap}.cp-emp-code{color:var(--cp-text-4);font-size:10px}.cp-overview{display:flex;flex-direction:column;gap:14px}.cp-stat-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.cp-stat-card{align-items:center;background:var(--cp-bg-card);border:1px solid var(--cp-border);border-left:4px solid #0000;border-radius:10px;display:flex;gap:10px;padding:8px 10px}.cp-stat-blue{border-left-color:var(--cp-blue)}.cp-stat-green{border-left-color:var(--cp-green)}.cp-stat-amber{border-left-color:var(--cp-amber)}.cp-stat-purple{border-left-color:var(--cp-purple)}.cp-stat-icon{font-size:20px}.cp-stat-value{color:var(--cp-text-1);font-size:18px;font-weight:700}.cp-stat-label{color:var(--cp-text-3);font-size:9px;font-weight:600;letter-spacing:.5px;margin:2px 0;text-transform:uppercase}.cp-stat-sub{color:var(--cp-text-4);font-size:9px}.cp-two-col{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:900px){.cp-two-col{grid-template-columns:1fr}}@media (max-width:768px){.cp-root{padding:12px!important}.cp-content-hdr,.cp-page-hdr{align-items:flex-start;flex-direction:column;gap:8px}.cp-hdr-actions{flex-wrap:wrap;width:100%}.cp-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.cp-stats-grid,.cp-summary-cards{grid-template-columns:repeat(2,1fr)}.cp-form-row,.cp-form-row-3{grid-template-columns:1fr}.cp-cal-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.cp-qa-row{gap:8px}.cp-qa-btn{min-width:80px;padding:10px 14px}}@media (max-width:480px){.cp-stats-grid,.cp-summary-cards{grid-template-columns:1fr}.cp-page-title,.cp-stat-value{font-size:18px}}.cp-panel{background:var(--cp-bg-card);border:1px solid var(--cp-border);border-radius:10px;overflow:hidden}.cp-panel-hdr{border-bottom:1px solid var(--cp-border);padding:14px 18px}.cp-panel-title{color:var(--cp-text-1);font-size:13px;font-weight:600}.cp-deadline-list{padding:8px 0}.cp-deadline-item{align-items:center;border-bottom:1px solid var(--cp-border);display:flex;gap:12px;padding:10px 18px}.cp-deadline-item:last-child{border-bottom:none}.cp-deadline-type{border-radius:4px;flex-shrink:0;font-size:10px;font-weight:700;padding:3px 0;text-align:center;width:44px}.cp-deadline-pf{background:var(--cp-blue-bg);color:var(--cp-blue)}.cp-deadline-esi{background:var(--cp-green-bg);color:var(--cp-green)}.cp-deadline-pt{background:var(--cp-amber-bg);color:var(--cp-amber)}.cp-deadline-tds{background:var(--cp-purple-bg);color:var(--cp-purple)}.cp-deadline-info{flex:1 1}.cp-deadline-label{color:var(--cp-text-1);font-size:12px;font-weight:500}.cp-deadline-due{color:var(--cp-text-4);font-size:11px}.cp-cal-table-wrap{overflow-x:auto}.cp-cal-table{border:none;margin:0}.cp-cal-table td,.cp-cal-table th{padding:8px 12px}.cp-qa-title{color:var(--cp-text-3);font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.cp-qa-row{display:flex;flex-wrap:wrap;gap:12px}.cp-qa-btn{align-items:center;background:var(--cp-bg-card);border:1px solid var(--cp-border-md);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:4px;min-width:100px;padding:14px 20px;transition:all .2s}.cp-qa-btn:hover{background:var(--cp-bg-ch);border-color:var(--cp-blue);transform:translateY(-1px)}.cp-qa-icon{font-size:22px}.cp-qa-label{color:var(--cp-text-1);font-size:11px;font-weight:600;text-align:center}.cp-qa-sub{color:var(--cp-text-4);font-size:10px}.cp-tab-content{display:flex;flex-direction:column;gap:0}.cp-summary-cards{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));margin-top:4px}.cp-sum-card{background:var(--cp-bg-card);border:1px solid var(--cp-border);border-radius:8px;border-top:3px solid;padding:14px 16px}.cp-sum-label{color:var(--cp-text-3);font-size:11px;margin-bottom:6px}.cp-sum-value{font-size:18px;font-weight:700}.cp-pt-summary{padding:16px 18px}.cp-pt-sum-row{align-items:center;border-bottom:1px solid var(--cp-border);color:var(--cp-text-2);display:flex;font-size:13px;justify-content:space-between;padding:8px 0}.cp-pt-sum-row:last-child{border-bottom:none}.cp-empty{align-items:center;display:flex;flex-direction:column;gap:8px;padding:60px 20px}.cp-empty-icon{font-size:48px}.cp-empty-title{color:var(--cp-text-1);font-size:15px;font-weight:600}.cp-empty-sub{color:var(--cp-text-3);font-size:12px;max-width:380px;text-align:center}.cp-modal-overlay{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.cp-modal{background:#0f1929;border:1px solid var(--cp-border-md);border-radius:12px;box-shadow:0 24px 60px #00000080;max-height:90vh;max-width:95vw;overflow-y:auto;width:560px}.cp-modal-hdr{align-items:center;border-bottom:1px solid var(--cp-border);display:flex;justify-content:space-between;padding:18px 24px 14px}.cp-modal-title{color:var(--cp-text-1);font-size:15px;font-weight:600}.cp-modal-close{background:none;border:none;color:var(--cp-text-3);cursor:pointer;font-size:16px;padding:4px}.cp-modal-body{display:flex;flex-direction:column;gap:14px;padding:20px 24px}.cp-modal-footer{align-items:center;border-top:1px solid var(--cp-border);display:flex;gap:10px;padding:14px 24px 20px}.cp-form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.cp-form-row-3{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr 1fr}.cp-form-field{display:flex;flex-direction:column;gap:6px}.cp-label{color:var(--cp-text-3);font-size:11px;font-weight:600;letter-spacing:.4px;text-transform:uppercase}:root:not([data-theme=dark]) .cp-root{--cp-bg:#f0f2f5;--cp-bg-2:#fff;--cp-bg-card:#00000005;--cp-bg-ch:#0000000a;--cp-border:#00000014;--cp-border-md:#0000001f;--cp-text-1:#1e293b;--cp-text-2:#334155;--cp-text-3:#64748b;--cp-text-4:#94a3b8;--cp-blue:#2563eb;--cp-blue-bg:#2563eb14;--cp-green:#16a34a;--cp-green-bg:#16a34a14;--cp-amber:#d97706;--cp-amber-bg:#d9770614;--cp-red:#dc2626;--cp-red-bg:#dc262614;--cp-purple:#7c3aed;--cp-purple-bg:#7c3aed14;--cp-teal:#0d9488;--cp-input-bg:#fff}:root:not([data-theme=dark]) .cp-modal{background:#fff;border-color:#0000001f;box-shadow:0 24px 60px #00000026}:root:not([data-theme=dark]) .cp-table th,:root:not([data-theme=dark]) .cp-tfoot-row td{background:#00000005}:root:not([data-theme=dark]) .cp-module-head,:root:not([data-theme=dark]) .cp-stat-card{background:#fff}:root:not([data-theme=dark]) .cp-btn-primary{background:#2563eb}:root:not([data-theme=dark]) .cp-btn-primary:hover{background:#1d4ed8}:root:not([data-theme=dark]) .cp-tab--active{border-bottom-color:#2563eb;color:#2563eb}:root:not([data-theme=dark]) .cp-emp-avatar{box-shadow:0 1px 3px #0000001a}:root:not([data-theme=dark]) .cp-panel,:root:not([data-theme=dark]) .cp-qa-btn,:root:not([data-theme=dark]) .cp-sum-card{background:#fff}:root:not([data-theme=dark]) .cp-qa-btn:hover{background:#f8fafc}.pt-stats-pill{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:20px;font-weight:600;padding:4px 12px}.pt-legend,.pt-stats-pill{color:#475569;color:var(--text-secondary,#475569);font-size:12px}.pt-legend{flex-wrap:wrap;gap:16px;margin-bottom:16px}.pt-legend,.pt-legend-item{align-items:center;display:flex}.pt-legend-item{gap:5px}.pt-legend-dot{border-radius:50%;height:8px;width:8px}.pt-legend-dot.configured{background:#10b981}.pt-legend-dot.empty{background:#cbd5e1;border:1px solid #94a3b8}.pt-report-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:20px}.pt-report-card{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:12px;border-radius:var(--radius-xl,12px);overflow:hidden;transition:box-shadow .2s}.pt-report-card:hover{box-shadow:0 4px 16px #00000014;box-shadow:var(--shadow-md,0 4px 16px #00000014)}.pt-report-card-header{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-subtle,#f1f5f9);display:flex;gap:10px;padding:12px 14px 10px}.pt-type-icon{align-items:center;border-radius:8px;border-radius:var(--radius-lg,8px);display:flex;flex-shrink:0;font-size:16px;height:34px;justify-content:center;width:34px}.pt-report-card-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:13px;font-weight:700}.pt-single-slot{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:5px;justify-content:center;min-height:84px;padding:14px 12px 12px;transition:background .15s}.pt-single-slot.configured{background:#f0fdf4}.pt-single-slot.configured:hover{background:#dcfce7}.pt-single-slot.empty{background:#fff;background:var(--surface-primary,#fff)}.pt-single-slot.empty:hover{background:#f8fafc;background:var(--surface-secondary,#f8fafc)}.pt-tri-badge{background:#d1fae5;border-radius:10px;color:#059669;font-size:11px;font-weight:800;letter-spacing:.8px;padding:2px 12px}.pt-tri-badge.empty{background:#f1f5f9;color:#94a3b8}.pt-slot-name{color:#334155;font-size:11px;font-weight:600;max-width:180px;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.pt-slot-empty-label{color:#94a3b8;font-size:11px}.pt-lang-actions{display:flex;gap:2px;margin-top:2px}.pt-lang-actions button{background:none;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;line-height:1;padding:2px 3px;transition:.15s}.pt-lang-actions button:hover{background:#e2e8f0;color:#334155}.pt-lang-actions button.danger:hover{background:#fef2f2;color:#dc2626}.pt-footer{align-items:center;display:flex;font-size:12px;justify-content:space-between;padding:12px 0}.pt-empty,.pt-footer{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.pt-empty{padding:48px 20px;text-align:center}.pt-modal-meta{align-items:center;display:flex;gap:8px;margin-top:4px}.pt-type-badge{white-space:nowrap}.pt-lang-tag,.pt-type-badge{border-radius:10px;font-size:11px;font-weight:600;padding:2px 10px}.pt-lang-tag{background:#eef2ff;color:#6366f1}.pt-lang-selector{display:flex;gap:6px}.pt-lang-sel-btn{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:8px;color:#475569;color:var(--text-secondary,#475569);cursor:pointer;flex:1 1;font-size:12px;font-weight:600;padding:7px 4px;transition:.15s}.pt-lang-sel-btn.active,.pt-lang-sel-btn:hover{border-color:#4d9fff;color:#4d9fff}.pt-lang-sel-btn.active{background:#4d9fff1a}.pt-form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr;margin-bottom:4px}.pt-form-grid-2col{grid-template-columns:1fr 1fr}.pt-toggle-row{display:flex;flex-wrap:wrap;gap:20px;margin:10px 0 4px}.pt-editor-section{margin-top:14px}.pt-editor-tabs{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-default,#e2e8f0);display:flex}.pt-editor-tab{background:#0000;border:none;color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;font-size:12px;font-weight:600;padding:8px 16px;position:relative;transition:color .15s}.pt-editor-tab:hover{color:#334155;color:var(--text-primary,#334155)}.pt-editor-tab.active{color:#4d9fff}.pt-editor-tab.active:after{background:#4d9fff;border-radius:2px 2px 0 0;bottom:-1px;content:"";height:2px;left:0;position:absolute;right:0}.pt-editor-wrap{margin-top:0}.pt-editor-pane{padding:0}.pt-editor-hint{align-items:center;color:#94a3b8;color:var(--text-tertiary,#94a3b8);display:flex;flex-wrap:wrap;font-size:11px;gap:4px;line-height:1.8;padding:8px 0}.pt-editor-hint code{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border-radius:3px;color:#8b5cf6;font-family:monospace;font-family:var(--font-mono,monospace);font-size:10px;padding:1px 6px}.pt-code-editor{background:#1e293b;border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:8px;color:#e2e8f0;font-family:JetBrains Mono,Fira Code,monospace;font-family:var(--font-mono,"JetBrains Mono","Fira Code",monospace);font-size:12px;line-height:1.6;min-height:220px;outline:none;padding:14px;resize:vertical;tab-size:2;width:100%}.pt-code-editor:focus{border-color:#4d9fff;box-shadow:0 0 0 3px #4d9fff1f}.pt-code-editor::placeholder{color:#475569}.pt-live-preview{margin-top:12px}.pt-preview-label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.pt-preview-box{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:8px;overflow:hidden}.pt-preview-frame{background:#fff}.modal-content.modal-xl{max-width:900px;width:90vw}@media (max-width:900px){.pt-form-grid,.pt-report-grid{grid-template-columns:1fr 1fr}}@media (max-width:600px){.pt-form-grid,.pt-report-grid{grid-template-columns:1fr}}.sm-page{padding:0}.sm-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:16px 0}.sm-title{color:#1e293b;font-size:18px;font-weight:600;margin:0}.sm-actions{gap:8px}.sm-actions,.sm-search-wrap{align-items:center;display:flex}.sm-search-wrap{background:#f1f5f9;border-radius:6px;gap:6px;padding:6px 10px}.sm-search-wrap input{background:#0000;border:none;font-size:13px;outline:none;width:160px}.sm-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:5px;padding:7px 14px;transition:.15s}.sm-btn-primary{background:#4d9fff;color:#fff}.sm-btn-primary:hover{background:#3b82f6}.sm-btn-primary:disabled{cursor:not-allowed;opacity:.5}.sm-btn-ghost{background:#0000;border:1px solid #e2e8f0;color:#64748b}.sm-btn-ghost:hover{background:#f1f5f9}.sm-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;display:flex;font-size:13px;justify-content:space-between;margin-bottom:12px;padding:8px 12px}.sm-error button{background:none;border:none;color:#dc2626;cursor:pointer}.sm-loading{font-size:14px;padding:40px}.sm-empty,.sm-loading{color:#94a3b8;text-align:center}.sm-empty{font-style:italic;padding:32px!important}.sm-table-wrap{border:1px solid #e2e8f0;border-radius:8px;overflow-x:auto}.sm-table{border-collapse:collapse;font-size:13px;width:100%}.sm-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#475569;font-weight:600;padding:10px 14px;text-align:left;white-space:nowrap}.sm-table td{border-bottom:1px solid #f1f5f9;color:#334155;padding:10px 14px}.sm-table tr:hover{background:#f8fafc}.sm-table tr:last-child td{border-bottom:none}.sm-mono{font-family:JetBrains Mono,monospace;font-size:12px}.sm-ellipsis{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sm-row-actions{display:flex;gap:4px}.sm-row-actions button{background:none;border:none;border-radius:4px;color:#64748b;cursor:pointer;padding:4px;transition:.15s}.sm-row-actions button:hover{background:#f1f5f9;color:#334155}.sm-badge{border-radius:10px;font-size:11px;font-weight:600;padding:2px 8px}.sm-badge.active{background:#dcfce7;color:#16a34a}.sm-badge.inactive{background:#f1f5f9;color:#64748b}.sm-overlay{background:#0000004d;display:flex;inset:0;justify-content:flex-end;position:fixed;z-index:1000}.sm-drawer{animation:smSlideIn .2s ease;background:#fff;background:var(--surface-primary,#fff);box-shadow:-4px 0 24px #00000014;display:flex;flex-direction:column;height:100%;max-width:90vw;width:460px}@keyframes smSlideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.sm-drawer-head{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-default,#e2e8f0);display:flex;justify-content:space-between;padding:16px 20px}.sm-drawer-head h3{color:#1e293b;color:var(--text-primary,#1e293b);font-size:16px;font-weight:600;margin:0}.sm-drawer-head button{background:none;border:none;color:#94a3b8;cursor:pointer}.sm-form{flex:1 1;gap:14px;overflow-y:auto;padding:20px}.sm-field,.sm-form{display:flex;flex-direction:column}.sm-field{gap:4px}.sm-field label{color:#475569;font-size:12px;font-weight:600}.sm-req{color:#ef4444;margin-left:2px}.sm-field input,.sm-field select,.sm-field textarea{border:1px solid #e2e8f0;border-radius:6px;font-size:13px;outline:none;padding:8px 10px;transition:.15s}.sm-field input:focus,.sm-field select:focus,.sm-field textarea:focus{border-color:#4d9fff;box-shadow:none}.sm-field textarea{font-family:inherit;min-height:80px;resize:vertical}.sm-field input[type=color]{cursor:pointer;height:36px;padding:2px}.sm-check{align-items:center;color:#334155;cursor:pointer;display:flex;font-size:13px;gap:6px}.sm-check input{height:16px;width:16px}.sm-form-footer{border-top:1px solid #e2e8f0;display:flex;gap:8px;justify-content:flex-end;margin-top:auto;padding-top:16px}.sm-pagination{align-items:center;display:flex;gap:12px;justify-content:center;padding:16px 0}.sm-pagination button{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:6px;cursor:pointer;font-size:13px;padding:6px 14px}.sm-pagination button:disabled{cursor:not-allowed;opacity:.4}.sm-pagination span{color:#64748b;color:var(--text-secondary,#64748b);font-size:13px}.sh-root{background:var(--surface-secondary);display:flex;flex-direction:column;height:100%;overflow:hidden}.sh-topbar{background:var(--surface-primary);border-bottom:1px solid var(--border-default);flex-shrink:0;gap:16px;padding:14px 28px}.sh-topbar,.sh-topbar-left{align-items:center;display:flex}.sh-topbar-left{flex:0 0 auto;gap:10px}.sh-topbar-icon{font-size:26px}.sh-topbar-title{color:var(--text-primary);font-size:var(--text-xl);font-weight:700;line-height:1.2}.sh-topbar-sub{color:var(--text-secondary);font-size:var(--text-xs)}.sh-search-box{flex:1 1 360px;margin:0 auto;max-width:440px;position:relative}.sh-search-icon{color:var(--text-tertiary);left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.sh-search-input{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);outline:none;padding:7px 30px;transition:border-color .15s;width:100%}.sh-search-input:focus{background:var(--surface-primary);border-color:var(--color-primary)}.sh-search-clear{background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;padding:2px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.sh-close-btn{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:500;gap:6px;padding:6px 14px;transition:background .15s;white-space:nowrap}.sh-close-btn:hover{background:var(--surface-tertiary)}.sh-body{flex:1 1;overflow-y:auto;padding:28px 32px 48px}.sh-section{margin-bottom:36px}.sh-section-title{color:var(--text-secondary);font-size:var(--text-base);font-weight:700;letter-spacing:.5px;margin:0 0 16px 4px;text-transform:uppercase}.sh-cards-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.sh-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);overflow:hidden;transition:box-shadow .15s}.sh-card:hover{box-shadow:var(--shadow-sm)}.sh-card-header{align-items:center;display:flex;gap:8px;padding:12px 16px 8px}.sh-card-icon{font-size:var(--text-xl)}.sh-card-label{font-size:var(--text-base);font-weight:600}.sh-card-items{list-style:none;margin:0;padding:0 0 8px}.sh-card-item{color:var(--text-primary);cursor:pointer;font-size:var(--text-sm);padding:7px 16px 7px 42px;position:relative;transition:background .12s,color .12s}.sh-card-item:hover{background:var(--color-primary-50);color:var(--color-primary-dark)}.sh-card-item.disabled{color:var(--text-tertiary);cursor:default;pointer-events:none}.sh-card-item.disabled:after{color:var(--text-tertiary);content:"Coming soon";font-size:var(--text-2xs);font-style:italic;margin-left:8px}.sh-detail{display:flex;flex-direction:column;height:100%;overflow:hidden}.sh-detail .prs-root{flex:1 1;min-height:0;overflow:hidden}.sh-back-btn{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-primary);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:var(--text-sm);font-weight:500;gap:6px;margin:12px 16px 4px;padding:8px 16px;transition:background .12s}.sh-back-btn:hover{background:var(--color-primary-50)}.sh-empty{color:var(--text-tertiary);font-size:var(--text-base);padding:64px 16px;text-align:center}.sh-sub-hub{padding:24px 32px}.sh-sub-hub-title{color:var(--text-primary);font-size:var(--text-xl);font-weight:700;margin-bottom:20px}.sh-sub-hub-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.sh-sub-hub-card{align-items:flex-start;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:20px;text-align:left;transition:box-shadow .15s,border-color .15s}.sh-sub-hub-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.sh-sub-hub-icon{font-size:24px}.sh-sub-hub-label{color:var(--text-primary);font-size:var(--text-md);font-weight:600}.sh-sub-hub-desc{color:var(--text-secondary);font-size:var(--text-xs)}@media (max-width:768px){.sh-topbar{flex-wrap:wrap;padding:12px 16px}.sh-search-box{flex:1 1 100%;max-width:none;order:3}.sh-body{padding:16px}.sh-cards-grid{grid-template-columns:1fr}}@media (max-width:480px){.sh-topbar{padding:8px 10px}.sh-body{padding:10px}.sh-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}}.pp-overlay{background:#0000004d;inset:0;position:fixed;z-index:1200}.pp-panel{animation:ppSlideIn .2s ease-out;background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-2xl);box-shadow:0 20px 60px #0000002e;display:flex;flex-direction:column;max-height:calc(100vh - 80px);overflow:hidden;position:fixed;right:16px;top:64px;width:380px;z-index:1201}@keyframes ppSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.pp-header{align-items:center;background:#f8fafc;background:var(--surface-hover,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);display:flex;gap:14px;padding:18px 20px}.pp-avatar-wrap{cursor:pointer;flex-shrink:0;position:relative}.pp-avatar{align-items:center;color:var(--text-inverse);display:flex;font-size:var(--text-xl);font-weight:700;justify-content:center}.pp-avatar,.pp-avatar-img{border-radius:50%;height:54px;width:54px}.pp-avatar-img{object-fit:cover}.pp-avatar-edit{align-items:center;border:2px solid #fff;border:2px solid var(--card-bg,#fff);border-radius:50%;bottom:-2px;color:var(--text-inverse);display:flex;font-size:var(--text-2xs);height:20px;justify-content:center;position:absolute;right:-2px;width:20px}.pp-header-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.pp-name{color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-md);font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pp-username{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-sm)}.pp-role-badge{align-items:center;border:1px solid;border-radius:var(--radius-3xl);display:inline-flex;gap:5px;margin-top:5px;padding:2px 9px;width:fit-content}.pp-role-icon{font-size:var(--text-sm)}.pp-role-text{font-size:var(--text-2xs);font-weight:700}.pp-close{background:none;border:none;color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;flex-shrink:0;font-size:var(--text-xl);padding:4px}.pp-close:hover{color:#1e293b;color:var(--text-primary,#1e293b)}.pp-tabs{background:#f8fafc;background:var(--surface-hover,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);display:flex}.pp-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:700;padding:10px 0;transition:all .15s}.pp-tab:hover{color:#64748b;color:var(--text-secondary,#64748b)}.pp-tab.active{border-bottom-color:#6366f1;border-bottom-color:var(--primary-color,#6366f1);color:#6366f1;color:var(--primary-color,#6366f1)}.pp-content{max-height:400px;overflow-y:auto;padding:18px}.pp-toast{align-items:center;border-radius:var(--radius-xl);display:flex;font-size:var(--text-xs);font-weight:600;gap:8px;margin-bottom:14px;padding:8px 12px}.pp-toast.success{background:var(--color-green-50);border:1px solid var(--color-green-100);color:var(--color-green-600)}.pp-toast.error{background:var(--color-red-50);border:1px solid var(--color-red-light);color:var(--color-red-dark)}.pp-form{display:flex;flex-direction:column;gap:12px}.pp-row-2{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.pp-field{display:flex;flex-direction:column;gap:5px}.pp-field label{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs);font-weight:700;letter-spacing:.7px;text-transform:uppercase}.pp-field input{background:#fff;background:var(--input-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);box-sizing:border-box;color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);outline:none;padding:9px 12px;width:100%}.pp-field input:focus{border-color:#6366f1;border-color:var(--primary-color,#6366f1)}.pp-field input.disabled{background:#f1f5f9;background:var(--surface-hover,#f1f5f9);color:#94a3b8;color:var(--text-secondary,#94a3b8);cursor:not-allowed}.pp-photo-row{align-items:center;display:flex;gap:10px}.pp-photo-preview{cursor:pointer}.pp-photo-preview img{border-radius:50%;height:46px;object-fit:cover;width:46px}.pp-photo-initials{align-items:center;border-radius:50%;color:var(--text-inverse);display:flex;font-size:var(--text-base);font-weight:700;height:46px;justify-content:center;width:46px}.pp-photo-actions{display:flex;flex:1 1;flex-direction:column;gap:4px}.pp-btn-upload{align-items:center;background:#6366f11f;border:none;border-radius:var(--radius-lg);color:#6366f1;color:var(--primary-color,#6366f1);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:600;gap:6px;justify-content:center;padding:7px 14px;width:100%}.pp-btn-upload:hover{background:#6366f133}.pp-btn-remove{background:#ef44441a;border:none;border-radius:var(--radius-md);color:var(--color-red);cursor:pointer;font-size:var(--text-2xs);font-weight:600;padding:4px 12px;width:100%}.pp-btn-remove:hover{background:#ef44442e}.pp-photo-hint{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs)}.pp-actions{display:flex;gap:8px;margin-top:4px}.pp-btn-save{background:#6366f1;background:var(--primary-color,#6366f1);border:none;border-radius:var(--radius-lg);color:var(--text-inverse);cursor:pointer;flex:1 1;font-size:var(--text-xs);font-weight:600;padding:9px 0}.pp-btn-save:hover{opacity:.9}.pp-btn-save:disabled{cursor:not-allowed;opacity:.6}.pp-btn-cancel{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;flex:1 1;font-size:var(--text-xs);font-weight:500;padding:9px 0}.pp-btn-cancel:hover{background:#f1f5f9;background:var(--surface-hover,#f1f5f9)}.pp-security-notice{align-items:flex-start;background:var(--color-orange-50);border:1px solid #d977064d;border-radius:var(--radius-xl);display:flex;gap:12px;padding:10px 14px}.pp-security-notice strong{color:var(--color-orange);font-size:var(--text-xs)}.pp-security-notice p{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs);margin:3px 0 0}.pp-pw-wrap{position:relative}.pp-pw-wrap input{background:#fff;background:var(--input-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-lg);box-sizing:border-box;color:#1e293b;color:var(--text-primary,#1e293b);font-size:var(--text-sm);outline:none;padding:9px 36px 9px 12px;width:100%}.pp-pw-wrap input:focus{border-color:#6366f1;border-color:var(--primary-color,#6366f1)}.pp-pw-toggle{background:none;border:none;color:#94a3b8;color:var(--text-tertiary,#94a3b8);cursor:pointer;display:flex;padding:2px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.pp-pw-strength{display:flex;flex-wrap:wrap;gap:4px}.pp-pw-tag{border-radius:var(--radius-3xl);font-size:var(--text-2xs);font-weight:700;padding:2px 8px}.pp-pw-tag.pass{background:var(--color-green-50);color:var(--color-green-600)}.pp-pw-tag.fail{background:var(--color-red-50);color:var(--color-red)}.pp-btn-pw{background:var(--color-orange-50);border:none;border-radius:var(--radius-lg);color:var(--color-orange);cursor:pointer;font-size:var(--text-xs);font-weight:600;margin-top:4px;padding:9px 0;width:100%}.pp-btn-pw:hover{background:var(--color-orange)}.pp-sep{align-items:center;display:flex;gap:10px;margin:16px 0 8px;position:relative;text-align:center}.pp-sep:after,.pp-sep:before{background:#e2e8f0;background:var(--border-color,#e2e8f0);content:"";flex:1 1;height:1px}.pp-sep span{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-2xs);font-weight:700;letter-spacing:.8px;white-space:nowrap}.pp-session{display:flex;flex-direction:column}.pp-session-row{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);display:flex;font-size:var(--text-xs);justify-content:space-between;padding:8px 0}.pp-session-key{color:#94a3b8;color:var(--text-tertiary,#94a3b8)}.pp-session-val{color:#64748b;color:var(--text-secondary,#64748b);font-weight:600}.pp-permissions{display:flex;flex-direction:column;gap:10px}.pp-role-banner{align-items:center;border:1px solid;border-radius:var(--radius-xl);display:flex;gap:10px;margin-bottom:6px;padding:12px 14px}.pp-role-banner-icon{flex-shrink:0}.pp-role-banner-name{font-size:var(--text-sm);font-weight:800}.pp-role-banner-desc{color:#94a3b8;color:var(--text-tertiary,#94a3b8);font-size:var(--text-sm);margin-top:2px}.pp-perm-group{border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:var(--radius-xl);overflow:hidden}.pp-perm-header{background:#f8fafc;background:var(--surface-hover,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm);font-weight:700;letter-spacing:.5px;padding:8px 12px;text-transform:capitalize}.pp-perm-body{display:flex;flex-wrap:wrap;gap:6px;padding:6px 12px}.pp-perm-badge{border-radius:var(--radius-3xl);font-size:var(--text-2xs);font-weight:700;padding:2px 9px}.pp-perm-badge.allowed{background:var(--color-green-50);color:var(--color-green-600)}.pp-perm-badge.denied{background:var(--color-red-50);color:var(--color-red)}@media (max-width:768px){.pp-panel{border-radius:0;max-height:100vh;right:0;top:0;width:100%}.pp-row-2{grid-template-columns:1fr}}.pfesi-overlay{align-items:flex-start;animation:pfesi-fadein .2s ease;background:#00000073;display:flex;inset:0;justify-content:center;padding-top:64px;position:fixed;z-index:1200}@keyframes pfesi-fadein{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.pfesi-modal{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-default,#e5e7eb);border-radius:var(--radius-xl);box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;max-height:calc(100vh - 100px);max-width:calc(100vw - 32px);overflow:hidden;width:640px}.pfesi-header{align-items:flex-start;background:var(--color-orange-50);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-default,#e5e7eb);display:flex;justify-content:space-between;padding:18px 20px 14px}[data-theme=dark] .pfesi-header{background:#ea580c14}.pfesi-header-left{align-items:flex-start;display:flex;gap:12px}.pfesi-icon-wrap{align-items:center;background:var(--color-orange);border-radius:var(--radius-lg);color:var(--color-orange);display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.pfesi-title{color:#1a1a2e;color:var(--text-primary,#1a1a2e);font-size:var(--text-md);font-weight:700}.pfesi-subtitle{align-items:center;color:#64748b;color:var(--text-secondary,#64748b);display:flex;font-size:var(--text-xs);gap:6px;margin-top:2px}.pfesi-overdue-pill{background:var(--color-red-50);border-radius:var(--radius-xl);color:var(--color-red-dark);display:inline-block;font-size:var(--text-sm);font-weight:600;padding:1px 7px}.pfesi-close{background:none;border:none;border-radius:var(--radius-sm);color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;line-height:0;padding:4px;transition:background .15s}.pfesi-close:hover{background:#0000000f;color:#111;color:var(--text-primary,#111)}.pfesi-info-bar{background:var(--color-orange-50);border-bottom:1px solid var(--color-orange);color:var(--color-orange);font-size:12.5px;line-height:1.5;padding:10px 20px}[data-theme=dark] .pfesi-info-bar{background:#f59e0b14;border-color:#f59e0b33;color:var(--color-orange)}.pfesi-list{display:flex;flex:1 1;flex-direction:column;gap:6px;overflow-y:auto;padding:8px 12px}.pfesi-row{align-items:center;border-left:3px solid;border-radius:var(--radius-lg);display:flex;gap:10px;justify-content:space-between;padding:10px 12px}.pfesi-row.warning{background:var(--color-orange-50);border-color:#f59e0b}.pfesi-row.overdue{background:var(--color-red-50);border-color:#ef4444}[data-theme=dark] .pfesi-row.warning{background:#f59e0b14}[data-theme=dark] .pfesi-row.overdue{background:#ef444414}.pfesi-row-info{flex:1 1;min-width:0}.pfesi-emp-name{align-items:center;color:#1a1a2e;color:var(--text-primary,#1a1a2e);display:flex;font-size:var(--text-sm);font-weight:600;gap:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pfesi-emp-code{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border-radius:var(--radius-sm);color:#475569;color:var(--text-secondary,#475569);flex-shrink:0;font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;padding:1px 6px}.pfesi-row-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.pfesi-dept{color:#64748b;color:var(--text-secondary,#64748b);font-size:var(--text-sm)}.pfesi-days-badge{border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:600;padding:1px 8px}.pfesi-days-badge.warning{background:var(--color-orange-50);color:var(--color-orange)}.pfesi-days-badge.overdue{background:var(--color-red-50);color:var(--color-red-dark)}.pfesi-missing{color:var(--color-orange);font-size:var(--text-sm);font-style:italic}.pfesi-goto-btn{align-items:center;background:#2563eb;background:var(--primary,#2563eb);border:none;border-radius:var(--radius-md);color:var(--text-inverse);cursor:pointer;display:flex;flex-shrink:0;font-size:var(--text-xs);font-weight:600;gap:5px;padding:5px 12px;transition:background .15s;white-space:nowrap}.pfesi-goto-btn:hover{background:var(--color-primary-dark)}.pfesi-footer{align-items:center;background:#f8fafc;background:var(--surface-secondary,#f8fafc);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-default,#e5e7eb);display:flex;gap:10px;justify-content:space-between;padding:12px 20px}.pfesi-footer-note{color:#94a3b8;color:var(--text-secondary,#94a3b8);font-size:var(--text-sm);font-style:italic}.pfesi-dismiss-btn{background:none;border:1px solid #d1d5db;border:1px solid var(--border-default,#d1d5db);border-radius:var(--radius-md);color:#475569;color:var(--text-secondary,#475569);cursor:pointer;font-size:var(--text-xs);font-weight:500;padding:6px 16px;transition:background .15s;white-space:nowrap}.pfesi-dismiss-btn:hover{background:#f1f5f9;background:var(--surface-hover,#f1f5f9)}.ha-fab{align-items:center;background:#6366f1;background:var(--color-primary,#6366f1);border:none;border-radius:50%;box-shadow:0 4px 16px #6366f173;color:#fff;display:flex;font-size:22px;height:56px;justify-content:center;position:fixed;touch-action:none;transition:transform .15s ease,box-shadow .15s ease;-webkit-user-select:none;user-select:none;width:56px;z-index:10000}.ha-fab:hover{box-shadow:0 6px 22px #6366f18c;transform:scale(1.08)}.ha-fab-badge{background:#22c55e;border:2px solid #fff;border-radius:50%;height:10px;position:absolute;right:4px;top:4px;width:10px}.ha-panel{animation:ha-slide-up .22s ease;background:#fff;background:var(--surface-primary,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:16px;border-radius:var(--radius-xl,16px);box-shadow:0 16px 48px #00000029;display:flex;flex-direction:column;max-height:580px;overflow:hidden;position:fixed;width:380px;z-index:10000}@keyframes ha-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ha-header{align-items:center;background:#6366f1;background:var(--color-primary,#6366f1);color:#fff;display:flex;flex-shrink:0;gap:10px;padding:14px 16px 12px}.ha-header-icon{flex-shrink:0;font-size:20px}.ha-header-text{flex:1 1;min-width:0}.ha-header-title{font-size:.92rem;font-weight:700;letter-spacing:.01em;line-height:1.2}.ha-header-sub{font-size:.72rem;margin-top:1px;opacity:.82;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ha-close-btn{align-items:center;background:#ffffff2e;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;height:28px;justify-content:center;transition:background .15s;width:28px}.ha-close-btn:hover{background:#ffffff4d}.ha-module-chip{background:#ffffff2e;border-radius:20px;color:#fff;flex-shrink:0;font-size:.68rem;font-weight:600;letter-spacing:.03em;margin-left:auto;padding:2px 8px;text-transform:uppercase}.ha-quick-bar{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-default,#e2e8f0);display:flex;flex-shrink:0;flex-wrap:wrap;gap:6px;padding:8px 12px}.ha-quick-chip{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:20px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;font-size:.7rem;padding:3px 10px;transition:background .15s,border-color .15s;white-space:nowrap}.ha-quick-chip:hover{background:#eef2ff;background:var(--color-primary-50,#eef2ff);border-color:#6366f1;border-color:var(--color-primary,#6366f1);color:#6366f1;color:var(--color-primary,#6366f1)}.ha-messages{display:flex;flex:1 1;flex-direction:column;gap:10px;overflow-y:auto;padding:12px;scroll-behavior:smooth}.ha-messages::-webkit-scrollbar{width:4px}.ha-messages::-webkit-scrollbar-track{background:#0000}.ha-messages::-webkit-scrollbar-thumb{background:#e2e8f0;background:var(--border-default,#e2e8f0);border-radius:2px}.ha-msg{display:flex;flex-direction:column;max-width:90%}.ha-msg.user{align-items:flex-end;align-self:flex-end}.ha-msg.assistant{align-items:flex-start;align-self:flex-start}.ha-bubble{border-radius:14px;font-size:.82rem;line-height:1.55;padding:9px 13px;white-space:pre-wrap;word-break:break-word}.ha-msg.user .ha-bubble{background:#6366f1;background:var(--color-primary,#6366f1);border-bottom-right-radius:4px;color:#fff}.ha-msg.assistant .ha-bubble{background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-bottom-left-radius:4px;color:#1e293b;color:var(--text-primary,#1e293b)}.ha-msg-time{color:#94a3b8;color:var(--text-muted,#94a3b8);font-size:.65rem;margin-top:3px;padding:0 4px}.ha-typing{align-items:center;align-self:flex-start;background:#f1f5f9;background:var(--surface-secondary,#f1f5f9);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:14px;border-bottom-left-radius:4px;display:flex;gap:4px;padding:10px 13px;width:fit-content}.ha-dot{animation:ha-bounce 1.2s infinite;background:#94a3b8;background:var(--text-muted,#94a3b8);border-radius:50%;height:7px;width:7px}.ha-dot:nth-child(2){animation-delay:.2s}.ha-dot:nth-child(3){animation-delay:.4s}@keyframes ha-bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}}.ha-input-row{align-items:flex-end;background:#fff;background:var(--surface-primary,#fff);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-default,#e2e8f0);display:flex;flex-shrink:0;gap:8px;padding:10px 12px}.ha-input{background:#f8fafc;background:var(--surface-secondary,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:10px;border-radius:var(--radius-lg,10px);color:#1e293b;color:var(--text-primary,#1e293b);flex:1 1;font-family:inherit;font-size:.82rem;line-height:1.5;max-height:96px;min-height:38px;outline:none;padding:9px 12px;resize:none;transition:border-color .15s}.ha-input:focus{background:#fff;background:var(--surface-primary,#fff);border-color:#6366f1;border-color:var(--color-primary,#6366f1)}.ha-input::placeholder{color:#94a3b8;color:var(--text-muted,#94a3b8)}.ha-send-btn{align-items:center;background:#6366f1;background:var(--color-primary,#6366f1);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:15px;height:36px;justify-content:center;transition:background .15s,transform .1s;width:36px}.ha-send-btn:hover:not(:disabled){background:#4f46e5;background:var(--color-primary-700,#4f46e5);transform:scale(1.06)}.ha-send-btn:disabled{background:#e2e8f0;background:var(--border-default,#e2e8f0);cursor:not-allowed}.ha-clear-btn{align-self:center;background:none;border:none;color:#94a3b8;color:var(--text-muted,#94a3b8);cursor:pointer;font-size:.7rem;padding:0 4px;text-decoration:underline;transition:color .15s}.ha-clear-btn:hover{color:#64748b;color:var(--text-secondary,#64748b)}.ha-empty{align-items:center;color:#94a3b8;color:var(--text-muted,#94a3b8);display:flex;flex:1 1;flex-direction:column;gap:8px;justify-content:center;padding:20px;text-align:center}.ha-empty-icon{font-size:36px}.ha-empty-title{color:#64748b;color:var(--text-secondary,#64748b);font-size:.85rem;font-weight:600}.ha-empty-sub{font-size:.75rem;line-height:1.5}.ha-bubble b,.ha-bubble strong{font-weight:700}.ha-list-item{align-items:flex-start;display:flex;font-size:.82rem;gap:6px;line-height:1.55;margin:2px 0}.ha-list-num{flex-shrink:0;font-weight:700;min-width:18px}.ha-list-dot{flex-shrink:0;font-size:.7rem;margin-top:2px}.ha-reply-header{color:#6366f1;color:var(--color-primary,#6366f1);font-size:.82rem;font-weight:700;margin:4px 0 2px}.ha-sources{margin-top:6px;width:100%}.ha-sources-toggle{background:none;border:1px solid #e2e8f0;border:1px solid var(--border-default,#e2e8f0);border-radius:20px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;font-size:.68rem;padding:2px 9px;transition:background .15s,color .15s}.ha-sources-toggle:hover{background:#eef2ff;background:var(--color-primary-50,#eef2ff);color:#6366f1;color:var(--color-primary,#6366f1)}.ha-sources-list{display:flex;flex-direction:column;gap:2px;list-style:none;margin:4px 0 0;padding:4px 4px 0}.ha-source-item{border-left:2px solid #6366f1;border-left:2px solid var(--color-primary,#6366f1);color:#64748b;color:var(--text-secondary,#64748b);font-size:.68rem;padding:1px 4px}.ha-suggestions{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.ha-suggestion-chip{background:none;border:1px solid #6366f1;border:1px solid var(--color-primary,#6366f1);border-radius:20px;color:#6366f1;color:var(--color-primary,#6366f1);cursor:pointer;font-size:.68rem;padding:3px 10px;text-align:left;transition:background .15s}.ha-suggestion-chip:hover:not(:disabled){background:#eef2ff;background:var(--color-primary-50,#eef2ff)}.ha-suggestion-chip:disabled{cursor:not-allowed;opacity:.5}.ha-msg-meta{align-items:center;display:flex;gap:6px;margin-top:3px;padding:0 4px}.ha-rag-badge{border-radius:20px;font-size:.6rem;font-weight:600;letter-spacing:.04em;padding:1px 7px}.ha-rag-llm{background:#ede9fe;color:#6d28d9}.ha-rag-local{background:#dcfce7;color:#166534}.ha-msg.ha-msg-error .ha-bubble{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.ha-retry-btn{background:none;border:1px solid #fca5a5;border-radius:20px;color:#ef4444;cursor:pointer;font-size:.7rem;margin-top:4px;padding:3px 10px;transition:background .15s}.ha-retry-btn:hover:not(:disabled){background:#fef2f2}@media (max-width:480px){.ha-panel{bottom:80px;max-height:70vh;right:12px;width:calc(100vw - 24px)}.ha-fab{bottom:16px;right:16px}}.ha-nav-path{align-items:center;background:#eef2ff;background:var(--color-primary-50,#eef2ff);border:1px solid #6366f1;border-left:3px solid #6366f1;border:1px solid var(--color-primary,#6366f1);border-left-width:3px;border-radius:8px;box-sizing:border-box;color:#4f46e5;color:var(--color-primary,#4f46e5);display:flex;flex-wrap:wrap;font-size:.72rem;gap:4px;margin-top:7px;padding:6px 10px;transition:background .15s;width:100%}.ha-nav-path--link{cursor:pointer;-webkit-user-select:none;user-select:none}.ha-nav-path--link:hover{background:#e0e7ff;background:var(--color-primary-100,#e0e7ff)}.ha-nav-path--link:focus-visible{outline:2px solid #6366f1;outline:2px solid var(--color-primary,#6366f1);outline-offset:2px}.ha-nav-icon{flex-shrink:0;font-size:.85rem;margin-right:2px}.ha-nav-segments{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:3px;min-width:0}.ha-nav-seg{font-weight:500;white-space:nowrap}.ha-nav-seg--root{color:#4338ca;color:var(--color-primary,#4338ca);font-weight:700}.ha-nav-arrow{font-size:.8rem;font-weight:300;opacity:.55}.ha-nav-go{background:#6366f1;background:var(--color-primary,#6366f1);border-radius:4px;color:#fff;flex-shrink:0;font-size:.68rem;font-weight:700;margin-left:auto;padding:2px 7px;transition:background .15s}.ha-nav-path--link:hover .ha-nav-go{background:#4338ca;background:var(--color-primary-700,#4338ca)}.ha-section-answer{align-items:flex-start;display:flex;font-size:.82rem;gap:6px;line-height:1.55;margin:2px 0 4px}.ha-section-check{color:#16a34a;flex-shrink:0;font-size:.9rem;font-weight:700;margin-top:1px}.ha-section-steps{align-items:center;color:#475569;color:var(--text-secondary,#475569);display:flex;gap:5px;margin:8px 0 3px}.ha-section-label,.ha-section-steps{font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.ha-section-label{color:#64748b;color:var(--text-secondary,#64748b);margin:6px 0 2px}.ha-cursor{animation:ha-blink .7s step-end infinite;background:#6366f1;background:var(--ha-accent,#6366f1);border-radius:1px;display:inline-block;height:1em;margin-left:2px;vertical-align:text-bottom;width:2px}@keyframes ha-blink{0%,to{opacity:1}50%{opacity:0}}.ha-thinking{animation:ha-pulse 1.4s ease-in-out infinite;color:#6366f1;color:var(--ha-accent,#6366f1);font-style:italic}@keyframes ha-pulse{0%,to{opacity:1}50%{opacity:.5}}.ha-stop-btn{background:#0000;border:1.5px solid #f87171;border-radius:8px;color:#f87171;cursor:pointer;flex-shrink:0;font-size:.75rem;font-weight:700;line-height:1;padding:6px 10px;transition:background .15s,color .15s}.ha-stop-btn:hover{background:#f87171;color:#fff}.ha-msg.assistant .ha-bubble:has(.ha-cursor){animation:ha-stream-border 1.4s ease-in-out infinite;border-left:2px solid #6366f1;border-left:2px solid var(--ha-accent,#6366f1);padding-left:10px}@keyframes ha-stream-border{0%,to{border-color:#6366f1}50%{border-color:#a5b4fc}}.cmp-root{background:var(--surface-secondary);color:var(--text-primary);font-family:Inter,Segoe UI,sans-serif;min-height:100%;padding:20px 24px}.cmp-card{background:var(--surface-primary);border:1px solid var(--border-default);border-radius:12px;margin-bottom:14px;padding:16px}.cmp-input{background:var(--input-bg);border:1px solid var(--border-default);border-radius:8px;box-sizing:border-box;color:var(--text-primary);font-size:12px;padding:7px 11px;width:100%}.cmp-btn{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;font-weight:700;padding:9px 24px}.cmp-btn-reset{background:var(--surface-tertiary)}.cmp-btn-pdf{background:linear-gradient(135deg,#0d47a1,#1565c0);padding:9px 18px}.cmp-title{color:var(--color-primary-light);font-size:18px;font-weight:700;margin-bottom:2px}.cmp-subtitle{color:var(--text-tertiary);font-size:11px;margin-bottom:16px}.cmp-tab-bar{background:var(--surface-tertiary);border-radius:10px;display:flex;gap:4px;margin-bottom:16px;padding:3px;width:fit-content}.cmp-tab{background:#0000;border:none;border-radius:8px;color:var(--text-tertiary);cursor:pointer;font-size:12px;font-weight:600;padding:7px 18px;transition:all .2s}.cmp-tab.active{background:linear-gradient(135deg,#4fc3f7,#2196f3);color:#fff}.cmp-section{background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:10px;margin-bottom:12px;overflow:hidden}.cmp-section-header{align-items:center;background:var(--surface-primary);border-bottom:1px solid var(--border-default);color:var(--text-secondary);display:flex;font-size:11px;font-weight:700;justify-content:space-between;padding:6px 14px}.cmp-section-body{padding:12px 14px}.cmp-thead-row{background:var(--surface-tertiary)}.cmp-th{color:var(--text-tertiary);font-size:9px;font-weight:700;letter-spacing:.06em;padding:5px 12px;text-align:left;text-transform:uppercase}.cmp-td{color:var(--text-secondary);font-size:11px;padding:6px 12px}.cmp-row-border{border-bottom:1px solid var(--border-light)}.cmp-table-header-row{background:var(--surface-tertiary);border-bottom:1px solid var(--border-default)}.cmp-data-row{background:var(--surface-primary);border-bottom:1px solid var(--border-light);cursor:pointer}.cmp-data-row:hover{background:var(--surface-tertiary)}.cmp-stat-box{background:var(--surface-secondary);border-radius:8px;flex:1 1;min-width:70px;padding:8px 4px;text-align:center}.cmp-stat-label{color:var(--text-tertiary);font-size:9px;margin-top:2px}.cmp-month-badge{background:var(--color-primary-50);border:1px solid var(--color-primary);border-radius:6px;color:var(--color-primary-light);font-size:12px;font-weight:600;padding:4px 12px}.cmp-info-row{background:var(--surface-primary);border-radius:8px;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:12px;padding:10px 12px}.cmp-info-label{color:var(--text-tertiary);font-size:9px;margin-bottom:2px}.cmp-info-value{color:var(--text-primary);font-size:12px;font-weight:600}.cmp-report{background:var(--surface-secondary);font-size:12px;padding:16px 18px}.cmp-report-title{color:var(--color-primary-light);font-size:13px;font-weight:700;letter-spacing:.02em;margin-bottom:14px}.cmp-badge-pass{background:var(--color-green-50);border:1px solid var(--color-green);border-radius:20px;color:var(--color-green)}.cmp-badge-fail,.cmp-badge-pass{font-size:10px;font-weight:700;padding:3px 9px;white-space:nowrap}.cmp-badge-fail{background:var(--color-red-50);border:1px solid var(--color-red);border-radius:20px;color:var(--color-red)}.cmp-badge-warn{background:var(--color-orange-50);border:1px solid var(--color-orange);border-radius:20px;color:var(--color-orange);font-size:10px;font-weight:700;padding:3px 9px;white-space:nowrap}.cmp-final-pass{background:var(--color-green-50);border:1.5px solid var(--color-green);border-radius:10px;padding:14px 16px}.cmp-final-fail{background:var(--color-red-50);border:1.5px solid var(--color-red);border-radius:10px;padding:14px 16px}.cmp-upload-zone{background:var(--surface-tertiary);border-radius:12px;cursor:pointer;flex:1 1;min-width:200px;padding:18px 16px;text-align:center;transition:all .2s;-webkit-user-select:none;user-select:none}.cmp-error-box{background:var(--color-red-50);border:1px solid var(--color-red);border-radius:8px;color:var(--color-red);font-size:11px;margin-top:10px;padding:7px 12px}.cmp-att-cell{align-items:center;border-radius:4px;display:flex;font-size:8px;font-weight:700;height:22px;justify-content:center;width:28px}.cmp-att-pass-indicator{align-items:center;border-radius:20px;display:inline-flex;gap:8px;margin:8px 0 10px;padding:4px 14px}.cmp-file-ref{color:var(--text-tertiary);font-size:10px}.cmp-file-ref span{color:var(--color-primary-light)}.cmp-cfg-pass{background:var(--color-green-50);border-color:var(--color-green)}.cmp-cfg-fail{background:var(--color-red-50);border-color:var(--color-red)}.cmp-cfg-warn{background:var(--color-orange-50);border-color:var(--color-orange)}.cmp-cfg-neutral{background:var(--surface-tertiary);border-color:var(--border-default)}.cmp-cfg-info{background:var(--color-blue-50);border-color:var(--color-blue)}.co-page{max-width:1100px;padding:24px}.co-header{flex-wrap:wrap;margin-bottom:20px}.co-header,.co-header-left{align-items:center;display:flex;gap:10px}.co-header-left{flex:1 1}.co-header-actions{align-items:center;display:flex;gap:8px}.co-header-icon{color:#6366f1;color:var(--color-indigo,#6366f1)}.co-title{color:var(--text-primary);font-size:1.15rem;font-size:var(--text-xl,1.15rem);font-weight:700;margin:0}.co-badge{border-radius:100px;font-size:11px;font-weight:700;line-height:1.6;padding:2px 8px}.co-badge,.co-btn-primary{background:#6366f1;background:var(--color-indigo,#6366f1);color:#fff}.co-btn-primary{align-items:center;border:none;border-radius:6px;border-radius:var(--radius-md,6px);cursor:pointer;display:inline-flex;font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:600;gap:6px;padding:7px 14px;transition:background .15s}.co-btn-primary:hover:not(:disabled){background:#4f46e5}.co-btn-primary:disabled{cursor:not-allowed;opacity:.5}.co-btn-ghost{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-default,#e5e7eb);border-radius:6px;border-radius:var(--radius-md,6px);color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:500;gap:6px;padding:7px 12px;transition:background .15s,border-color .15s}.co-btn-ghost:hover:not(:disabled){background:#f3f4f6;background:var(--hover-bg,#f3f4f6)}.co-btn-ghost:disabled{cursor:not-allowed;opacity:.5}.co-btn-back{align-items:center;background:none;border:none;color:#6366f1;color:var(--color-indigo,#6366f1);cursor:pointer;display:inline-flex;font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:600;gap:4px;padding:4px 0}.co-btn-back:hover{text-decoration:underline}.co-btn-link{background:none;border:none;border-radius:6px;border-radius:var(--radius-md,6px);color:#6366f1;color:var(--color-indigo,#6366f1);cursor:pointer;font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:600;padding:4px 8px;transition:background .15s}.co-btn-link:hover{background:#6366f114}.co-alert{align-items:center;border-radius:6px;border-radius:var(--radius-md,6px);display:flex;font-size:.875rem;font-size:var(--text-sm,.875rem);gap:8px;margin-bottom:16px;padding:10px 14px}.co-alert-error{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c}.co-alert-success{background:#f0fdf4;border:1px solid #86efac;color:#15803d}.co-table-wrap{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-default,#e5e7eb);border-radius:12px;border-radius:var(--radius-xl,12px);overflow:hidden}.co-table{border-collapse:collapse;font-size:.875rem;font-size:var(--text-sm,.875rem);width:100%}.co-table thead{background:#f9fafb;background:var(--hover-bg,#f9fafb)}.co-table th{color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.co-table td,.co-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-default,#e5e7eb)}.co-table td{color:var(--text-primary);padding:12px 14px}.co-table tbody tr:last-child td{border-bottom:none}.co-table tbody tr:hover{background:#f9fafb;background:var(--hover-bg,#f9fafb)}.co-count{background:#f3f4f6;background:var(--hover-bg,#f3f4f6);color:var(--text-secondary);font-size:12px}.co-count,.co-status{border-radius:100px;display:inline-block;font-weight:600;padding:2px 8px}.co-status{font-size:11px}.co-status-active{background:#dcfce7;color:#15803d}.co-status-inactive{background:#f3f4f6;color:#6b7280}.co-empty{color:var(--text-secondary);padding:64px 24px;text-align:center}.co-empty-icon{color:#e5e7eb;color:var(--border-default,#e5e7eb);margin-bottom:12px}.co-empty p{font-size:1rem;font-size:var(--text-base,1rem);margin:0 0 16px}.co-form{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-default,#e5e7eb);border-radius:12px;border-radius:var(--radius-xl,12px);overflow:hidden}.co-section{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-default,#e5e7eb);padding:20px 24px}.co-section:last-of-type{border-bottom:none}.co-section-title{align-items:center;color:var(--text-primary);display:flex;font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:700;gap:7px;letter-spacing:.5px;margin-bottom:16px;text-transform:uppercase}.co-section-hint{color:var(--text-secondary);font-size:.75rem;font-size:var(--text-xs,.75rem);font-weight:500;letter-spacing:0;text-transform:none}.co-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.co-field{display:flex;flex-direction:column;gap:4px}.co-field-full{grid-column:1/-1}.co-field label{align-items:center;color:var(--text-secondary);display:flex;font-size:12px;font-weight:600;gap:5px}.co-field input,.co-field select{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-default,#e5e7eb);border-radius:6px;border-radius:var(--radius-md,6px);box-sizing:border-box;color:var(--text-primary);font-size:.875rem;font-size:var(--text-sm,.875rem);padding:7px 10px;transition:border-color .15s;width:100%}.co-field input:focus,.co-field select:focus{border-color:#6366f1;border-color:var(--color-indigo,#6366f1);box-shadow:0 0 0 2px #6366f11f;outline:none}.co-req{color:#ef4444;font-size:13px}.co-hint{color:var(--text-secondary);font-size:.75rem;font-size:var(--text-xs,.75rem);line-height:1.5;margin:10px 0 0}.co-form-footer{align-items:center;background:#f9fafb;background:var(--hover-bg,#f9fafb);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-default,#e5e7eb);display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.co-detail-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}@media (max-width:640px){.co-detail-grid{grid-template-columns:1fr}}.co-detail-card{background:#fff;background:var(--surface-primary,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-default,#e5e7eb);border-radius:12px;border-radius:var(--radius-xl,12px);padding:20px}.co-detail-card h4{align-items:center;color:var(--text-primary);font-weight:700;gap:6px;letter-spacing:.5px;margin:0 0 14px;text-transform:uppercase}.co-detail-card h4,.co-info-row{display:flex;font-size:.875rem;font-size:var(--text-sm,.875rem)}.co-info-row{align-items:flex-start;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-default,#f3f4f6);gap:12px;justify-content:space-between;padding:7px 0}.co-info-row:last-child{border-bottom:none}.co-info-row>span:first-child{color:var(--text-secondary);flex-shrink:0;font-weight:500}.co-info-row>span:last-child{color:var(--text-primary);font-weight:600;text-align:right}.co-admin-row{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-default,#f3f4f6);padding:10px 0}.co-admin-row:last-child{border-bottom:none}.co-admin-name{color:var(--text-primary);font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:600}.co-admin-email{color:var(--text-secondary);font-size:12px;margin:2px 0 6px}.co-admin-meta{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.co-last-login{color:var(--text-secondary);font-size:11px}.co-no-admins{color:var(--text-secondary);font-size:.875rem;font-size:var(--text-sm,.875rem);margin:0;padding:12px 0}.idc-root{--idc-bg:#f8fafc;--idc-bg2:#f1f5f9;--idc-bg3:#fff;--idc-bg4:#e2e8f0;--idc-hd:linear-gradient(135deg,#e2e8f0,#f1f5f9);--idc-t1:#1e293b;--idc-t2:#475569;--idc-t3:#64748b;--idc-t4:#94a3b8;--idc-b1:#00000014;--idc-b2:#00000026;--idc-ib:#0000000a;--idc-cb:#00000008;--idc-sb:#0000000a;--idc-ov:#00000080;--idc-sh:0 20px 60px #0000001f}[data-theme=dark] .idc-root{--idc-bg:#0f1629;--idc-bg2:#0d1321;--idc-bg3:#131c2e;--idc-bg4:#080d18;--idc-hd:linear-gradient(135deg,#1b2b4b,#0f1629);--idc-t1:#e2e8f0;--idc-t2:#94a3b8;--idc-t3:#64748b;--idc-t4:#475569;--idc-b1:#ffffff0f;--idc-b2:#ffffff1a;--idc-ib:#ffffff0d;--idc-cb:#ffffff08;--idc-sb:#ffffff0a;--idc-ov:#000000c7;--idc-sh:0 32px 100px #000000b3}.idc-root input{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.idc-root input:focus{outline:2px solid var(--idc-b2);outline-offset:-1px}@media (max-width:768px){.idc-root>div>div:last-child>div:first-child{min-width:140px!important;padding:10px!important;width:180px!important}.idc-root input,.idc-root select{-webkit-appearance:none;font-size:13px!important;padding:8px 10px!important}}@media (max-width:480px){.idc-root>div>div:last-child{flex-direction:column!important}.idc-root>div>div:last-child>div:first-child{border-bottom:1px solid var(--idc-b1);border-right:none!important;max-height:200px;min-width:0!important;min-width:auto!important;width:100%!important}}.adv-root{animation:adv-fadein .25s ease;display:flex;flex-direction:column;gap:12px}@keyframes adv-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.adv-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}.adv-title{color:#1e293b;color:var(--text-primary,#1e293b);font-size:1.35rem;font-size:var(--text-2xl,1.35rem);font-weight:800;margin:0}.adv-subtitle{color:#64748b;color:var(--text-secondary,#64748b);font-size:.75rem;font-size:var(--text-xs,.75rem);margin:3px 0 0}.adv-tabs{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:10px;border-radius:var(--radius-lg,10px);display:flex;gap:4px;padding:4px;width:fit-content}.adv-tab{background:#0000;border:none;border-radius:8px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;font-size:.85rem;font-size:var(--text-sm,.85rem);font-weight:600;padding:6px 18px;transition:all .15s}.adv-tab.active{background:#00b4a8;background:var(--color-teal,#00b4a8);color:#fff}.adv-kpi-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.adv-kpi{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:10px;border-radius:var(--radius-lg,10px);display:flex;flex-direction:column;gap:4px;padding:14px 16px;transition:box-shadow .15s}.adv-kpi:hover{box-shadow:0 2px 10px #00000012}.adv-kpi--pending{border-left:3px solid #f59e0b}.adv-kpi--approved{border-left:3px solid #22c55e}.adv-kpi--disbursed{border-left:3px solid #3b82f6}.adv-kpi-val{color:#1e293b;color:var(--text-primary,#1e293b);font-size:1.3rem;font-weight:800;line-height:1}.adv-kpi-lbl{color:#64748b;color:var(--text-secondary,#64748b);font-size:.72rem;font-size:var(--text-xs,.72rem);font-weight:500}.adv-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.adv-search-wrap{flex:1 1;min-width:180px;position:relative}.adv-search-icon{color:#94a3b8;color:var(--text-secondary,#94a3b8);left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.adv-search{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:8px;border-radius:var(--radius-lg,8px);box-sizing:border-box;color:#1e293b;color:var(--text-primary,#1e293b);font-size:.85rem;font-size:var(--text-sm,.85rem);padding:7px 10px 7px 32px;width:100%}.adv-search:focus{border-color:#00b4a8;border-color:var(--color-teal,#00b4a8);outline:none}.adv-select{min-width:150px}.adv-table-wrap{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:10px;border-radius:var(--radius-lg,10px);overflow-x:auto}.adv-table{border-collapse:collapse;font-size:.83rem;font-size:var(--text-sm,.83rem);width:100%}.adv-table th{background:#f8fafc;background:var(--bg-subtle,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);color:#64748b;color:var(--text-secondary,#64748b);font-size:.72rem;font-size:var(--text-xs,.72rem);font-weight:700;letter-spacing:.04em;text-align:left;text-transform:uppercase}.adv-table td,.adv-table th{padding:10px 12px;white-space:nowrap}.adv-table td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-color,#f1f5f9);color:#1e293b;color:var(--text-primary,#1e293b)}.adv-table tbody tr:last-child td{border-bottom:none}.adv-table tbody tr:hover td{background:#f8fafc;background:var(--bg-subtle,#f8fafc)}.adv-emp-cell{align-items:center;display:flex;gap:8px}.adv-emp-name{color:#1e293b;color:var(--text-primary,#1e293b);font-size:.83rem;font-size:var(--text-sm,.83rem);font-weight:600}.adv-emp-code{color:#64748b;color:var(--text-secondary,#64748b);font-size:.72rem;font-size:var(--text-xs,.72rem)}.adv-status-badge{border-radius:99px;padding:3px 10px;white-space:nowrap}.adv-status-badge,.adv-type-badge{display:inline-block;font-size:11px;font-weight:700}.adv-type-badge{border-radius:6px;padding:3px 9px}.adv-type-badge.advance{background:#ecfdf5;color:#059669}.adv-type-badge.loan{background:#eff6ff;color:#2563eb}.adv-action-btns{align-items:center;display:flex;gap:4px}.adv-icon-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;height:28px;justify-content:center;transition:all .12s;width:28px}.adv-icon-btn.view{background:#f1f5f9;color:#475569}.adv-icon-btn.approve{background:#d1fae5;color:#059669}.adv-icon-btn.reject{background:#fee2e2;color:#dc2626}.adv-icon-btn.disburse{background:#dbeafe;color:#2563eb}.adv-icon-btn.delete{background:#fef2f2;color:#ef4444}.adv-icon-btn:hover{opacity:.8;transform:scale(1.1)}.adv-pagination{display:flex;gap:12px}.adv-pagination,.adv-pg-btn{align-items:center;justify-content:center}.adv-pg-btn{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:6px;color:#1e293b;color:var(--text-primary,#1e293b);cursor:pointer;display:inline-flex;height:30px;width:30px}.adv-pg-btn:disabled{cursor:default;opacity:.4}.adv-pg-info{font-size:.83rem;font-size:var(--text-sm,.83rem)}.adv-empty,.adv-pg-info{color:#64748b;color:var(--text-secondary,#64748b)}.adv-empty{align-items:center;display:flex;flex-direction:column;gap:12px;padding:60px 20px;text-align:center}.adv-empty p{font-size:.9rem;font-size:var(--text-base,.9rem);margin:0}.adv-btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-lg,8px);cursor:pointer;display:inline-flex;font-size:.85rem;font-size:var(--text-sm,.85rem);font-weight:700;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.adv-btn.accent{background:#00b4a8;background:var(--color-teal,#00b4a8);color:#fff}.adv-btn.accent:hover{opacity:.88}.adv-btn.outline{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);color:#1e293b;color:var(--text-primary,#1e293b)}.adv-btn.approve-full{background:#d1fae5;color:#059669;flex:1 1}.adv-btn.reject-full{background:#fee2e2;color:#dc2626;flex:1 1}.adv-btn.disburse-full{background:#dbeafe;color:#2563eb;flex:1 1}.adv-btn:disabled{cursor:not-allowed;opacity:.55}.adv-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1200}.adv-modal{background:#fff;background:var(--card-bg,#fff);border-radius:14px;border-radius:var(--radius-xl,14px);box-shadow:0 20px 60px #0000002e;display:flex;flex-direction:column;max-height:90vh;max-width:520px;overflow-y:auto;width:100%}.adv-modal--wide{max-width:700px}.adv-modal--sm{max-width:420px}.adv-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);display:flex;justify-content:space-between;padding:18px 20px 14px}.adv-modal-header h2{align-items:center;color:#1e293b;color:var(--text-primary,#1e293b);display:flex;font-size:1rem;font-size:var(--text-lg,1rem);font-weight:800;gap:8px;margin:0}.adv-modal-icon.approve{color:#059669}.adv-modal-icon.reject{color:#dc2626}.adv-modal-icon.disburse{color:#2563eb}.adv-modal-close{background:none;border:none;border-radius:6px;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;padding:4px}.adv-modal-close:hover{background:#f1f5f9;background:var(--bg-subtle,#f1f5f9)}.adv-modal-body{display:flex;flex:1 1;flex-direction:column;gap:14px;padding:18px 20px}.adv-modal-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color,#e2e8f0);display:flex;gap:10px;justify-content:flex-end;padding:14px 20px}.adv-type-toggle{border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:8px;display:flex;gap:0;overflow:hidden}.adv-type-toggle button{background:#0000;border:none;color:#64748b;color:var(--text-secondary,#64748b);cursor:pointer;flex:1 1;font-size:.85rem;font-size:var(--text-sm,.85rem);font-weight:600;padding:9px 14px;transition:all .15s}.adv-type-toggle button.active{background:#00b4a8;background:var(--color-teal,#00b4a8);color:#fff}.adv-form-hint{background:#f8fafc;background:var(--bg-subtle,#f8fafc);border-radius:6px;color:#64748b;color:var(--text-secondary,#64748b);font-size:.75rem;font-size:var(--text-xs,.75rem);margin:0;padding:8px 12px}.adv-form-row2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.adv-form-group{display:flex;flex-direction:column;gap:5px}.adv-form-group label{color:#64748b;color:var(--text-secondary,#64748b);font-size:.75rem;font-size:var(--text-xs,.75rem);font-weight:700;letter-spacing:.04em;text-transform:uppercase}.adv-req{color:#ef4444}.adv-input,.adv-textarea{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:8px;box-sizing:border-box;color:#1e293b;color:var(--text-primary,#1e293b);font-size:.85rem;font-size:var(--text-sm,.85rem);padding:8px 10px;width:100%}.adv-input:focus,.adv-textarea:focus{border-color:#00b4a8;border-color:var(--color-teal,#00b4a8);outline:none}.adv-textarea{resize:vertical}.adv-select-wide{width:100%}.adv-emi-preview{background:#eff6ff;border-radius:8px;color:#1d4ed8;font-size:.85rem;font-size:var(--text-sm,.85rem);padding:10px 14px}.adv-detail-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.adv-detail-card{background:#f8fafc;background:var(--bg-subtle,#f8fafc);border-radius:8px;display:flex;flex-direction:column;gap:4px;padding:10px 12px}.adv-detail-lbl{color:#94a3b8;color:var(--text-secondary,#94a3b8);font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.adv-detail-val{color:#1e293b;color:var(--text-primary,#1e293b);font-size:.85rem;font-size:var(--text-sm,.85rem);font-weight:600}.adv-detail-reason{background:#f8fafc;background:var(--bg-subtle,#f8fafc);border-radius:8px;display:flex;flex-direction:column;gap:4px;padding:12px 14px}.adv-detail-reason p{color:#1e293b;color:var(--text-primary,#1e293b);font-size:.85rem;font-size:var(--text-sm,.85rem);margin:0;white-space:pre-wrap}.adv-detail-reason--reject{background:#fef2f2;border-left:3px solid #ef4444}.adv-action-desc{color:#1e293b;color:var(--text-primary,#1e293b);font-size:.85rem;font-size:var(--text-sm,.85rem);margin:0}.theme-picker{align-items:center;display:inline-flex;position:relative}.theme-picker__trigger{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--weight-medium);gap:6px;padding:6px 10px;transition:background var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast);white-space:nowrap}.theme-picker__trigger:hover{background:var(--surface-tertiary);border-color:var(--border-strong)}.theme-picker__trigger:focus-visible{box-shadow:var(--focus-ring-shadow);outline:none}.theme-picker__trigger[aria-expanded=true]{background:var(--surface-tertiary);border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-100)}.theme-picker__icon{font-size:15px;line-height:1}.theme-picker__label{font-size:var(--text-sm)}.theme-picker__chevron{color:var(--text-tertiary);flex-shrink:0;transition:transform var(--transition-fast)}.theme-picker__chevron--open{transform:rotate(180deg)}.theme-picker__panel{animation:theme-picker-appear .16s var(--ease-out) both;background:var(--surface-elevated);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:260px;z-index:var(--z-dropdown)}@keyframes theme-picker-appear{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.theme-picker__panel-header{align-items:center;border-bottom:1px solid var(--border-light);color:var(--text-tertiary);display:flex;font-size:var(--text-xs);font-weight:var(--weight-semibold);justify-content:space-between;letter-spacing:var(--tracking-wider);padding:12px 14px 8px;text-transform:uppercase}.theme-picker__list{max-height:380px;overflow-y:auto;padding:6px;scrollbar-color:var(--border-strong) #0000;scrollbar-width:thin}.theme-picker__list::-webkit-scrollbar{width:4px}.theme-picker__list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}.theme-picker__option{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;display:flex;font-family:var(--font-sans);gap:10px;padding:8px 10px;text-align:left;transition:background var(--transition-fast),border-color var(--transition-fast);width:100%}.theme-picker__option--focused,.theme-picker__option:hover{background:var(--surface-secondary)}.theme-picker__option--active{background:var(--color-primary-50);border-color:var(--color-primary-100);color:var(--color-primary-dark)}.theme-picker__option--active.theme-picker__option--focused,.theme-picker__option--active:hover{background:var(--color-primary-100)}.theme-picker__swatch{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:32px;justify-content:space-between;overflow:hidden;padding:4px 6px;position:relative;width:44px}.theme-picker__swatch-primary{border-radius:var(--radius-sm);flex-shrink:0;height:18px;width:10px}.theme-picker__swatch-text{font-size:11px;font-weight:700;line-height:1}.theme-picker__option-text{display:flex;flex:1 1;flex-direction:column;gap:1px;min-width:0}.theme-picker__option-name{font-size:var(--text-sm);font-weight:var(--weight-medium)}.theme-picker__option-desc,.theme-picker__option-name{line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.theme-picker__option-desc{color:var(--text-tertiary);font-size:var(--text-xs)}.theme-picker__check,.theme-picker__option--active .theme-picker__option-desc{color:var(--color-primary)}.theme-picker__check{flex-shrink:0}@media (max-width:640px){.theme-picker__label{display:none}.theme-picker__panel{right:-40px;width:240px}}@media (max-width:400px){.theme-picker__panel{right:-60px;width:220px}}.dashboard-layout{background:var(--surface-secondary);background:var(--gs-page-bg-color,var(--surface-secondary));display:flex;flex-direction:column;height:100vh;overflow:hidden;padding-left:var(--sidebar-w,var(--sidebar-width-expanded));transition:padding-left .25s ease}.dashboard-topbar{background:var(--surface-primary);background:var(--gs-header-bg-color,var(--surface-primary));border-bottom:1px solid var(--gs-header-border-color,var(--border-default));flex-shrink:0;font-family:var(--font-sans);font-family:var(--gs-header-font-family,var(--font-sans));gap:9px;height:55px;padding:0 18px;position:relative;z-index:var(--z-sticky)}.dashboard-topbar,.tb-title,.topbar-left{align-items:center;display:flex}.tb-title{color:var(--text-primary);color:var(--gs-header-text-color,var(--text-primary));font-size:var(--text-base);font-weight:700;gap:7px}.tb-icon{font-size:var(--text-lg)}.tb-name{white-space:nowrap}.tb-bread{color:var(--text-tertiary);color:var(--gs-header-muted-color,var(--text-tertiary));font-size:var(--text-sm);font-weight:400}.topbar-right{gap:8px;margin-left:auto}.tb-chip,.topbar-right{align-items:center;display:flex}.tb-chip{background:var(--surface-secondary);background:var(--gs-header-chip-bg-color,var(--surface-secondary));border:1px solid var(--gs-header-border-color,var(--border-default));border-radius:var(--radius-3xl);color:var(--text-secondary);color:var(--gs-header-chip-text-color,var(--text-secondary));font-family:var(--font-mono);font-family:var(--gs-header-font-family,var(--font-mono));font-size:var(--text-sm);gap:6px;padding:5px 10px;white-space:nowrap}.tb-date{border-color:#10b98126;border-color:var(--gs-header-border-color,#10b98126);color:var(--color-green);color:var(--gs-header-active-text-color,var(--color-green))}.tb-login-mode{font-family:inherit;font-family:var(--font-sans,inherit);font-size:.75rem;font-size:var(--text-xs,.75rem);font-weight:600;letter-spacing:.02em}.tb-login-mode.mode-actual{background:#2563eb0f;background:var(--gs-header-active-bg-color,#2563eb0f);border-color:#2563eb33;border-color:var(--gs-header-border-color,#2563eb33);color:#2563eb;color:var(--gs-header-active-text-color,var(--color-primary,#2563eb))}.tb-login-mode.mode-compliance{background:#d977060f;border-color:#d9770633;color:#d97706;color:var(--color-amber,#d97706)}.tb-dot{border-radius:50%;height:7px;width:7px}.tb-dot.live{animation:tbPulse 2s infinite;background:var(--color-green);box-shadow:0 0 6px var(--color-green)}@keyframes tbPulse{0%,to{opacity:1}50%{opacity:.4}}.tb-theme{align-items:center;background:var(--surface-secondary);background:var(--gs-header-chip-bg-color,var(--surface-secondary));border:1px solid var(--gs-header-border-color,var(--border-default));border-radius:var(--radius-3xl);color:var(--text-secondary);color:var(--gs-header-chip-text-color,var(--text-secondary));cursor:pointer;display:flex;font-family:var(--font-sans);font-family:var(--gs-header-font-family,var(--font-sans));font-size:var(--text-sm);gap:5px;padding:5px 10px;transition:all .2s}.tb-theme:hover{border-color:#10b98166;border-color:var(--gs-header-button-hover-bg-color,#10b98166);color:var(--color-green);color:var(--gs-header-active-text-color,var(--color-green))}.tb-bell{align-items:center;background:var(--surface-secondary);background:var(--gs-header-chip-bg-color,var(--surface-secondary));border:1px solid var(--gs-header-border-color,var(--border-default));border-radius:var(--radius-lg);cursor:pointer;display:flex;font-size:var(--text-base);height:32px;justify-content:center;position:relative;transition:all .2s;width:32px}.tb-bell:hover{border-color:#10b98166;border-color:var(--gs-header-button-hover-bg-color,#10b98166)}.tb-avatar{align-items:center;background:linear-gradient(135deg,var(--color-purple),var(--color-blue));border:1px solid #6366f14d;border-radius:var(--radius-lg);color:var(--text-inverse);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:700;height:32px;justify-content:center;overflow:hidden;padding:0;width:32px}.tb-avatar-img{border-radius:var(--radius-lg);height:100%;object-fit:cover;width:100%}.dashboard-main{flex:1 1;margin:0 auto;max-width:var(--content-max-width);min-height:0;overflow-y:auto;padding:var(--space-6);padding-bottom:calc(var(--space-6) + 44px);width:100%}.dashboard-main.dashboard-main-wide{max-width:none}.app-footer-bar{background:var(--surface-primary);border-top:1px solid var(--border-default);bottom:0;height:40px;justify-content:space-between;left:var(--sidebar-width-expanded);left:var(--sidebar-w,var(--sidebar-width-expanded));padding:0 var(--space-6);position:fixed;right:0;transition:left var(--transition-slow);z-index:var(--z-sticky)}.app-footer-bar,.footer-brand{align-items:center;display:flex}.footer-brand{flex-shrink:0;gap:var(--space-2)}.footer-brand-name{font-size:var(--text-xs);font-weight:700;letter-spacing:.02em}.footer-text{flex:1 1;overflow:hidden;padding:0 var(--space-4);text-align:center;text-overflow:ellipsis;white-space:nowrap}.footer-copy,.footer-text{color:var(--text-tertiary);font-size:var(--text-sm)}.footer-copy{font-feature-settings:"tnum";flex-shrink:0;font-variant-numeric:tabular-nums}.home-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);min-height:0;min-width:0}.stats-row{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(4,1fr)}.stat-card{align-items:flex-start;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;gap:var(--space-4);padding:var(--space-4) var(--space-5);transition:box-shadow var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-sm)}.stat-icon-wrapper{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.stat-icon-wrapper svg{stroke-width:1.75;height:20px;width:20px}.stat-icon-wrapper.green{background:var(--color-green-50);color:var(--color-green)}.stat-icon-wrapper.red{background:var(--color-red-50);color:var(--color-red)}.stat-icon-wrapper.blue{background:var(--color-blue-50);color:var(--color-blue)}.stat-icon-wrapper.purple{background:var(--color-purple-50);color:var(--color-purple)}.stat-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.stat-info .stat-label{color:var(--text-tertiary);font-size:var(--text-xs);font-weight:500;letter-spacing:.04em;text-transform:uppercase}.stat-info .stat-value{color:var(--text-primary);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0}.stat-info .stat-change{align-items:center;display:flex;font-size:var(--text-xs);font-weight:500;gap:2px}.stat-change.up{color:var(--color-green)}.stat-change.down{color:var(--color-red)}.content-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:5fr 3fr}.content-card{animation:fadeInUp .3s ease-out both;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-5)}.content-card:nth-child(2){animation-delay:.04s}.card-title{justify-content:space-between;margin-bottom:var(--space-4)}.card-title,.card-title h3{align-items:center;display:flex}.card-title h3{color:var(--text-primary);font-size:var(--text-sm);font-weight:600;gap:var(--space-2)}.card-title h3 svg{stroke-width:1.75;height:16px;width:16px}.card-title .card-action{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-primary);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:500;padding:var(--space-1) var(--space-2);transition:background var(--transition-fast)}.card-title .card-action:hover{background:var(--color-primary-50)}.punch-section{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(2,1fr);margin-bottom:var(--space-4)}.punch-btn{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;gap:var(--space-2);height:42px;justify-content:center;transition:all var(--transition-fast)}.punch-btn svg{stroke-width:1.75;height:16px;width:16px}.punch-btn:hover:not(:disabled){background:var(--surface-secondary);border-color:var(--border-strong)}.punch-btn:disabled{cursor:not-allowed;opacity:.45}.punch-btn.punch-in{background:var(--color-green-50);border-color:var(--color-green-100);color:var(--color-green-600)}.punch-btn.punch-in:hover:not(:disabled){background:var(--color-green);border-color:var(--color-green);color:#fff}.punch-btn.lunch-out{background:var(--color-orange-50);border-color:#f59e0b33;color:var(--color-orange)}.punch-btn.lunch-out:hover:not(:disabled){background:var(--color-orange);border-color:var(--color-orange);color:#fff}.punch-btn.lunch-in{background:var(--color-accent-50);border-color:#7c3aed26;color:var(--color-accent-dark)}.punch-btn.lunch-in:hover:not(:disabled){background:var(--color-accent);border-color:var(--color-accent);color:#fff}.punch-btn.punch-out{background:var(--color-red-50);border-color:#ef444426;color:var(--color-red-dark)}.punch-btn.punch-out:hover:not(:disabled){background:var(--color-red);border-color:var(--color-red);color:#fff}.quick-actions{display:flex;flex-direction:column;gap:var(--space-1)}.quick-action-item{align-items:center;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;font-family:var(--font-sans);gap:var(--space-3);padding:var(--space-3);text-align:left;transition:background var(--transition-fast);width:100%}.quick-action-item:hover{background:var(--surface-tertiary)}.quick-action-icon{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.quick-action-icon svg{stroke-width:1.75;height:16px;width:16px}.quick-action-icon.green{background:var(--color-green-50);color:var(--color-green)}.quick-action-icon.blue{background:var(--color-blue-50);color:var(--color-blue)}.quick-action-icon.purple{background:var(--color-purple-50);color:var(--color-purple)}.quick-action-icon.orange{background:var(--color-orange-50);color:var(--color-orange)}.quick-action-text{display:flex;flex-direction:column;gap:1px}.quick-action-text strong{color:var(--text-primary);font-size:var(--text-sm);font-weight:500}.quick-action-text span{color:var(--text-tertiary);font-size:var(--text-xs)}.timeline{display:flex;flex-direction:column}.timeline-item{display:flex;gap:var(--space-3);padding:var(--space-3) 0;position:relative}.timeline-item:not(:last-child):before{background:var(--border-default);bottom:-4px;content:"";left:14px;position:absolute;top:38px;width:1px}.timeline-dot{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.timeline-dot svg{stroke-width:1.75;height:14px;width:14px}.timeline-dot.green{background:var(--color-green-50);color:var(--color-green)}.timeline-dot.blue{background:var(--color-blue-50);color:var(--color-blue)}.timeline-dot.orange{background:var(--color-orange-50);color:var(--color-orange)}.timeline-content{display:flex;flex-direction:column;gap:1px;padding-top:3px}.timeline-content strong{color:var(--text-primary);font-size:var(--text-sm);font-weight:500}.timeline-content span{color:var(--text-tertiary);font-size:var(--text-xs)}.tb-hamburger{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:none;flex-shrink:0;height:36px;justify-content:center;padding:0;transition:all .2s;width:36px}.tb-hamburger:hover{background:var(--surface-tertiary);border-color:var(--border-strong);color:var(--text-primary)}@media (max-width:1200px){.stats-row{grid-template-columns:repeat(2,1fr)}.content-grid{grid-template-columns:1fr}}@media (max-width:768px){.dashboard-layout{padding-left:0}.dashboard-topbar{gap:6px;padding:0 var(--space-3)}.topbar-greeting{font-size:var(--text-base)}.dashboard-main{padding:var(--space-3);padding-bottom:calc(var(--space-3) + 60px + env(safe-area-inset-bottom, 0px))}.stats-row{grid-template-columns:1fr 1fr}.punch-section{grid-template-columns:1fr}.app-footer-bar,.topbar-chevron,.topbar-user-info{display:none}.tb-hamburger{display:flex}.tb-bread,.tb-date,.tb-theme span:last-child{display:none}.tb-theme{padding:5px 8px}.tb-time-chip{font-size:11px;padding:4px 8px}.tb-title{font-size:var(--text-sm)}.tb-icon{font-size:var(--text-base)}}@media (max-width:480px){.stats-row{grid-template-columns:1fr}.tb-theme,.tb-time-chip,.topbar-date{display:none}.topbar-left{flex:1 1;min-width:0;overflow:hidden}.tb-title{max-width:calc(100vw - 120px);overflow:hidden;white-space:nowrap}.tb-name{overflow:hidden;text-overflow:ellipsis}.dashboard-main{padding:var(--space-2);padding-bottom:calc(var(--space-2) + 44px)}}.topbar-icon-btn{align-items:center;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;position:relative;transition:all var(--transition-fast);width:36px}.topbar-icon-btn:hover{background:var(--surface-tertiary);border-color:var(--border-strong);color:var(--text-primary)}.topbar-notification{position:relative}.notif-badge{align-items:center;background:var(--color-pink);border:2px solid var(--surface-primary);border-radius:var(--radius-full);color:var(--text-inverse);display:flex;font-size:var(--text-sm);font-weight:700;height:18px;justify-content:center;line-height:1;min-width:18px;padding:0 5px;pointer-events:none;position:absolute;right:-4px;top:-4px}.notif-dropdown{animation:fadeInDown .15s ease-out;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:0 8px 32px #00000021,0 2px 8px #00000012;overflow:hidden;position:absolute;right:0;top:calc(100% + 10px);width:360px;z-index:var(--z-dropdown)}.notif-header{align-items:center;background:var(--surface-primary);border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;padding:14px 16px 12px}.notif-header-left,.notif-header-right{align-items:center;display:flex;gap:8px}.notif-title{color:var(--text-primary);font-size:var(--text-md);font-weight:700;letter-spacing:-.2px}.notif-count-pill{align-items:center;background:var(--color-pink);border-radius:var(--radius-full);color:var(--text-inverse);display:inline-flex;font-size:var(--text-sm);font-weight:700;height:22px;justify-content:center;line-height:1;min-width:22px;padding:0 6px}.notif-action-btn{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-primary);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:500;padding:2px 4px;white-space:nowrap}.notif-action-btn:hover{text-decoration:underline}.notif-close-btn{align-items:center;background:var(--surface-secondary);border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;height:26px;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast);width:26px}.notif-close-btn:hover{background:var(--border-default);color:var(--text-primary)}.notif-list{max-height:420px;overflow-y:auto;scroll-behavior:smooth}.notif-list::-webkit-scrollbar{width:4px}.notif-list::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}.notif-section{padding:0}.notif-section-label{font-size:var(--text-2xs);font-weight:700;letter-spacing:.8px;padding:10px 16px 6px;text-transform:uppercase}.notif-item{align-items:flex-start;background:var(--surface-primary);border-bottom:1px solid var(--border-light);cursor:pointer;display:flex;gap:10px;padding:10px 14px 10px 16px;transition:background var(--transition-fast)}.notif-item:last-child{border-bottom:none}.notif-item.unread,.notif-item:hover{background:var(--surface-secondary)}.notif-item.unread:hover{background:var(--surface-tertiary)}.notif-item.notif-item-link:hover{background:var(--surface-secondary)}.notif-item.notif-item-link .notif-item-title{color:#e65c00}.notif-item.notif-item-link .notif-item-msg{white-space:normal}.notif-item-body{flex:1 1;min-width:0}.notif-item-title{color:var(--text-primary);font-size:var(--text-sm);font-weight:600;line-height:1.3;margin-bottom:2px}.notif-item-msg{color:var(--text-secondary);font-size:var(--text-xs);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-item-time{color:var(--text-tertiary);font-size:var(--text-sm);margin-top:4px}.notif-item-end{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:6px;padding-top:2px}.notif-dot{border-radius:50%;display:block;flex-shrink:0;height:8px;width:8px}.notif-dismiss-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;display:flex;height:18px;justify-content:center;padding:0;transition:background var(--transition-fast),color var(--transition-fast);width:18px}.notif-dismiss-btn:hover{background:var(--border-default);color:var(--text-primary)}.notif-empty{color:var(--text-tertiary);font-size:var(--text-sm);padding:40px 16px;text-align:center}.topbar-user{position:relative}.topbar-user-btn{align-items:center;background:var(--surface-primary);background:var(--gs-header-chip-bg-color,var(--surface-primary));border:1px solid var(--gs-header-border-color,var(--border-default));border-radius:var(--radius-lg);cursor:pointer;display:flex;font-family:var(--font-sans);font-family:var(--gs-header-font-family,var(--font-sans));gap:var(--space-2);padding:var(--space-1) var(--space-2) var(--space-1) var(--space-1);transition:all var(--transition-fast)}.topbar-user-btn:hover{background:var(--surface-tertiary);background:var(--gs-header-active-bg-color,var(--surface-tertiary));border-color:var(--gs-header-button-hover-bg-color,var(--border-strong))}.topbar-avatar{align-items:center;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));background:linear-gradient(135deg,var(--gs-primary-color,var(--color-primary)),var(--gs-secondary-color,var(--color-accent)));color:var(--text-inverse);display:flex;font-size:var(--text-xs);font-weight:700;justify-content:center;letter-spacing:.5px}.topbar-avatar,.topbar-avatar-img{border-radius:var(--radius-md);flex-shrink:0;height:32px;width:32px}.topbar-avatar-img{object-fit:cover}.topbar-avatar-img.lg,.topbar-avatar.lg{border-radius:var(--radius-md);height:40px;width:40px}.topbar-avatar.lg{font-size:var(--text-sm)}.topbar-user-info{display:flex;flex-direction:column;gap:1px;text-align:left}.topbar-user-name{color:var(--text-primary);color:var(--gs-header-text-color,var(--text-primary));font-size:var(--text-xs);font-weight:600;white-space:nowrap}.topbar-user-role{font-size:var(--text-sm);white-space:nowrap}.topbar-chevron,.topbar-user-role{color:var(--text-tertiary);color:var(--gs-header-muted-color,var(--text-tertiary))}.topbar-chevron{transition:transform var(--transition-fast)}.topbar-chevron.open{transform:rotate(180deg)}.topbar-user-menu{animation:fadeInDown .15s ease-out;background:var(--surface-primary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:240px;z-index:var(--z-dropdown)}.user-menu-header{align-items:center;display:flex;gap:var(--space-3);padding:var(--space-4)}.user-menu-divider{background:var(--border-default);height:1px}.user-menu-item{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;gap:var(--space-3);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);width:100%}.user-menu-item:hover{background:var(--color-red-50);color:var(--color-red)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.notif-dropdown{left:var(--space-2);max-height:calc(100vh - 108px);position:fixed;right:var(--space-2);top:56px;width:auto}}@media (max-width:480px){.notif-dropdown{border-radius:0 0 var(--radius-xl) var(--radius-xl);left:0;right:0}}.App{min-height:100vh}.action-buttons button{padding:15px;width:100%}