@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');
:root{--primary:#0f4c81;--primary-light:#1a6bb5;--accent:#f97316;--success:#16a34a;--danger:#dc2626;--warning:#d97706;--info:#0891b2;--sidebar-bg:#0d1b2a;--sidebar-width:260px;--topbar-height:64px;--body-bg:#f0f4f8;--border:#e2e8f0;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow:0 4px 6px -1px rgba(0,0,0,.08);--transition:all .22s cubic-bezier(.4,0,.2,1)}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--body-bg);color:var(--text-primary);font-size:14px;line-height:1.6}
.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--sidebar-bg);z-index:1000;overflow-y:auto;overflow-x:hidden;transition:var(--transition);display:flex;flex-direction:column}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:99px}
.sidebar-brand{display:flex;align-items:center;gap:12px;padding:20px;border-bottom:1px solid rgba(255,255,255,.07);text-decoration:none}
.sidebar-brand .brand-icon{width:40px;height:40px;background:linear-gradient(135deg,#f97316,#ef4444);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex-shrink:0;box-shadow:0 4px 12px rgba(249,115,22,.35)}
.sidebar-brand .brand-text{color:#fff;font-weight:700;font-size:15px;line-height:1.2}
.sidebar-brand .brand-text span{display:block;font-size:10px;font-weight:400;color:rgba(255,255,255,.45);letter-spacing:1px;text-transform:uppercase}
.sidebar-nav{padding:12px 0;flex:1}
.nav-section-label{padding:16px 20px 6px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.28)}
.nav-item{position:relative}
.nav-link{display:flex;align-items:center;gap:12px;padding:10px 20px;color:rgba(255,255,255,.6);text-decoration:none;font-size:13.5px;font-weight:500;transition:var(--transition);cursor:pointer}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav-link.active{color:#fff;background:linear-gradient(90deg,rgba(249,115,22,.18),transparent);border-left:3px solid #f97316}
.nav-link .nav-icon{width:18px;font-size:15px;flex-shrink:0}
.nav-submenu{display:none;background:rgba(0,0,0,.2)}
.nav-submenu.show{display:block}
.nav-submenu .nav-link{padding:8px 20px 8px 50px;font-size:13px}
.nav-link .arrow{margin-left:auto;font-size:11px;transition:var(--transition)}
.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.07)}
.sidebar-user{display:flex;align-items:center;gap:10px}
.sidebar-user .user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#1a6bb5,#0f4c81);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}
.sidebar-user .user-info{flex:1;min-width:0}
.sidebar-user .user-name{color:#fff;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user .user-role{color:rgba(255,255,255,.4);font-size:11px}
.sidebar-user .user-logout{color:rgba(255,255,255,.4);font-size:14px;text-decoration:none;transition:var(--transition)}
.sidebar-user .user-logout:hover{color:#dc2626}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;backdrop-filter:blur(2px)}
.sidebar-overlay.show{display:block}
.main-content{margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:var(--transition)}
.topbar{height:var(--topbar-height);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:900;box-shadow:var(--shadow-sm)}
.topbar-toggle{display:none;width:38px;height:38px;border:none;background:var(--body-bg);border-radius:var(--radius-sm);font-size:16px;cursor:pointer;align-items:center;justify-content:center;transition:var(--transition);color:var(--text-primary)}
.topbar-toggle:hover{background:var(--border)}
.topbar-search{flex:1;max-width:380px}
.topbar-search .form-control{background:var(--body-bg);border:1.5px solid transparent;border-radius:99px;padding:8px 16px 8px 40px;font-size:13px;font-family:inherit;transition:var(--transition)}
.topbar-search .form-control:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(15,76,129,.1)}
.topbar-search-wrap{position:relative}
.topbar-search-wrap .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:13px}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.topbar-btn{width:38px;height:38px;border:none;background:var(--body-bg);border-radius:var(--radius-sm);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:var(--transition);color:var(--text-secondary);text-decoration:none}
.topbar-btn:hover{background:var(--primary);color:#fff}
.topbar-btn .badge-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid #fff}
.topbar-divider{width:1px;height:28px;background:var(--border);margin:0 4px}
.topbar-user{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm);transition:var(--transition)}
.topbar-user:hover{background:var(--body-bg)}
.topbar-user .user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#1a6bb5,#0f4c81);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:12px}
.topbar-user .user-name{font-size:13px;font-weight:600;color:var(--text-primary)}
.topbar-user .user-role{font-size:11px;color:var(--text-muted)}
.page-content{padding:24px;flex:1}
.page-header{margin-bottom:24px}
.page-title{font-size:22px;font-weight:800;color:var(--text-primary);margin-bottom:2px}
.page-subtitle{color:var(--text-muted);font-size:13px}
.page-header-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.breadcrumb-nav{margin-bottom:6px}
.breadcrumb{font-size:12px;margin:0}
.breadcrumb-item a{color:var(--primary);text-decoration:none}
.breadcrumb-item.active{color:var(--text-muted)}
.card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}
.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;background:#fff}
.card-title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0}
.card-body{padding:20px}
.stat-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:20px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:var(--transition)}
.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.stat-card .stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px}
.stat-card .stat-value{font-size:26px;font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:4px;font-family:'JetBrains Mono',monospace}
.stat-card .stat-label{font-size:12.5px;color:var(--text-muted);font-weight:500}
.stat-card .stat-change{display:flex;align-items:center;gap:4px;font-size:12px;margin-top:10px;font-weight:600}
.stat-card .stat-change.up{color:var(--success)}
.stat-card .stat-change.down{color:var(--danger)}
.stat-card::after{content:'';position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;opacity:.07}
.stat-card.blue .stat-icon{background:rgba(15,76,129,.1);color:var(--primary)}.stat-card.blue::after{background:var(--primary)}
.stat-card.orange .stat-icon{background:rgba(249,115,22,.1);color:var(--accent)}.stat-card.orange::after{background:var(--accent)}
.stat-card.green .stat-icon{background:rgba(22,163,74,.1);color:var(--success)}.stat-card.green::after{background:var(--success)}
.stat-card.red .stat-icon{background:rgba(220,38,38,.1);color:var(--danger)}.stat-card.red::after{background:var(--danger)}
.stat-card.cyan .stat-icon{background:rgba(8,145,178,.1);color:var(--info)}.stat-card.cyan::after{background:var(--info)}
.table-card .card-body{padding:0}
.custom-table{width:100%;border-collapse:collapse}
.custom-table thead th{background:#f8fafc;padding:12px 16px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}
.custom-table tbody td{padding:13px 16px;border-bottom:1px solid var(--border);font-size:13.5px;color:var(--text-primary);vertical-align:middle}
.custom-table tbody tr:last-child td{border-bottom:none}
.custom-table tbody tr:hover td{background:#f8fafc}
.badge-status{padding:4px 10px;border-radius:99px;font-size:11px;font-weight:600}
.badge-active{background:rgba(22,163,74,.1);color:var(--success)}
.badge-inactive{background:rgba(148,163,184,.15);color:var(--text-muted)}
.badge-low{background:rgba(220,38,38,.1);color:var(--danger)}
.badge-medium{background:rgba(217,119,6,.1);color:var(--warning)}
.badge-high{background:rgba(22,163,74,.1);color:var(--success)}
.badge-expired{background:rgba(220,38,38,.1);color:var(--danger)}
.badge-expiring{background:rgba(249,115,22,.1);color:var(--accent)}
.btn{font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;border-radius:var(--radius-sm);transition:var(--transition);font-size:13px}
.btn-primary{background:var(--primary);border-color:var(--primary)}.btn-primary:hover{background:var(--primary-light);border-color:var(--primary-light)}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-icon{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}
.form-label{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
.form-control,.form-select{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:9px 14px;font-size:13.5px;font-family:inherit;color:var(--text-primary);transition:var(--transition)}
.form-control:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,76,129,.1)}
.form-text{font-size:11.5px;color:var(--text-muted);margin-top:4px}
.required{color:var(--danger)}
.action-btns{display:flex;gap:6px;align-items:center}
.btn-edit{background:rgba(15,76,129,.08);color:var(--primary);border:none}.btn-edit:hover{background:var(--primary);color:#fff}
.btn-delete{background:rgba(220,38,38,.08);color:var(--danger);border:none}.btn-delete:hover{background:var(--danger);color:#fff}
.btn-view{background:rgba(8,145,178,.08);color:var(--info);border:none}.btn-view:hover{background:var(--info);color:#fff}
.table-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.search-box{position:relative}
.search-box .form-control{padding-left:36px;min-width:220px}
.search-box .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:13px;pointer-events:none}
.table-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--border);flex-wrap:wrap;gap:10px}
.table-info{font-size:12.5px;color:var(--text-muted)}
.pagination .page-link{font-size:12.5px;border-color:var(--border);font-family:inherit}
.pagination .page-item.active .page-link{background:var(--primary);border-color:var(--primary)}
.modal-header{background:var(--primary);color:#fff;border-radius:var(--radius) var(--radius) 0 0}
.modal-title{font-size:15px;font-weight:700;color:#fff}
.modal-header .btn-close{filter:brightness(0) invert(1)}
.alert{border-radius:var(--radius-sm);border:none;font-size:13.5px}
.alert-primary{background:rgba(15,76,129,.08);color:var(--primary)}
.alert-danger{background:rgba(220,38,38,.08);color:var(--danger)}
.alert-warning{background:rgba(217,119,6,.08);color:var(--warning)}
.alert-success{background:rgba(22,163,74,.08);color:var(--success)}
.progress{height:6px;border-radius:99px;background:var(--border)}
.progress-bar{border-radius:99px}
@media(max-width:991.98px){.sidebar{transform:translateX(-100%)}.sidebar.show{transform:translateX(0)}.main-content{margin-left:0}.topbar-toggle{display:flex}.topbar-search{display:none}.page-content{padding:16px}}
@media(max-width:575.98px){.page-title{font-size:18px}.stat-card .stat-value{font-size:22px}.topbar{padding:0 16px}.page-content{padding:12px}.card-header{padding:14px 16px}.card-body{padding:16px}.custom-table thead th,.custom-table tbody td{padding:10px 12px}}
@media print{.sidebar,.topbar,.topbar-toggle,.btn,.action-btns,.pagination{display:none!important}.main-content{margin-left:0!important}.page-content{padding:0!important}}



.nex-modal .modal-content {
  border: none !important;
  border-radius: 20px !important;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(26,29,46,.18), 0 8px 24px rgba(26,29,46,.10);
}
.nex-modal .modal-header { border-bottom: none !important; padding: 0 !important; }
.nex-modal .modal-body { padding: 32px 32px 20px !important; text-align: center; }
.nex-modal .modal-footer { border-top: 1.5px solid var(--clr-border) !important; padding: 14px 32px 20px !important; justify-content: center; gap: 10px; }
.nex-modal .modal-backdrop { backdrop-filter: blur(4px); }
.modal-stripe { height: 5px; width: 100%; }
.modal-icon-ring { width: 78px; height: 78px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; margin-bottom: 18px; position: relative; }
.modal-icon-ring::before { content: ''; position: absolute; inset: -5px; border-radius: 50%; border: 2px solid currentColor; opacity: .2; animation: ringPulse 2s ease-in-out infinite; }
.modal-icon-ring::after  { content: ''; position: absolute; inset: -12px; border-radius: 50%; border: 1.5px solid currentColor; opacity: .08; animation: ringPulse 2s ease-in-out infinite .4s; }
@keyframes ringPulse { 0%,100%{transform:scale(1);opacity:.18;} 50%{transform:scale(1.06);opacity:.32;} }
.modal-icon-ring svg { width: 42px; height: 42px; position: relative; z-index: 1; }
.modal-popup-title { font-family: 'Fraunces', serif; font-size: 12px; font-weight: 700; margin-bottom: 10px; letter-spacing: -.3px; }
.modal-popup-msg { font-size: 13.5px; color: var(--clr-muted); line-height: 1.65; max-width: 320px; margin: 0 auto 4px; }
.modal-esc-hint { font-size: 11.5px; color: #b0b8d1; text-align: center; padding: 0 32px 16px; }
.modal-esc-hint kbd { background: var(--clr-bg); border: 1px solid var(--clr-border); padding: 1px 6px; border-radius: 4px; font-size: 10px; }

/* Success modal */
#successModal .modal-icon-ring { background: var(--clr-success-lt); color: var(--clr-success); }
#successModal .modal-popup-title { color: #065f3e; }
.circle-stroke-s { fill:none; stroke:var(--clr-success); stroke-width:3; stroke-linecap:round; stroke-dasharray:113; stroke-dashoffset:113; transition: stroke-dashoffset .6s cubic-bezier(.65,0,.45,1) .1s; }
.circle-bg-s     { fill:none; stroke:#b7f0d8; stroke-width:3; }
.checkmark-path  { fill:none; stroke:var(--clr-success); stroke-width:3.5; stroke-linecap:round; stroke-linejoin:round; stroke-dasharray:30; stroke-dashoffset:30; transition: stroke-dashoffset .35s ease .6s; }
#successModal.show .circle-stroke-s { stroke-dashoffset:0; }
#successModal.show .checkmark-path  { stroke-dashoffset:0; }

/* Error modal */
#errorModal .modal-icon-ring { background: var(--clr-danger-lt); color: var(--clr-danger); }
#errorModal .modal-popup-title { color: #7a1920; }
.circle-stroke-e { fill:none; stroke:var(--clr-danger); stroke-width:3; stroke-linecap:round; stroke-dasharray:113; stroke-dashoffset:113; transition: stroke-dashoffset .6s cubic-bezier(.65,0,.45,1) .1s; }
.circle-bg-e     { fill:none; stroke:#fcc5c8; stroke-width:3; }
.xmark-l1,.xmark-l2 { fill:none; stroke:var(--clr-danger); stroke-width:3.5; stroke-linecap:round; stroke-dasharray:20; stroke-dashoffset:20; }
.xmark-l1 { transition: stroke-dashoffset .28s ease .55s; }
.xmark-l2 { transition: stroke-dashoffset .28s ease .75s; }
#errorModal.show .circle-stroke-e { stroke-dashoffset:0; }
#errorModal.show .xmark-l1,
#errorModal.show .xmark-l2        { stroke-dashoffset:0; }
@keyframes shakeModal { 0%,100%{transform:translateX(0);} 15%{transform:translateX(-7px);} 30%{transform:translateX(6px);} 45%{transform:translateX(-5px);} 60%{transform:translateX(4px);} 75%{transform:translateX(-3px);} 90%{transform:translateX(2px);} }
.shake-anim { animation: shakeModal .55s ease; }

    /* SUCCESS ICON */
.circle-bg-s{
    fill:none;
    stroke:#e6f7f1;
    stroke-width:4;
}

.circle-stroke-s{
    fill:none;
    stroke:#0ead69;
    stroke-width:4;
    stroke-dasharray:113;
    stroke-dashoffset:113;
    animation:drawCircle 0.6s ease forwards;
}

.checkmark-path{
    fill:none;
    stroke:#0ead69;
    stroke-width:4;
    stroke-linecap:round;
    stroke-linejoin:round;
    stroke-dasharray:40;
    stroke-dashoffset:40;
    animation:drawCheck 0.4s ease forwards 0.6s;
}

/* ERROR ICON */

.circle-bg-e{
    fill:none;
    stroke:#fde8e8;
    stroke-width:4;
}

.circle-stroke-e{
    fill:none;
    stroke:#e63946;
    stroke-width:4;
}

.xmark-l1,.xmark-l2{
    stroke:#e63946;
    stroke-width:4;
    stroke-linecap:round;
}

/* ANIMATIONS */

@keyframes drawCircle{
    to{ stroke-dashoffset:0; }
}

@keyframes drawCheck{
    to{ stroke-dashoffset:0; }
}
