:root{--bg:#f3f6fb;--panel:rgba(255,255,255,.86);--text:#101828;--muted:#667085;--line:rgba(16,24,40,.12);--brand:#3153a4;--brand2:#20a98a;--danger:#c53030;--warn:#b7791f;--ok:#208a5a;--shadow:0 22px 70px rgba(31,49,91,.13);--radius:24px}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:radial-gradient(circle at 10% 0%,rgba(49,83,164,.16),transparent 30%),radial-gradient(circle at 90% 10%,rgba(34,168,137,.12),transparent 36%),var(--bg);color:var(--text)}a{color:inherit}.app{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:24px;border-right:1px solid var(--line);background:rgba(255,255,255,.72);backdrop-filter:blur(18px)}.brand{display:flex;align-items:center;gap:12px;margin-bottom:26px;text-decoration:none}.brand-mark{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;font-weight:900}.brand-title{font-size:19px;font-weight:900;letter-spacing:-.04em}.brand-sub{font-size:12px;color:var(--muted)}.nav{display:grid;gap:6px}.nav a,.nav button{width:100%;display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:15px;border:0;background:transparent;color:#344054;text-decoration:none;text-align:left;font-weight:750;cursor:pointer}.nav a:hover,.nav a.active,.nav button:hover{background:rgba(49,83,164,.10);color:var(--brand)}.main{padding:28px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px}.page-title h1{font-size:34px;line-height:1.05;letter-spacing:-.055em;margin:0}.page-title p{margin:8px 0 0;color:var(--muted)}.userbox{display:flex;align-items:center;gap:12px}.avatar{width:42px;height:42px;border-radius:16px;background:#dbe6ff;display:grid;place-items:center;font-weight:900;color:var(--brand);overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.panel{background:var(--panel);border:1px solid rgba(255,255,255,.9);box-shadow:var(--shadow);border-radius:var(--radius);padding:22px}.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:rgba(255,255,255,.72);border:1px solid var(--line);border-radius:20px;padding:18px;text-decoration:none}.card:hover{box-shadow:0 16px 42px rgba(31,49,91,.10)}.metric{font-size:34px;font-weight:900;letter-spacing:-.05em}.muted{color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800;background:rgba(49,83,164,.10);color:var(--brand)}.badge.ok{background:rgba(32,138,90,.12);color:var(--ok)}.badge.warn{background:rgba(183,121,31,.12);color:var(--warn)}.badge.danger{background:rgba(197,48,48,.12);color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:14px;border:1px solid var(--line);background:#fff;color:#1f2937;font-weight:800;text-decoration:none;cursor:pointer}.btn.primary{background:linear-gradient(135deg,var(--brand),#4471d6);color:#fff;border:0}.btn.danger{background:#fff5f5;color:var(--danger)}.btn.small{padding:7px 10px;border-radius:12px;font-size:13px}.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.form{display:grid;gap:16px}.field{display:grid;gap:7px}.field label{font-weight:800;font-size:14px}.input,select,textarea{width:100%;border:1px solid var(--line);border-radius:14px;background:#fff;padding:11px 13px;font:inherit;color:var(--text)}textarea{min-height:130px;resize:vertical}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.table th{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.alert{padding:14px 16px;border-radius:18px;margin-bottom:18px;background:#eef6ff;border:1px solid #cfe3ff}.alert.success{background:#edfdf5;border-color:#c6f1dc}.alert.error{background:#fff5f5;border-color:#fed7d7}.alert.warning{background:#fffaf0;border-color:#fbd38d}.progress{height:10px;border-radius:999px;background:#e5e7eb;overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--brand2))}.content{line-height:1.75}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(500px,100%)}.certificate{background:#fff;border:16px solid #eef3ff;border-radius:28px;padding:48px;text-align:center}.certificate h1{font-size:44px;letter-spacing:-.06em}.pagination{display:flex;gap:8px;list-style:none;padding:0}.pagination a,.pagination span{display:block;padding:8px 12px;border-radius:12px;background:#fff;border:1px solid var(--line);text-decoration:none}@media(max-width:980px){.app{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.main{padding:18px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.topbar{align-items:flex-start;flex-direction:column}}@media print{.sidebar,.topbar,.actions,.btn{display:none!important}.app{display:block}.main{padding:0}.panel{box-shadow:none;border:0}.certificate{border:12px solid #000}}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:22px}.page-head h1{margin:0;font-size:34px;line-height:1.05;letter-spacing:-.055em}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--brand);font-weight:900;margin-bottom:8px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-grid label,.stack label{display:grid;gap:7px}.form-grid label>span,.stack label>span{font-size:14px;font-weight:850;color:#344054}.form-grid .full,.full{grid-column:1/-1}.check{display:flex!important;align-items:center;gap:10px}.check input{width:auto}.compact{gap:6px;font-size:13px}.table-wrap{overflow:auto}.right{text-align:right!important}.status{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:850;background:#eef2ff;color:var(--brand)}.status.published,.status.completed,.status.active{background:rgba(32,138,90,.12);color:var(--ok)}.status.draft,.status.pending,.status.in_progress{background:rgba(183,121,31,.12);color:var(--warn)}.status.overdue,.status.failed{background:rgba(197,48,48,.12);color:var(--danger)}.stack{display:grid;gap:14px}.mini-card{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.72);padding:16px}.between{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.plain-list{margin:12px 0 0;padding-left:0;list-style:none;display:grid;gap:8px}.inline-form{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:12px}.inline-form input{width:auto;min-width:220px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:10px 12px;font:inherit}.small-input{min-width:80px!important;width:90px!important}.btn.sm{padding:7px 10px;border-radius:12px;font-size:13px}.mt{margin-top:18px}.mb{margin-bottom:18px}.mt-sm{margin-top:10px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.note{padding:12px 14px;border-radius:16px;background:#f8fafc;border:1px solid var(--line);color:var(--muted)}.chips{display:flex;gap:8px;flex-wrap:wrap}.chips span{display:inline-flex;border-radius:999px;background:#eef2ff;color:var(--brand);font-weight:800;font-size:12px;padding:6px 10px}small{color:var(--muted);line-height:1.4}.course-cover{width:100%;height:160px;border-radius:18px;object-fit:cover;background:#eef2ff}.empty{padding:32px;border-radius:20px;border:1px dashed var(--line);text-align:center;color:var(--muted)}.timeline{display:grid;gap:10px}.timeline article{padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.62);display:flex;justify-content:space-between;gap:12px}@media(max-width:760px){.page-head{flex-direction:column}.form-grid,.grid.two{grid-template-columns:1fr}.inline-form input{width:100%;min-width:0}.timeline article{display:grid}}

/* === LMS EPA mobile off-canvas navigation === */
.mobile-shell-bar,
.sidebar-backdrop,
.sidebar-close {
    display: none;
}

.sidebar-head {
    display: block;
}

@media (max-width: 980px) {
    .mobile-shell-bar {
        position: sticky;
        top: 0;
        z-index: 70;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 14px;
        min-height: 68px;
        padding: 10px 14px;
        border-bottom: 1px solid var(--line);
        background: rgba(255, 255, 255, .82);
        backdrop-filter: blur(18px);
        box-shadow: 0 14px 34px rgba(31, 49, 91, .08);
    }

    .mobile-brand {
        display: inline-flex;
        align-items: center;
        gap: 10px;
        min-width: 0;
        color: var(--text);
        text-decoration: none;
    }

    .mobile-brand .brand-mark {
        width: 42px;
        height: 42px;
        border-radius: 15px;
        flex: 0 0 auto;
        font-size: 16px;
    }

    .mobile-brand strong {
        display: block;
        font-size: 16px;
        line-height: 1.1;
        font-weight: 950;
        letter-spacing: -.04em;
        white-space: nowrap;
    }

    .mobile-brand small {
        display: block;
        max-width: 185px;
        margin-top: 2px;
        overflow: hidden;
        color: var(--muted);
        font-size: 11px;
        line-height: 1.2;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .menu-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        min-height: 44px;
        padding: 9px 13px;
        border: 1px solid rgba(49, 83, 164, .18);
        border-radius: 16px;
        background: rgba(255, 255, 255, .78);
        color: var(--brand);
        font: inherit;
        font-weight: 900;
        cursor: pointer;
        box-shadow: 0 12px 30px rgba(31, 49, 91, .08);
        -webkit-tap-highlight-color: transparent;
    }

    .menu-toggle span {
        display: block;
        width: 17px;
        height: 2px;
        border-radius: 999px;
        background: currentColor;
    }

    .menu-toggle b {
        font-size: 14px;
    }

    .menu-toggle:focus {
        outline: none;
    }

    .menu-toggle:focus-visible {
        outline: 3px solid rgba(49, 83, 164, .22);
        outline-offset: 2px;
    }

    .app {
        display: block;
        min-height: auto;
    }

    .sidebar {
        position: fixed !important;
        inset: 0 0 0 auto;
        z-index: 90;
        width: min(360px, calc(100vw - 34px));
        height: 100dvh !important;
        max-height: 100dvh;
        padding: 18px;
        overflow-y: auto;
        border-left: 1px solid rgba(16, 24, 40, .14);
        border-right: 0;
        background: rgba(255, 255, 255, .94);
        box-shadow: -26px 0 70px rgba(15, 23, 42, .22);
        transform: translateX(105%);
        transition: transform .24s ease;
        overscroll-behavior: contain;
    }

    body.menu-open .sidebar {
        transform: translateX(0);
    }

    .sidebar-backdrop {
        position: fixed;
        inset: 0;
        z-index: 80;
        display: block;
        pointer-events: none;
        background: rgba(15, 23, 42, 0);
        transition: background .24s ease;
    }

    body.menu-open .sidebar-backdrop {
        pointer-events: auto;
        background: rgba(15, 23, 42, .42);
    }

    .sidebar-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        margin-bottom: 22px;
    }


    .sidebar-title {
        display: block;
        color: var(--text);
        font-size: 24px;
        line-height: 1.1;
        font-weight: 950;
        letter-spacing: -.04em;
    }


    .sidebar-head .brand {
        min-width: 0;
        margin-bottom: 0;
    }

    .sidebar-close {
        display: grid;
        place-items: center;
        width: 42px;
        height: 42px;
        flex: 0 0 auto;
        border: 1px solid var(--line);
        border-radius: 15px;
        background: rgba(255, 255, 255, .78);
        color: #344054;
        font-size: 28px;
        line-height: 1;
        cursor: pointer;
        -webkit-tap-highlight-color: transparent;
    }

    .sidebar-close:focus {
        outline: none;
    }

    .sidebar-close:focus-visible {
        outline: 3px solid rgba(49, 83, 164, .22);
        outline-offset: 2px;
    }

    .nav {
        gap: 8px;
        padding-bottom: 20px;
    }

    .nav a,
    .nav button {
        min-height: 46px;
        padding: 12px 14px;
        border-radius: 16px;
        font-size: 15px;
    }

    .main {
        padding: 18px;
    }

    .topbar {
        margin-bottom: 18px;
    }

    .page-title h1 {
        font-size: 30px;
    }
}

