:root{--bg:#f4f7fb;--surface:#fff;--surface-elevated:#f8fafc;--surface-muted:#eef2f7;--border:#dfe7f1;--border-strong:#c7d2e0;--text:#0f172a;--text-muted:#64748b;--muted:#64748b;--primary:#2563eb;--primary-strong:#1d4ed8;--accent:#38bdf8;--success:#16a34a;--warning:#f59e0b;--danger:#dc2626;--success-bg:rgba(22,163,74,.08);--warning-bg:rgba(245,158,11,.08);--danger-bg:rgba(220,38,38,.08);--accent-bg:rgba(56,189,248,.08);--shadow-sm:0 8px 24px rgba(15,23,42,.06);--shadow-md:0 18px 48px rgba(15,23,42,.12);--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--font-sans:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-display:"Sora","Inter",system-ui,sans-serif;--ease:cubic-bezier(.4,0,.2,1);--transition-fast:.14s var(--ease);--transition-base:.2s var(--ease);--skeleton-base:#e7edf5;--skeleton-shine:#f3f6fb}html[data-theme=dark]{--bg:#020617;--surface:#0f172a;--surface-elevated:#111c33;--surface-muted:#17233c;--border:#243247;--border-strong:#314765;--text:#f8fafc;--text-muted:#94a3b8;--muted:#94a3b8;--primary:#3b82f6;--primary-strong:#2563eb;--accent:#38bdf8;--success:#22c55e;--warning:#fbbf24;--danger:#f87171;--success-bg:rgba(34,197,94,.1);--warning-bg:rgba(251,191,36,.1);--danger-bg:hsla(0,91%,71%,.1);--accent-bg:rgba(56,189,248,.1);--shadow-sm:0 10px 30px rgba(2,6,23,.35);--shadow-md:0 24px 70px rgba(2,6,23,.45);--skeleton-base:#16213b;--skeleton-shine:#1d2c4d}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);min-height:100vh}h1,h2,h3{font-family:var(--font-display);font-weight:600;margin:0}button{cursor:pointer;background:none;border:none;color:inherit}button,input,select,textarea{font-family:inherit}a{color:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}body{transition:background-color .2s ease,color .2s ease}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border:1px solid transparent;border-radius:999px;padding:.72rem 1.1rem;font-weight:600;font-size:.95rem;transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease,border-color .16s ease}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;box-shadow:0 12px 30px rgba(37,99,235,.22)}.btn-primary:hover{box-shadow:0 16px 36px rgba(37,99,235,.28)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-muted);padding-left:0;padding-right:0}.btn-sm{padding:.5rem .8rem;font-size:.8rem}.btn-md{padding:.72rem 1.1rem;font-size:.95rem}.btn-lg{padding:.9rem 1.35rem;font-size:1rem}.btn-loading{display:inline-flex;align-items:center;gap:var(--space-2)}.field{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.field-label{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.field-input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.8rem .95rem;color:var(--text);font-size:.95rem;transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.field-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,.12)}.field-helper{margin:0;font-size:.8rem;color:var(--text-muted)}.field-error .field-input{border-color:var(--danger)}.field-error-text{margin:0;font-size:.8rem;color:var(--danger)}.form-banner-error{grid-column:1/-1;padding:.7rem .9rem;border-radius:var(--radius-sm);background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-bg);font-size:.85rem}.card-shell{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:var(--radius-lg);padding:var(--space-5)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.card-title{font-size:1rem;font-weight:700}.card-subtitle{margin:var(--space-1) 0 0;font-size:.9rem;color:var(--text-muted)}.badge-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:.35rem .7rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.02em}.badge-neutral{background:var(--surface-muted);color:var(--text-muted)}.badge-active{background:rgba(37,99,235,.14);color:var(--primary)}.badge-success{background:rgba(22,163,74,.14);color:var(--success)}.badge-warning{background:rgba(245,158,11,.14);color:var(--warning)}.badge-danger{background:rgba(220,38,38,.14);color:var(--danger)}.modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,.45);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:60}.modal-card{width:min(100%,540px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--border)}.modal-title{font-size:1.05rem}.modal-description{margin:var(--space-1) 0 0;color:var(--text-muted);font-size:.92rem}.modal-close{font-size:1.4rem;line-height:1;color:var(--text-muted)}.modal-body{padding:var(--space-5)}.toast-root{position:fixed;top:var(--space-5);right:var(--space-5);z-index:70;padding:.9rem 1rem;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);font-size:.92rem;border:1px solid var(--border);background:var(--surface);color:var(--text)}.toast-success{border-color:rgba(22,163,74,.2);background:rgba(22,163,74,.12);color:var(--success)}.toast-warning{border-color:rgba(245,158,11,.2);background:rgba(245,158,11,.12);color:var(--warning)}.toast-danger{border-color:rgba(220,38,38,.2);background:rgba(220,38,38,.12);color:var(--danger)}.login-view{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 18% 20%,rgba(37,99,235,.16),transparent 45%),radial-gradient(circle at 82% 78%,rgba(56,189,248,.14),transparent 55%),var(--bg);padding:24px}.login-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 32px 32px;box-shadow:var(--shadow-md)}.login-card .brandmark{margin-bottom:28px}.login-card h2{font-size:1.4rem;margin-bottom:6px}.login-sub{color:var(--text-muted);font-size:.95rem;margin:0 0 24px;line-height:1.5}.error-note{font-size:.9rem;color:var(--danger);margin:-6px 0 14px}.login-foot{margin-top:22px;font-size:.82rem;color:var(--text-muted);text-align:center}.topbar{height:64px;background:hsla(0,0%,100%,.9);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:30}html[data-theme=dark] .topbar{background:rgba(15,23,42,.85)}.topbar-title{font-family:var(--font-display);font-size:1rem;font-weight:700}.topbar-subtitle{font-size:.82rem;color:var(--text-muted);margin-top:2px}.topbar-actions{display:flex;align-items:center;gap:12px}.ghost-btn{padding:.55rem .9rem;border-radius:999px;color:var(--text-muted);font-weight:600}.ghost-btn:hover{background:var(--surface-muted);color:var(--text)}.avatar-pill{width:36px;height:36px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:#fff}.app-shell{display:flex;min-height:calc(100vh - 64px)}.sidebar{width:250px;flex:none;background:linear-gradient(180deg,var(--surface-elevated),var(--surface));border-right:1px solid var(--border);padding:18px 12px;overflow-y:auto}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:10px 12px 20px}.sidebar-brand-mark{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;color:#fff}.sidebar-brand-title{font-weight:700;font-size:.95rem}.sidebar-brand-subtitle{font-size:.78rem;color:var(--text-muted)}.nav-item{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;padding:10px 12px;border-radius:12px;font-size:.92rem;font-weight:600;color:var(--text-muted);margin-bottom:4px;transition:background .14s ease,color .14s ease}.nav-item:hover{background:var(--surface-muted);color:var(--text)}.nav-item.is-active{background:rgba(37,99,235,.12);color:var(--primary)}.nav-item.is-active .dot{background:var(--accent)}.nav-item .dot{width:6px;height:6px;border-radius:999px;margin-right:8px;background:var(--border-strong);flex:none}.nav-section-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;margin:18px 12px 6px}.nav-frac,.nav-section-label{color:var(--text-muted);font-weight:700}.nav-frac{font-size:.74rem;background:var(--surface-muted);border-radius:999px;padding:2px 8px;flex:none}.nav-item.has-live .nav-frac{color:var(--primary)}.main{flex:1 1;min-width:0;overflow-y:auto;background:linear-gradient(180deg,transparent,rgba(37,99,235,.03))}.panel{max-width:1120px;margin:0 auto;padding:32px 28px 80px}.search-wrap{position:relative;margin-bottom:28px}.search-wrap input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:13px 16px 13px 44px;color:var(--text);font-size:.95rem;box-shadow:var(--shadow-sm)}.search-wrap input:focus{border-color:var(--primary)}.search-wrap svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted)}.panel-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:4px;flex-wrap:wrap;gap:8px}.panel-head h1{font-size:1.35rem}.live-counter{font-size:.88rem;color:var(--primary);font-weight:700}.panel-sub{font-size:.95rem;margin:6px 0 24px;line-height:1.6}.breadcrumb,.panel-sub{color:var(--text-muted)}.breadcrumb{font-size:.9rem;margin-bottom:10px}.breadcrumb button{color:var(--primary);font-weight:600}.section-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700;margin:30px 0 12px}.hero-card{margin-bottom:24px;background:linear-gradient(135deg,var(--surface) 0,var(--surface-elevated) 100%)}.hero-grid{display:grid;grid-template-columns:1.4fr .8fr;grid-gap:20px;gap:20px;align-items:center}.hero-copy{margin:0 0 16px;color:var(--text-muted);line-height:1.7}.hero-metrics{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}.hero-metrics>div{background:var(--surface-muted);border:1px solid var(--border);border-radius:14px;padding:14px;text-align:center}.hero-metrics strong{display:block;font-size:1.15rem}.hero-metrics span{display:block;font-size:.78rem;color:var(--text-muted);margin-top:4px}.pinned-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:14px;gap:14px}@media (max-width:620px){.pinned-row{grid-template-columns:1fr}}.pinned-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:18px 18px 16px;display:flex;align-items:flex-start;gap:14px;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;width:100%;box-shadow:var(--shadow-sm)}.pinned-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:var(--shadow-md)}.pinned-icon{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex:none}.pinned-info .ptitle{font-size:14.5px;font-weight:700;margin-bottom:3px}.pinned-info .ptag{font-size:11.5px;color:var(--text-muted)}.pinned-info .pstatus{font-size:11px;color:var(--primary);font-weight:700;margin-top:6px;display:flex;align-items:center;gap:5px}.pinned-info .pstatus .pip{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(56,189,248,.16)}.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:14px;gap:14px}@media (max-width:620px){.cat-grid{grid-template-columns:1fr}}.cat-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:16px 17px;text-align:left;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease;width:100%;box-shadow:var(--shadow-sm)}.cat-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:var(--shadow-md)}.cat-top{gap:12px;margin-bottom:12px}.cat-badge,.cat-top{display:flex;align-items:center}.cat-badge{width:34px;height:34px;border-radius:10px;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:11.5px;background:var(--surface-muted);color:var(--text-muted);border:1px solid var(--border);flex:none}.cat-badge.live{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:none}.cat-name{font-size:14.5px;font-weight:700}.cat-count{font-size:11.5px;color:var(--text-muted);margin-top:1px}.cat-bar-track{height:4px;border-radius:999px;background:var(--surface-muted);overflow:hidden}.cat-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--accent))}.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}@media (max-width:760px){.tile-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:460px){.tile-grid{grid-template-columns:1fr}}.tile{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:15px 14px;text-align:left;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease;width:100%;box-shadow:var(--shadow-sm)}.tile-icon{width:30px;height:30px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:11.5px;margin-bottom:11px}.tile-name{font-size:13.5px;font-weight:700;margin-bottom:3px;line-height:1.3}.tile-cat{font-size:11px;color:var(--text-muted);margin-bottom:6px}.tile-status{font-size:10.5px;font-weight:700;letter-spacing:.03em;display:flex;align-items:center;gap:5px}.pip{width:6px;height:6px;border-radius:50%;flex:none}.tile.active{cursor:pointer}.tile.active .tile-icon{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff}.tile.active .pip{background:var(--accent);box-shadow:0 0 0 3px rgba(56,189,248,.18)}.tile.active .tile-status{color:var(--primary)}.tile.active:hover{transform:translateY(-3px);border-color:var(--primary);box-shadow:var(--shadow-md)}.tile.soon{opacity:.75;cursor:default;border-style:dashed}.tile.soon .tile-icon{background:var(--surface-muted);color:var(--text-muted);border:1px solid var(--border)}.tile.soon .pip{background:var(--border-strong)}.empty-note,.tile.soon .tile-status{color:var(--text-muted)}.empty-note{font-size:13px;padding:30px 0;text-align:center}.toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%,12px);background:var(--surface);border:1px solid var(--border);color:var(--text);padding:10px 18px;border-radius:999px;font-size:13px;opacity:0;transition:opacity .18s,transform .18s;pointer-events:none;z-index:50;box-shadow:var(--shadow-sm)}.toast.show{opacity:1;transform:translate(-50%)}@media (max-width:820px){.app-shell{flex-direction:column}.sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);display:flex;gap:6px;padding:12px;overflow-x:auto;white-space:nowrap}.nav-section-label{display:none}.nav-item{flex:none;margin-bottom:0}.hero-grid{grid-template-columns:1fr}.hero-metrics{grid-template-columns:repeat(3,1fr)}}@media (max-width:560px){.hero-metrics{grid-template-columns:1fr}}.module-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}.module-sub{font-size:.88rem;margin:4px 0 0}.back-link,.module-sub{color:var(--text-muted)}.back-link{display:inline-flex;align-items:center;gap:4px;font-size:.86rem;font-weight:600;margin-bottom:14px;padding:0;transition:color .14s ease}.back-link:hover{color:var(--primary)}.primary-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--primary);color:#fff;border:none;border-radius:8px;padding:9px 16px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s ease,box-shadow .15s ease;white-space:nowrap}.primary-btn:hover{background:var(--primary-strong);box-shadow:0 4px 14px rgba(37,99,235,.25)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4);box-shadow:var(--shadow-sm)}.stage-strip{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}.stage-card{flex:1 1 90px;min-width:80px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 12px;text-align:center;box-shadow:var(--shadow-sm)}.stage-card .num{font-size:1.35rem;font-weight:700;line-height:1;margin-bottom:5px;font-family:var(--font-display)}.stage-card .lbl{font-size:.72rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.contacts{width:100%;border-collapse:collapse;font-size:13.5px}.contacts th{text-align:left;padding:10px 12px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);white-space:nowrap}.contacts td,.contacts th{border-bottom:1px solid var(--border)}.contacts td{padding:11px 12px;vertical-align:middle}.contacts tbody tr:hover{background:var(--surface-muted)}.contacts tbody tr:last-child td{border-bottom:none}.ctag{display:inline-flex;align-items:center;font-size:11.5px;font-weight:600;padding:4px 8px;border-radius:6px;background:var(--surface-muted);color:var(--text-muted);cursor:pointer;margin-right:4px;border:none;transition:background .12s ease,color .12s ease}.ctag:hover{background:var(--border);color:var(--text)}.board{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px}@media (max-width:680px){.board{grid-template-columns:1fr}}.col-head{display:flex;align-items:center;justify-content:space-between;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);padding:0 2px;margin-bottom:10px}.ctitle{font-size:13px;font-weight:600;color:var(--text);line-height:1.4}.invoice-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:0;flex-wrap:wrap}.invoice-search{flex:1 1 220px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text);font-size:.88rem;transition:border-color .14s ease}.invoice-search:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.1)}.invoice-tabs{display:flex;border-bottom:1px solid var(--border);margin:14px 0 18px;gap:0}.invoice-tab{display:inline-flex;align-items:center;gap:7px;padding:10px 14px;font-size:.875rem;font-weight:600;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .14s ease,border-color .14s ease;margin-bottom:-1px;white-space:nowrap}.invoice-tab:hover{color:var(--text)}.invoice-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.invoice-tab-count{font-size:.72rem;font-weight:700;padding:2px 7px;border-radius:999px;background:var(--surface-muted);color:var(--text-muted);transition:background .14s ease,color .14s ease}.invoice-tab.active .invoice-tab-count{background:rgba(37,99,235,.14);color:var(--primary)}.module-area{padding:0 0 2rem}.module-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.module-title{font-size:1.15rem;font-weight:700}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));grid-gap:.75rem;gap:.75rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:.85rem 1rem}.stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.25rem}.stat-value{font-size:1.35rem;font-weight:700;color:var(--text)}.tab-bar{display:flex;gap:.25rem;border-bottom:2px solid var(--border)}.tab-btn{background:none;padding:.5rem 1rem;font-size:.82rem;font-weight:600;color:var(--text-muted);cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;display:flex;align-items:center;gap:.35rem;transition:color .12s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--danger);display:inline-block}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:.5rem;gap:.5rem;margin-bottom:.5rem}.form-input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .7rem;font-size:.82rem;color:var(--text);outline:none;transition:border-color .12s}.form-input:focus{border-color:var(--primary)}.table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border)}.data-table{width:100%;border-collapse:collapse;font-size:.82rem}.data-table th{background:var(--surface-muted);padding:.55rem .85rem;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);white-space:nowrap}.data-table td{padding:.65rem .85rem;border-top:1px solid var(--border);vertical-align:middle}.data-table tbody tr:hover,.status-badge{background:var(--surface-muted)}.status-badge{display:inline-flex;align-items:center;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:999px;color:var(--text-muted);text-transform:capitalize}.status-badge.active,.status-badge.approved,.status-badge.processed{background:rgba(22,163,74,.14);color:var(--success)}.status-badge.draft,.status-badge.pending{background:rgba(245,158,11,.14);color:var(--warning)}.status-badge.rejected,.status-badge.terminated{background:rgba(220,38,38,.14);color:var(--danger)}.status-badge.on-leave{background:rgba(37,99,235,.14);color:var(--primary)}.status-badge.full-time{background:rgba(37,99,235,.1);color:var(--primary)}.status-badge.part-time{background:rgba(139,92,246,.1);color:#7c3aed}.status-badge.contract{background:rgba(245,158,11,.1);color:var(--warning)}.status-badge.intern{background:var(--surface-muted);color:var(--text-muted)}.empty-state{text-align:center;color:var(--text-muted);font-size:.85rem;padding:2rem 0}.active-card{border-color:var(--primary)!important}.module-wrap{padding:0 0 2rem}.stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:.75rem;gap:.75rem;margin-bottom:1.25rem}.muted{color:var(--text-muted);font-size:.85rem}.accent-light{background:rgba(37,99,235,.06)}.success-bg{background:rgba(22,163,74,.08)}.danger-bg{background:rgba(220,38,38,.08)}.warning-bg{background:rgba(245,158,11,.08)}.accent-light{background:var(--accent-bg)}.tag{display:inline-block;background:var(--surface-muted);color:var(--text-muted);border-radius:4px;padding:1px 6px;font-size:.72rem;font-weight:600;margin-right:2px}.ctag.danger{background:rgba(220,38,38,.08);color:var(--danger)}.ctag.danger:hover{background:rgba(220,38,38,.16)}.ctag.success{background:rgba(22,163,74,.08);color:var(--success)}.ctag.success:hover{background:rgba(22,163,74,.16)}.empty-state-pro{flex-direction:column;text-align:center;padding:3rem 1.5rem;gap:.4rem}.empty-state-pro,.empty-state-pro .es-icon{display:flex;align-items:center;justify-content:center}.empty-state-pro .es-icon{width:52px;height:52px;border-radius:16px;background:var(--surface-muted);color:var(--text-muted);margin-bottom:.6rem;font-size:1.4rem}.empty-state-pro .es-title{font-size:.98rem;font-weight:700;color:var(--text)}.empty-state-pro .es-desc{font-size:.85rem;color:var(--text-muted);max-width:360px;line-height:1.55;margin:0}.empty-state-pro .es-action{margin-top:.85rem}@keyframes skeleton-shine{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton{background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-shine) 37%,var(--skeleton-base) 63%);background-size:400px 100%;animation:skeleton-shine 1.4s ease infinite;border-radius:var(--radius-sm);display:block}.skeleton-text{height:.85em;margin:.3em 0}.skeleton-row{height:42px;border-radius:var(--radius-sm);margin-bottom:8px}.skeleton-card{height:96px;border-radius:var(--radius-md)}.skeleton-stack{display:flex;flex-direction:column;gap:8px}.tooltip-wrap{position:relative;display:inline-flex}.tooltip-bubble{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(2px);background:var(--text);color:var(--bg);font-size:.74rem;font-weight:600;line-height:1.4;padding:6px 10px;border-radius:8px;white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;transition:opacity var(--transition-fast),transform var(--transition-fast);z-index:80;box-shadow:var(--shadow-sm)}html[data-theme=dark] .tooltip-bubble{background:var(--surface-elevated);color:var(--text);border:1px solid var(--border)}.tooltip-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top:5px solid var(--text)}html[data-theme=dark] .tooltip-bubble:after{border-top-color:var(--surface-elevated)}.tooltip-wrap:focus-within .tooltip-bubble,.tooltip-wrap:hover .tooltip-bubble{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}.menu-wrap{position:relative;display:inline-flex}.menu-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:190px;z-index:75;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:6px;animation:menu-pop .14s var(--ease)}.menu-panel.align-left{right:auto;left:0}@keyframes menu-pop{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.menu-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 10px;font-size:.85rem;font-weight:600;color:var(--text);border-radius:8px;transition:background var(--transition-fast)}.menu-item:hover{background:var(--surface-muted)}.menu-item.danger{color:var(--danger)}.menu-item.danger:hover{background:var(--danger-bg)}.menu-item:disabled{opacity:.5;cursor:not-allowed}.menu-sep{height:1px;background:var(--border);margin:5px 2px}.pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:14px;flex-wrap:wrap}.pagination-info{font-size:.8rem;color:var(--text-muted)}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-btn{min-width:30px;height:30px;padding:0 8px;border-radius:8px;font-size:.8rem;font-weight:700;color:var(--text-muted);transition:background var(--transition-fast),color var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--surface-muted);color:var(--text)}.pagination-btn.active{background:var(--primary);color:#fff}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.modal-card.danger .modal-title{color:var(--danger)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.field-select,.field-textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.8rem .95rem;color:var(--text);font-size:.95rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.field-select:focus,.field-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,.12);outline:none}.field-textarea{resize:vertical;min-height:90px;font-family:inherit}.toolbar-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}.toolbar-search{position:relative;flex:1 1 220px}.toolbar-search input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px 9px 34px;font-size:.86rem;color:var(--text);transition:border-color var(--transition-fast)}.toolbar-search input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.1)}.toolbar-search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--text-muted);pointer-events:none}.toolbar-select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;font-size:.84rem;color:var(--text)}.bulk-bar{justify-content:space-between;gap:12px;flex-wrap:wrap;background:rgba(37,99,235,.08);border:1px solid rgba(37,99,235,.25);border-radius:var(--radius-sm);padding:9px 14px;margin-bottom:12px;font-size:.84rem;font-weight:600;color:var(--primary);animation:menu-pop .14s var(--ease)}.bulk-bar,.bulk-bar-actions{display:flex;align-items:center}.bulk-bar-actions{gap:6px}.row-checkbox{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.th-sort{display:inline-flex;align-items:center;gap:4px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.th-sort:hover{color:var(--text)}.th-sort .sort-caret{font-size:.65rem;opacity:.5}.th-sort.active .sort-caret{opacity:1;color:var(--primary)}.bell-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;color:var(--text-muted);transition:background var(--transition-fast),color var(--transition-fast)}.bell-btn:hover{background:var(--surface-muted);color:var(--text)}.bell-dot{position:absolute;top:4px;right:4px;min-width:16px;height:16px;border-radius:8px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:340px;max-height:440px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:80;animation:menu-pop .14s var(--ease)}.notif-head,.notif-panel{background:var(--surface)}.notif-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0}.notif-head-title{font-weight:700;font-size:.88rem}.notif-mark-all{font-size:.78rem;color:var(--primary);font-weight:600}.notif-mark-all:hover{text-decoration:underline}.notif-empty{padding:28px 16px;text-align:center;color:var(--text-muted);font-size:.84rem}.notif-item{width:100%;display:flex;gap:12px;padding:12px 16px;border:none;border-bottom:1px solid var(--border);text-align:left;transition:background var(--transition-fast)}.notif-item:hover{background:var(--surface-muted)}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:var(--accent-bg)}.notif-item.unread:hover{background:rgba(56,189,248,.14)}.notif-dot{width:8px;height:8px;border-radius:50%;flex:none;margin-top:5px;background:var(--border-strong)}.notif-item.unread .notif-dot{background:var(--accent)}.notif-body{flex:1 1;min-width:0}.notif-title{font-size:.84rem;color:var(--text);line-height:1.4;margin-bottom:2px;font-weight:400}.notif-item.unread .notif-title{font-weight:700}.notif-desc{font-size:.78rem;color:var(--text-muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-time{font-size:.72rem;color:var(--text-muted);margin-top:4px}.sidebar-backdrop,.sidebar-toggle{display:none}@media (max-width:820px){.sidebar-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;color:var(--text-muted)}.sidebar-toggle:hover{background:var(--surface-muted);color:var(--text)}.app-shell .sidebar{position:fixed;top:64px;left:0;bottom:0;width:250px;z-index:45;flex-direction:column;overflow-y:auto;overflow-x:hidden;white-space:normal;transform:translateX(-100%);transition:transform var(--transition-base);box-shadow:var(--shadow-md)}.app-shell.nav-open .sidebar{transform:translateX(0)}.app-shell .nav-section-label{display:block}.app-shell .nav-item{flex:none;margin-bottom:4px}.sidebar-backdrop.show{display:block;position:fixed;inset:64px 0 0 0;background:rgba(2,6,23,.45);z-index:40;animation:menu-pop .14s var(--ease)}}