:root{--bg:#f5f7fb;--card:#fff;--text:#182235;--muted:#7b8498;--navy:#111b35;--blue:#2563eb;--green:#16a34a;--red:#dc2626;--orange:#f97316;--yellow:#eab308;--border:#e8ecf4;--shadow:0 12px 30px rgba(15,23,42,.07);--radius:16px}*{box-sizing:border-box}body{margin:0;font-family:Inter,Poppins,Arial,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{width:270px;background:var(--navy);color:#fff;display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;padding:22px}.brand{display:flex;align-items:center;gap:12px;color:#fff}.brand-mark{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,#3b82f6,#06b6d4);display:grid;place-items:center;font-size:24px;font-weight:900}.brand span{display:block;font-size:12px;color:#aab4c8}.company-box{margin:18px 0;padding:14px;border:1px solid rgba(255,255,255,.11);border-radius:14px;background:rgba(255,255,255,.06);font-size:13px}.nav-menu{display:flex;flex-direction:column;gap:4px;overflow:auto}.nav-menu a{padding:11px 12px;border-radius:12px;color:#dce6f7;display:flex;gap:10px;align-items:center;font-size:14px}.nav-menu a:hover{background:rgba(255,255,255,.09);color:#fff}.sidebar-footer{margin-top:auto;color:#aab4c8;font-size:12px}.logout-link{display:block;padding:11px 12px;background:rgba(239,68,68,.16);color:#fff;border-radius:12px;margin-bottom:16px}.main-content{margin-left:270px;width:calc(100% - 270px);padding:28px}.topbar{display:flex;justify-content:space-between;gap:20px;align-items:center;margin-bottom:24px}.topbar h1{font-size:28px;margin:0}.topbar p{margin:6px 0 0;color:var(--muted)}.topbar-actions{display:flex;align-items:center;gap:12px}.notif-pill,.user-mini{background:#fff;border:1px solid var(--border);border-radius:999px;padding:10px 14px;box-shadow:var(--shadow)}.user-mini{border-radius:14px}.user-mini span{display:block;color:var(--muted);font-size:12px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:20px}.stats-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;margin-bottom:20px}.stat-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:20px;box-shadow:var(--shadow)}.stat-card span{display:block;color:var(--muted);font-size:13px}.stat-card strong{font-size:30px;display:block;margin-top:8px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.field label{display:block;margin-bottom:7px;font-weight:700;font-size:13px}.field input,.field select,.field textarea,.inline-form input{width:100%;border:1px solid var(--border);border-radius:12px;padding:12px 13px;font:inherit;background:#fff}.field.full,.full{grid-column:1/-1}.form-actions{display:flex;gap:10px;align-items:center}.btn{border:1px solid var(--border);background:#fff;border-radius:12px;padding:11px 15px;font-weight:700;cursor:pointer;display:inline-block}.btn-sm{padding:8px 10px;font-size:12px}.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff}.btn-success{background:var(--green);border-color:var(--green);color:#fff}.btn-danger{background:var(--red);border-color:var(--red);color:#fff}.btn-warning{background:var(--orange);border-color:var(--orange);color:#fff}.btn-info{background:#0891b2;border-color:#0891b2;color:#fff}.btn-block{width:100%;margin-top:16px}.toolbar{display:flex;justify-content:flex-end;margin-bottom:14px;gap:10px}.table-card{overflow:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:14px 12px;border-bottom:1px solid var(--border);vertical-align:top;text-align:left}.table th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.table small{color:var(--muted)}.badge{display:inline-flex;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800}.badge-muted{background:#eef2f7;color:#64748b}.badge-primary{background:#dbeafe;color:#1d4ed8}.badge-warning{background:#fef3c7;color:#a16207}.badge-success{background:#dcfce7;color:#15803d}.badge-info{background:#cffafe;color:#0e7490}.badge-orange{background:#ffedd5;color:#c2410c}.badge-danger{background:#fee2e2;color:#b91c1c}.badge-darkred{background:#7f1d1d;color:#fff}.empty{color:var(--muted);text-align:center;padding:20px}.meta-list{display:grid;gap:12px}.meta-list div{display:flex;justify-content:space-between;border-bottom:1px dashed var(--border);padding-bottom:10px}.meta-list span{color:var(--muted)}.timeline{display:grid;gap:10px}.evidence-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.evidence{display:block;border:1px solid var(--border);border-radius:14px;padding:14px;background:#f8fafc}.evidence span,.evidence small{display:block;color:var(--muted);word-break:break-word}.alert{padding:12px 14px;border-radius:14px;margin-bottom:16px}.alert-success{background:#dcfce7;color:#15803d}.alert-danger{background:#fee2e2;color:#b91c1c}.notification-list{display:grid;gap:12px}.notification-item{padding:16px;border:1px solid var(--border);border-radius:14px;background:#fff}.notification-item.unread{border-color:#93c5fd;background:#eff6ff}.feedback-admin{padding:18px;border:1px solid var(--border);border-radius:16px;margin-bottom:14px}.reply-box{margin-top:10px;padding:12px;border-radius:12px;background:#f1f5f9}.rank-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}.rank{font-weight:900;color:var(--blue)}.login-body{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#0f172a,#1d4ed8)}.login-card{width:min(440px,92vw);background:#fff;border-radius:24px;padding:34px;box-shadow:0 25px 70px rgba(0,0,0,.25)}.login-logo{width:70px;height:70px;border-radius:22px;background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;display:grid;place-items:center;font-weight:900;margin:auto}.login-card h1{text-align:center;font-size:24px;margin:18px 0 6px}.login-card p{text-align:center;color:var(--muted);margin:0 0 22px}.login-card label{font-weight:800;font-size:13px;margin:13px 0 7px;display:block}.login-card input{width:100%;padding:13px;border:1px solid var(--border);border-radius:12px}.login-card footer{text-align:center;color:var(--muted);font-size:12px;margin-top:22px}.footer{display:flex;justify-content:space-between;color:var(--muted);font-size:12px;margin-top:24px}.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}.check-grid label{padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff}.inline-form{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.mt-2{margin-top:14px}.warning-card{border-color:#fed7aa;background:#fff7ed}.recurring-only,.recurring-weekly,.recurring-monthly{display:none}@media(max-width:1000px){.sidebar{position:static;width:100%;min-height:auto}.app-shell{display:block}.main-content{margin-left:0;width:100%;padding:16px}.stats-grid,.grid-2,.form-grid{grid-template-columns:1fr}.topbar{display:block}.topbar-actions{margin-top:12px}.footer{display:block}.table{min-width:760px}}

/* EPMS v1.1.0 - PWA Push + Mobile Burger Drawer */
.menu-toggle{display:none;border:0;background:#fff;border:1px solid var(--border);border-radius:14px;width:44px;height:44px;font-size:22px;font-weight:900;box-shadow:var(--shadow);cursor:pointer}.topbar-title{display:flex;align-items:center;gap:14px}.push-btn{white-space:nowrap}.push-btn:disabled{opacity:.72;cursor:default}.remember-line{display:flex!important;align-items:center;gap:9px;margin-top:12px!important;font-weight:700!important;color:var(--text)}.remember-line input{width:auto!important}.sidebar-backdrop{display:none}.install-hint{font-size:12px;color:var(--muted);margin-top:7px}
@media(max-width:1000px){
  body.sidebar-open{overflow:hidden}.app-shell{display:block}.sidebar{position:fixed!important;top:0;left:0;bottom:0;width:min(84vw,310px)!important;min-height:100vh!important;z-index:1000;transform:translateX(-105%);transition:transform .24s ease;box-shadow:20px 0 45px rgba(15,23,42,.22);padding:20px!important}.sidebar.open{transform:translateX(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;background:rgba(15,23,42,.45);opacity:0;pointer-events:none;transition:.2s;z-index:999}.sidebar-open .sidebar-backdrop{opacity:1;pointer-events:auto}.menu-toggle{display:grid;place-items:center;flex:0 0 auto}.main-content{margin-left:0!important;width:100%!important;padding:14px!important}.topbar{display:flex!important;align-items:flex-start;justify-content:space-between;gap:12px;background:rgba(245,247,251,.94);position:sticky;top:0;z-index:100;padding:10px 0 14px;margin-bottom:12px;backdrop-filter:blur(8px)}.topbar h1{font-size:20px;line-height:1.15}.topbar p{font-size:12px;margin-top:4px}.topbar-actions{margin-top:0!important;gap:8px;flex-wrap:wrap;justify-content:flex-end}.notif-pill{padding:9px 11px}.user-mini{display:none}.push-btn{padding:9px 10px;font-size:11px}.stats-grid,.grid-2,.form-grid{grid-template-columns:1fr!important}.card{padding:16px;border-radius:16px}.stat-card{padding:16px}.stat-card strong{font-size:24px}.toolbar{justify-content:flex-start;flex-wrap:wrap}.table-card{margin-left:-4px;margin-right:-4px}.footer{display:block;text-align:center;line-height:1.8}.login-card{padding:26px}.login-card h1{font-size:21px}.brand{padding-right:32px}.nav-menu{max-height:calc(100vh - 210px)}}
@media(max-width:520px){.topbar{display:block!important}.topbar-title{align-items:flex-start}.topbar-actions{margin-top:10px!important;justify-content:flex-start}.push-btn{width:auto}.card h2{font-size:20px}.inline-form{display:block}.inline-form>*{margin-bottom:10px}.form-actions{flex-wrap:wrap}.btn{width:auto}.check-grid{grid-template-columns:1fr}.meta-list div{display:block}.meta-list strong{display:block;margin-top:4px}}

/* EPMS v1.1.1 - Mobile/PWA Fix */
.pwa-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.58);z-index:3000;display:grid;place-items:center;padding:18px;backdrop-filter:blur(8px)}
.pwa-modal-backdrop[hidden]{display:none!important}.pwa-modal-open{overflow:hidden}.pwa-modal-card{width:min(440px,94vw);background:#fff;border-radius:26px;padding:26px;box-shadow:0 30px 90px rgba(15,23,42,.32);position:relative;text-align:center;border:1px solid rgba(255,255,255,.4)}
.pwa-modal-close{position:absolute;right:14px;top:12px;width:36px;height:36px;border:0;border-radius:999px;background:#f1f5f9;color:#334155;font-size:24px;line-height:1;cursor:pointer}.pwa-modal-icon{width:78px;height:78px;margin:0 auto 16px;border-radius:24px;background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;display:grid;place-items:center;font-weight:900;letter-spacing:.04em;box-shadow:0 18px 30px rgba(37,99,235,.28)}
.pwa-modal-card h2{margin:0 0 10px;font-size:24px}.pwa-modal-card p{margin:0 0 18px;color:var(--muted);line-height:1.55}.pwa-modal-actions{display:grid;gap:10px;margin:14px 0}.pwa-modal-actions .btn{width:100%;text-align:center}.pwa-modal-note{margin-top:12px;background:#f8fafc;border:1px dashed var(--border);border-radius:16px;padding:12px;color:#64748b;font-size:13px;line-height:1.45}.pwa-later{margin-top:12px;border:0;background:transparent;color:#64748b;font-weight:800;cursor:pointer;padding:8px 10px}
.sidebar{height:100vh;height:100dvh;overflow:hidden}.nav-menu{flex:1;min-height:0}.sidebar-footer{flex-shrink:0;padding-bottom:max(12px,env(safe-area-inset-bottom));background:linear-gradient(180deg,rgba(17,27,53,0),var(--navy) 18%)}
@media(max-width:1000px){.sidebar{height:100dvh!important;overflow:hidden!important}.nav-menu{flex:1!important;min-height:0!important;max-height:none!important;overflow:auto!important;padding-bottom:8px}.sidebar-footer{position:relative!important;flex-shrink:0!important;margin-top:12px!important;padding-top:10px!important;padding-bottom:max(18px,calc(env(safe-area-inset-bottom) + 14px))!important}.logout-link{margin-bottom:10px!important}.pwa-modal-card{padding:24px 20px}.pwa-modal-card h2{font-size:22px}.pwa-modal-icon{width:68px;height:68px;border-radius:22px}.topbar-actions .push-btn{display:none}.topbar-actions{align-items:center}.notif-pill{box-shadow:none}.topbar{padding-bottom:10px!important}}
@media(max-width:520px){.pwa-modal-backdrop{align-items:end;padding:10px}.pwa-modal-card{width:100%;border-radius:24px 24px 18px 18px;padding:24px 18px 18px}.pwa-modal-card h2{font-size:21px}.pwa-modal-card p{font-size:14px}.pwa-modal-note{font-size:12px}.pwa-modal-actions{gap:9px}.topbar-title{width:100%}.topbar-actions{width:100%}.notif-pill{padding:8px 11px}.menu-toggle{width:42px;height:42px}.main-content{padding-bottom:max(24px,env(safe-area-inset-bottom))!important}}