@media (max-width: 430px) {
    .mobile-brand small {
        max-width: 145px;
    }

    .menu-toggle b {
        display: none;
    }

    .menu-toggle {
        width: 46px;
        padding-inline: 0;
        flex-direction: column;
        gap: 4px;
    }

    .menu-toggle span {
        width: 18px;
    }

    .main {
        padding: 14px;
    }
}
/* === /LMS EPA mobile off-canvas navigation === */


.sidebar-title {
    display: none;
}


/* === HARD FIX: mobile menu header === */
.sidebar-title {
    display: none;
}

@media (max-width: 980px) {
    .sidebar .sidebar-head {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 16px !important;
        width: 100% !important;
        margin: 0 0 22px 0 !important;
        padding: 0 !important;
    }

    .sidebar .sidebar-title {
        display: block !important;
        min-width: 0 !important;
        color: var(--text) !important;
        font-size: 26px !important;
        line-height: 1.1 !important;
        font-weight: 950 !important;
        letter-spacing: -.05em !important;
    }

    .sidebar .sidebar-close {
        display: grid !important;
        place-items: center !important;
        width: 44px !important;
        height: 44px !important;
        margin-left: auto !important;
        flex: 0 0 44px !important;
        border: 1px solid var(--line) !important;
        border-radius: 16px !important;
        background: rgba(255, 255, 255, .82) !important;
        color: #344054 !important;
        font-size: 28px !important;
        line-height: 1 !important;
        cursor: pointer !important;
    }
}
/* === /HARD FIX: mobile menu header === */
