/* Netri Academy custom theme overrides — built on top of the Educavo template */

/* Brand colors: Navy + Blue accent */
:root {
    --netri-navy: #0a2540;
    --netri-orange: #2b7de9;
    --netri-orange-soft: #7ab8f5;
}

/* Hero override */
#rs-banner.netri-hero {
    background: linear-gradient(120deg, rgba(0,0,0,0.72) 0%, rgba(0,0,0,0.52) 60%, rgba(43,125,233,0.25) 100%),
                url('../images/hero/hero-main.jpg') center/cover no-repeat;
    min-height: 620px;
    display: flex;
    align-items: center;
    padding: 120px 0 90px;
}
#rs-banner.netri-hero .banner-title { font-size: 56px; line-height: 1.1; }
#rs-banner.netri-hero .banner-desc { font-size: 18px; max-width: 620px; margin-bottom: 30px; }

/* Pillar cards (n-ICL framework) */
.netri-pillar {
    background:#fff;
    border-radius:12px;
    padding:35px 25px;
    text-align:center;
    box-shadow:0 6px 30px rgba(10,37,64,0.08);
    height:100%;
    transition:transform .3s ease, box-shadow .3s ease;
}
.netri-pillar:hover{ transform:translateY(-6px); box-shadow:0 10px 40px rgba(10,37,64,0.15); }
.netri-pillar .icon-wrap{
    width:74px; height:74px; line-height:74px;
    background:linear-gradient(135deg,var(--netri-navy),var(--netri-orange));
    color:#fff; font-size:32px; border-radius:50%; margin:0 auto 18px;
}
.netri-pillar h4{ color:var(--netri-navy); margin-bottom:10px; }
.netri-pillar p{ color:#5a6378; margin-bottom:0; }

/* ICL strip */
.netri-icl-strip {
    background: var(--netri-navy);
    color:#fff;
    border-radius:14px;
    padding:36px 30px;
    margin-top:40px;
}
.netri-icl-strip .step{ text-align:center; padding:10px; }
.netri-icl-strip .step .num{
    display:inline-block; width:54px; height:54px; line-height:54px;
    border-radius:50%; background:var(--netri-orange); color:#fff;
    font-size:22px; font-weight:700; margin-bottom:12px;
}
.netri-icl-strip .step h5{ color:#fff; margin-bottom:6px; }
.netri-icl-strip .step p{ color:#cfd6e2; margin-bottom:0; font-size:14px; }

/* Stats band */
.netri-stats { background:var(--netri-navy); padding:60px 0; }
.netri-stats .stat { text-align:center; color:#fff; }
.netri-stats .stat .num{ font-size:48px; font-weight:800; color:var(--netri-orange); display:block; }
.netri-stats .stat .lbl{ font-size:15px; letter-spacing:.5px; text-transform:uppercase; color:#cfd6e2; }

/* Project cards (showcase) */
.netri-project {
    position:relative; overflow:hidden; border-radius:10px; margin-bottom:30px;
}
.netri-project img{ width:100%; height:260px; object-fit:cover; transition:transform .5s ease; }
.netri-project:hover img{ transform:scale(1.06); }
.netri-project .overlay{
    position:absolute; inset:0;
    background:linear-gradient(180deg, transparent 40%, rgba(10,37,64,0.92) 100%);
    display:flex; flex-direction:column; justify-content:flex-end;
    padding:20px; color:#fff;
}
.netri-project .overlay h5{ color:#fff; margin-bottom:4px; }
.netri-project .overlay span{ color:var(--netri-orange-soft); font-size:13px; }

/* Why-us card */
.netri-why { padding:24px; border-radius:10px; background:#f7f9fc; height:100%; }
.netri-why .icn { font-size:36px; color:var(--netri-orange); margin-bottom:10px; }
.netri-why h5 { color:var(--netri-navy); }

/* Loader / preloader — brand colors */
.loader .loader-container:before {
    border-color: var(--netri-orange) transparent transparent transparent !important;
}
.loader .loader-icon img {
    max-width: 100px;
}

/* Hide topbar globally */
.topbar-area { display: none !important; }

/* Production-ready menu bar */
.full-width-header .rs-header .menu-area {
    background: var(--netri-navy);
    box-shadow: 0 2px 20px rgba(0,0,0,0.15);
}
.full-width-header .rs-header .menu-area .logo-cat-wrap {
    height: 120px;
    line-height: 120px;
    padding: 0;
}
.full-width-header .rs-header .menu-area .main-menu .rs-menu ul.nav-menu li a {
    height: 120px;
    line-height: 120px;
    padding-top: 0;
    padding-bottom: 0;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.5px;
    color: #fff;
}
.full-width-header .rs-header .menu-area .main-menu .rs-menu ul.nav-menu li a:hover,
.full-width-header .rs-header .menu-area .main-menu .rs-menu ul.nav-menu li.current-menu-item > a {
    color: var(--netri-orange) !important;
}
.full-width-header .rs-header .menu-area .rs-menu-area {
    display: flex;
    align-items: center;
    height: 120px;
}
.expand-btn-inner .apply-btn {
    padding: 10px 22px !important;
    border-radius: 6px;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px;
}
.full-width-header.header-style2.modify1 .rs-header .menu-area.sticky,
.full-width-header.header-style2 .rs-header .menu-area.sticky,
.full-width-header .rs-header .menu-area.sticky {
    background: #fff !important;
    box-shadow: 0 2px 16px rgba(0,0,0,0.1) !important;
}
.full-width-header.header-style2.modify1 .rs-header .menu-area.sticky .main-menu .rs-menu ul.nav-menu > li > a,
.full-width-header.header-style2 .rs-header .menu-area.sticky .main-menu .rs-menu ul.nav-menu > li > a,
.full-width-header .rs-header .menu-area.sticky .main-menu .rs-menu ul.nav-menu li a {
    color: var(--netri-navy) !important;
}
.full-width-header.header-style2.modify1 .rs-header .menu-area.sticky .main-menu .rs-menu ul.nav-menu > li > a:hover,
.full-width-header.header-style2 .rs-header .menu-area.sticky .main-menu .rs-menu ul.nav-menu > li > a:hover,
.full-width-header .rs-header .menu-area.sticky .main-menu .rs-menu ul.nav-menu li a:hover,
.full-width-header .rs-header .menu-area.sticky .main-menu .rs-menu ul.nav-menu li.current-menu-item > a {
    color: var(--netri-orange) !important;
}
.full-width-header.header-style2.modify1 .rs-header .menu-area.sticky .expand-btn-inner li > a,
.full-width-header.header-style2 .rs-header .menu-area.sticky .expand-btn-inner li > a,
.full-width-header .rs-header .menu-area.sticky .expand-btn-inner .apply-btn {
    color: #fff !important;
}
.full-width-header.header-style2.modify1 .rs-header .menu-area.sticky .logo-cat-wrap,
.full-width-header .rs-header .menu-area.sticky .logo-cat-wrap {
    height: 120px;
    line-height: 120px;
}
.full-width-header.header-style2.modify1 .rs-header .menu-area.sticky .main-menu .rs-menu ul.nav-menu > li > a {
    height: 120px;
    line-height: 120px;
}

/* Page hero (small banner for inner pages) */
.netri-page-hero {
    background: linear-gradient(120deg, rgba(0,0,0,0.72), rgba(0,0,0,0.52)), url('../images/hero/inner.jpg') center/cover no-repeat;
    color:#fff; padding:150px 0 100px; text-align:center;
}
.netri-page-hero h1 { color:#fff; font-size:46px; }
.netri-page-hero .breadcrumb-link { color:#cfd6e2; }
.netri-page-hero .breadcrumb-link a{ color:var(--netri-orange-soft); }

/* Program hero section — full-bleed photo at top, title below */
.netri-prog-hero-section {
    padding-top: 0;
}
.netri-prog-hero-img {
    width: 100%;
    height: 460px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: block;
}
@media (max-width: 767px) {
    .netri-prog-hero-img {
        height: 340px;
    }
}
.netri-prog-title-bar {
    background: #0a2540;
    padding: 32px 0 28px;
    text-align: center;
}
.netri-prog-title {
    color: #ffffff !important;
    font-size: 52px !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    text-shadow: 0 2px 10px rgba(0,0,0,0.5);
}
@media (max-width: 991px) {
    .netri-prog-title {
        font-size: 38px !important;
    }
}
@media (max-width: 767px) {
    .netri-prog-title {
        font-size: 28px !important;
    }
}
.netri-prog-hero-subtitle {
    color: #f4631e;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.5px;
    margin: 0;
}
.netri-prog-hero-tagline {
    display: inline-block;
    background: #f4631e;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: 4px 16px;
    border-radius: 20px;
}

/* Program Levels — Junior / Senior cards */
.prog-levels-section { background: #f7f9fc; }
.prog-levels-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
.prog-levels-grid:has(.prog-level-card:only-child) {
    grid-template-columns: 1fr;
    max-width: 540px;
}
.prog-level-card {
    background: #fff;
    border-radius: 14px;
    border: 1px solid #e1e4e8;
    box-shadow: 0 4px 22px rgba(10,37,64,.09);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    padding: 0 0 28px;
}
.plc-header {
    padding: 24px 28px 18px;
    border-bottom: 1px solid #edf0f5;
}
.plc-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    padding: 3px 14px;
    border-radius: 20px;
    margin-bottom: 10px;
}
.prog-level-card--junior .plc-badge {
    background: #e8f4ff;
    color: #1a6fca;
}
.prog-level-card--senior .plc-badge {
    background: #fff4ed;
    color: #f4631e;
}
.plc-title {
    color: var(--netri-navy);
    font-size: 20px;
    margin: 0;
}
.plc-list {
    list-style: none;
    padding: 20px 28px 0;
    margin: 0;
    flex: 1;
}
.plc-list li {
    padding: 7px 0 7px 26px;
    position: relative;
    color: #444;
    font-size: 15px;
    border-bottom: 1px solid #f2f4f8;
}
.plc-list li:last-child { border-bottom: none; }
.plc-list li .fa {
    position: absolute;
    left: 0;
    top: 10px;
    color: var(--netri-orange);
    font-size: 13px;
}
.prog-level-card .readon3 {
    margin: 0 28px;
    display: inline-block;
    text-align: center;
}
@media (max-width: 767px) {
    .prog-levels-grid { grid-template-columns: 1fr; }
}

/* Program detail */
.netri-program-block { padding:60px 0; background:#fff; }
.netri-program-block.alt-bg { background:#f7f9fc; }
.netri-program-block .img-wrap img{ width:100%; border-radius:10px; }
.netri-program-block h2 { color:var(--netri-navy); }
.netri-program-block .tagline { color:var(--netri-orange); font-weight:600; margin-bottom:15px; }
.netri-program-block ul.netri-list { list-style:none; padding-left:0; }
.netri-program-block ul.netri-list li{ padding:6px 0 6px 28px; position:relative; }
.netri-program-block ul.netri-list li:before{
    content:"\f00c"; font-family:FontAwesome; color:var(--netri-orange);
    position:absolute; left:0; top:6px;
}

/* Forms */
.netri-form .form-group { margin-bottom:18px; }
.netri-form input, .netri-form select, .netri-form textarea {
    width:100%; padding:12px 16px; border:1px solid #e1e6ee; border-radius:6px;
    background:#fff; color:#0a2540; font-size:15px;
}
.netri-form textarea { min-height:140px; resize:vertical; }
.netri-form button {
    background:var(--netri-orange); color:#fff; border:0; padding:14px 32px;
    border-radius:6px; font-weight:600; cursor:pointer; transition:background .25s;
}
.netri-form button:hover { background:var(--netri-navy); }
.netri-alert { padding:14px 18px; border-radius:6px; margin-bottom:20px; }
.netri-alert.success { background:#e6f7ec; color:#1e6f3a; border:1px solid #b6e3c2; }
.netri-alert.error { background:#fdecec; color:#9b1c1c; border:1px solid #f3b6b6; }

/* Workshop card */
.netri-workshop { background:#fff; border-radius:10px; overflow:hidden; box-shadow:0 5px 25px rgba(10,37,64,0.08); margin-bottom:30px; }
.netri-workshop img { width:100%; height:220px; object-fit:cover; }
.netri-workshop .body { padding:22px; }
.netri-workshop .badge-cat { display:inline-block; padding:4px 10px; border-radius:4px; background:var(--netri-orange); color:#fff; font-size:12px; text-transform:uppercase; letter-spacing:.5px; margin-bottom:10px; }
.netri-workshop h4 { color:var(--netri-navy); }
.netri-workshop .date { color:#7a8395; font-size:14px; }

/* ================================================================
   ADMIN PANEL — Responsive Design System
   ================================================================ */
.admin-shell { display:flex; min-height:100vh; font-family:'Nunito',sans-serif; background:#f0f3f9; }

/* ---- Sidebar ---- */
.admin-side {
    width:256px;
    min-width:256px;
    background:#0a2540;
    color:#fff;
    display:flex;
    flex-direction:column;
    position:sticky;
    top:0;
    height:100vh;
    overflow-y:auto;
    overflow-x:hidden;
    scrollbar-width:thin;
    scrollbar-color:rgba(255,255,255,0.1) transparent;
    transition:transform .28s cubic-bezier(.4,0,.2,1);
    z-index:200;
    flex-shrink:0;
}
.admin-side::-webkit-scrollbar { width:4px; }
.admin-side::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.12); border-radius:4px; }
.admin-side .brand {
    padding:20px 22px 18px;
    border-bottom:1px solid rgba(255,255,255,0.08);
    font-weight:800;
    font-size:18px;
    letter-spacing:-.3px;
    color:#fff;
    flex-shrink:0;
    display:flex;
    align-items:center;
    gap:9px;
}
.admin-side .brand .brand-dot { color:#f47c20; }
.admin-side .nav-group {
    padding:18px 22px 5px;
    font-size:10px;
    text-transform:uppercase;
    letter-spacing:1.2px;
    color:#4a6882;
    font-weight:700;
    flex-shrink:0;
}
.admin-side a {
    display:flex;
    align-items:center;
    gap:11px;
    padding:10px 22px;
    color:#9ab0c4;
    text-decoration:none;
    font-size:13.5px;
    font-weight:500;
    border-left:3px solid transparent;
    transition:background .14s, color .14s, border-color .14s;
    flex-shrink:0;
}
.admin-side a i { width:17px; text-align:center; font-size:13px; flex-shrink:0; opacity:.8; }
.admin-side a:hover { background:rgba(255,255,255,0.06); color:#fff; }
.admin-side a:hover i { opacity:1; }
.admin-side a.active {
    background:rgba(244,124,32,0.12);
    color:#fff;
    border-left-color:#f47c20;
    font-weight:600;
}
.admin-side a.active i { opacity:1; }
.admin-side .admin-logout {
    margin-top:auto;
    padding:16px 22px;
    border-top:1px solid rgba(255,255,255,0.07);
    display:flex;
    align-items:center;
    gap:10px;
    color:#6b8aa0;
    font-size:13px;
    font-weight:500;
    cursor:pointer;
    border-left:3px solid transparent;
}
.admin-side .admin-logout:hover { color:#fff; background:rgba(255,255,255,0.06); }

/* ---- Main column ---- */
.admin-main { flex:1; min-width:0; display:flex; flex-direction:column; }

/* ---- Top bar ---- */
.admin-topbar {
    background:#fff;
    border-bottom:1px solid #e4e9f2;
    padding:0 28px;
    height:58px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    position:sticky;
    top:0;
    z-index:100;
    flex-shrink:0;
    gap:12px;
}
.admin-topbar-left { display:flex; align-items:center; gap:14px; min-width:0; }
.admin-topbar h1 {
    font-size:17px;
    font-weight:700;
    color:#0a2540;
    margin:0;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.admin-topbar-right {
    display:flex;
    align-items:center;
    gap:10px;
    font-size:13px;
    color:#6b7280;
    flex-shrink:0;
}
.admin-topbar-date { font-size:12px; color:#9ca3af; }
.admin-avatar {
    width:32px;
    height:32px;
    border-radius:50%;
    background:#0a2540;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:12px;
    font-weight:800;
    flex-shrink:0;
}
.admin-hamburger {
    display:none;
    background:none;
    border:none;
    cursor:pointer;
    padding:7px 8px;
    border-radius:7px;
    color:#0a2540;
    font-size:18px;
    line-height:1;
    flex-shrink:0;
}
.admin-hamburger:hover { background:#f0f3f9; }

/* ---- Page content area ---- */
.admin-content { padding:26px 28px; flex:1; }

/* ---- Alerts ---- */
.netri-alert { padding:12px 16px; border-radius:8px; margin-bottom:16px; font-size:14px; font-weight:500; }
.netri-alert.success { background:#ecfdf5; border-left:4px solid #16a34a; color:#166534; }
.netri-alert.error   { background:#fef2f2; border-left:4px solid #dc2626; color:#991b1b; }

/* ---- Cards ---- */
.admin-card {
    background:#fff;
    border-radius:12px;
    padding:24px;
    box-shadow:0 1px 3px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.04);
    margin-bottom:22px;
    border:1px solid #e4e9f2;
}
.admin-card h3 {
    font-size:15px;
    font-weight:700;
    color:#0a2540;
    margin:0 0 18px;
    padding-bottom:14px;
    border-bottom:1px solid #f0f3f9;
}

/* ---- Stat grid (dashboard) ---- */
.admin-stat-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(170px,1fr));
    gap:16px;
    margin-bottom:22px;
}
.admin-stat-card {
    background:#fff;
    border-radius:12px;
    padding:20px 22px;
    border:1px solid #e4e9f2;
    box-shadow:0 1px 3px rgba(0,0,0,0.05);
    transition:box-shadow .15s;
}
.admin-stat-card:hover { box-shadow:0 4px 16px rgba(0,0,0,0.08); }
.admin-stat-label {
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.7px;
    color:#6b7280;
    margin-bottom:8px;
}
.admin-stat-value {
    font-size:34px;
    font-weight:800;
    color:#0a2540;
    line-height:1;
}
.admin-stat-card.unread .admin-stat-value { color:#f47c20; }
.admin-stat-card.unread { border-top:3px solid #f47c20; }

/* ---- Table ---- */
.admin-table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; border-radius:8px; }
.admin-table { width:100%; border-collapse:collapse; min-width:480px; }
.admin-table th {
    background:#f8fafc;
    color:#374151;
    font-weight:700;
    font-size:11px;
    text-transform:uppercase;
    letter-spacing:.6px;
    padding:11px 14px;
    text-align:left;
    border-bottom:2px solid #e4e9f2;
    white-space:nowrap;
}
.admin-table td {
    padding:11px 14px;
    text-align:left;
    border-bottom:1px solid #f0f3f9;
    vertical-align:top;
    font-size:14px;
    color:#374151;
}
.admin-table tbody tr:last-child td { border-bottom:0; }
.admin-table tbody tr:hover td { background:#fafbfe; }
.admin-table tr.unread-row td { background:#fffbf5; }
.badge-new {
    display:inline-block;
    background:#f47c20;
    color:#fff;
    font-size:10px;
    font-weight:700;
    padding:2px 8px;
    border-radius:20px;
    letter-spacing:.3px;
}
.badge-read {
    display:inline-block;
    background:#e5e7eb;
    color:#6b7280;
    font-size:10px;
    font-weight:600;
    padding:2px 8px;
    border-radius:20px;
}

/* ---- Buttons ---- */
.admin-btn {
    display:inline-flex;
    align-items:center;
    gap:5px;
    background:#f47c20;
    color:#fff !important;
    padding:8px 15px;
    border-radius:7px;
    text-decoration:none;
    border:0;
    cursor:pointer;
    font-size:13px;
    font-weight:600;
    transition:opacity .15s, transform .1s, box-shadow .15s;
    margin-right:5px;
    margin-bottom:4px;
    line-height:1.4;
    white-space:nowrap;
}
.admin-btn:hover { opacity:.88; transform:translateY(-1px); box-shadow:0 4px 12px rgba(244,124,32,.3); }
.admin-btn:active { transform:translateY(0); }
.admin-btn.secondary { background:#64748b; }
.admin-btn.secondary:hover { box-shadow:0 4px 12px rgba(100,116,139,.3); }
.admin-btn.danger { background:#dc2626; }
.admin-btn.danger:hover { box-shadow:0 4px 12px rgba(220,38,38,.3); }
.admin-btn.success { background:#16a34a; }
.admin-btn.sm { padding:5px 11px; font-size:12px; }

/* ---- Mobile overlay ---- */
.admin-overlay {
    display:none;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.48);
    z-index:150;
    backdrop-filter:blur(2px);
}
.admin-overlay.show { display:block; }

/* ---- Login card ---- */
.admin-login-card {
    max-width:400px;
    margin:80px auto;
    padding:36px 32px;
    background:#fff;
    border-radius:14px;
    box-shadow:0 12px 48px rgba(10,37,64,.12);
    border:1px solid #e4e9f2;
}

/* Apply Educavo orange button to brand orange */
.readon3, .apply-btn { background:var(--netri-orange) !important; }
.readon3.active { background:var(--netri-navy) !important; }

/* ----- Rounded corners — applied globally to content imagery ----- */
.netri-rounded,
.subject-wrap img,
.netri-pillar img,
.netri-why img,
.netri-workshop img,
.netri-project img,
.netri-program-block .img-wrap img,
.testi-item .user-info img,
.about-intro img,
.rs-about img,
.banner-content img,
.netri-team-card img,
.netri-hero-slide .slide-img img,
.rs-popular-courses img { border-radius: 14px; }
.testi-item .user-info img { border-radius: 50%; }

/* ----- Hero carousel (Owl) ----- */
.netri-hero-carousel { position:relative; padding-top:120px; }
.netri-hero-slide {
    position:relative;
    min-height: 620px;
    display:flex; align-items:center;
    background-size:cover; background-position:center;
    color:#fff;
    padding:120px 0 90px;
}
.netri-hero-slide:before{
    content:""; position:absolute; inset:0;
    background:linear-gradient(180deg, rgba(0,0,0,0.72) 0%, rgba(0,0,0,0.52) 100%);
}
.netri-hero-slide .container { position:relative; z-index:2; }
.netri-hero-slide h1 { color:#fff; font-size:54px; line-height:1.1; margin-bottom:18px; max-width:780px; }
.netri-hero-slide p  { color:#e7ecf3; font-size:18px; max-width:640px; margin-bottom:28px; }
.netri-hero-slide .btns a { margin-right:12px; margin-bottom:10px; display:inline-block; }
.netri-hero-carousel .owl-dots { position:absolute; bottom:24px; left:0; right:0; text-align:center; z-index:5; }
.netri-hero-carousel .owl-dots .owl-dot span {
    width:14px; height:14px; background:rgba(255,255,255,0.45); border-radius:50%; display:inline-block; margin:0 5px;
}
.netri-hero-carousel .owl-dots .owl-dot.active span { background:var(--netri-orange); width:36px; border-radius:8px; }
.netri-hero-carousel .owl-nav button {
    position:absolute; top:50%; transform:translateY(-50%);
    background:rgba(10,37,64,0.55) !important; color:#fff !important;
    width:48px; height:48px; border-radius:50%; font-size:22px !important; z-index:5;
}
.netri-hero-carousel .owl-nav button.owl-prev { left:20px; }
.netri-hero-carousel .owl-nav button.owl-next { right:20px; }
.netri-hero-carousel .owl-nav button:hover { background:var(--netri-orange) !important; }

/* ----- Team grid card ----- */
.netri-team-card {
    background:#fff; border-radius:14px; padding:28px 22px; text-align:center;
    box-shadow:0 6px 24px rgba(10,37,64,0.08); height:100%;
}
.netri-team-card img {
    width:140px; height:140px; object-fit:cover; border-radius:50%; margin:0 auto 18px; display:block;
    border:4px solid #f3f5f9;
}
.netri-team-card h5 { color:var(--netri-navy); margin-bottom:4px; }
.netri-team-card .role { color:var(--netri-orange); font-weight:600; font-size:14px; margin-bottom:10px; display:block; }
.netri-team-card p { color:#5a6378; font-size:14px; margin-bottom:0; }

/* Mission/Vision/Values cards */
.netri-mvv-card {
    background:#fff; border-radius:14px; padding:32px 26px; height:100%;
    border-top:4px solid var(--netri-orange); box-shadow:0 6px 22px rgba(10,37,64,0.07);
}
.netri-mvv-card h4 { color:var(--netri-navy); }
.netri-mvv-card .icn { font-size:32px; color:var(--netri-orange); margin-bottom:12px; }
.netri-values-list { list-style:none; padding-left:0; }
.netri-values-list li { padding:10px 0 10px 30px; position:relative; border-bottom:1px solid #eef1f6; }
.netri-values-list li:last-child { border-bottom:0; }
.netri-values-list li:before {
    content:"\f005"; font-family:FontAwesome; color:var(--netri-orange); position:absolute; left:0; top:12px;
}

/* Impact band */
.netri-impact-band {
    background:linear-gradient(135deg, var(--netri-navy) 0%, #102d52 100%);
    color:#fff; padding:80px 0; border-radius:0;
}
.netri-impact-band h2 { color:#fff; }
.netri-impact-band p { color:#cfd6e2; }
.netri-impact-band .actions li {
    padding:8px 0 8px 30px; position:relative; color:#e7ecf3;
}
.netri-impact-band .actions li:before {
    content:"\f0a9"; font-family:FontAwesome; color:var(--netri-orange); position:absolute; left:0; top:8px;
}

@media (max-width: 991px){
    #rs-banner.netri-hero { min-height: auto; padding: 100px 0 60px; }
    #rs-banner.netri-hero .banner-title{ font-size: 36px; }
    .netri-hero-slide { min-height:auto; padding:100px 0 60px; }
    .netri-hero-slide h1 { font-size:32px; }
    .netri-hero-slide p { font-size:15px; }
    .netri-page-hero { padding:110px 0 50px; }
    /* Admin responsive */
    .admin-side {
        position:fixed;
        left:0; top:0; bottom:0;
        transform:translateX(-100%);
        z-index:200;
        height:100vh;
        border-radius:0;
    }
    .admin-side.open { transform:translateX(0); box-shadow:4px 0 32px rgba(0,0,0,0.22); }
    .admin-hamburger { display:flex; align-items:center; }
    .admin-topbar-date { display:none; }
    .admin-content { padding:16px; }
    .admin-topbar { padding:0 16px; height:54px; }
    .admin-stat-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
}

@media (max-width:576px) {
    .admin-stat-grid { grid-template-columns:repeat(2,1fr); gap:8px; }
    .admin-stat-card { padding:14px 16px; }
    .admin-stat-value { font-size:26px; }
    .admin-card { padding:16px; border-radius:8px; }
    .admin-content { padding:12px; }
    .admin-table th, .admin-table td { padding:8px 10px; font-size:13px; }
    .admin-btn { padding:7px 11px; font-size:12px; }
}

/* ===== Franchise page ===== */
.netri-franchise-check {
    display:flex; gap:16px; align-items:flex-start;
    background:#fff; border-radius:10px; padding:24px;
    box-shadow:0 5px 20px rgba(10,37,64,0.07); height:100%;
}
.netri-franchise-check .check-icon {
    flex-shrink:0; width:48px; height:48px; line-height:48px;
    border-radius:50%; background:linear-gradient(135deg,var(--netri-navy),var(--netri-orange));
    color:#fff; font-size:20px; text-align:center;
}
.netri-franchise-check .check-body h5 { color:var(--netri-navy); margin-bottom:6px; }
.netri-franchise-check .check-body p  { color:#5a6378; margin-bottom:0; font-size:14px; }

/* ===== Vision / quote strip (shared by franchise + impact) ===== */
.netri-vision-strip {
    background:var(--netri-navy); color:#fff; padding:70px 0; text-align:center;
}
.netri-vision-strip .quote {
    font-size:24px; font-style:italic; font-weight:600;
    color:#fff; max-width:860px; margin:0 auto 24px;
    line-height:1.5; border-left:4px solid var(--netri-orange);
    padding-left:22px; text-align:left;
}
.netri-vision-strip p { color:#cfd6e2; max-width:760px; margin:0 auto 22px; }

/* FontAwesome 4 aliases for icons used in new pages */
.fa-sync:before    { content:"\f021"; } /* fa-refresh */
.fa-wheelchair:before { content:"\f193"; }
.fa-female:before  { content:"\f182"; }
.fa-building:before{ content:"\f0f7"; }
.fa-hand-rock-o:before { content:"\f255"; }
.fa-birthday-cake:before { content:"\f1fd"; }

/* ===== Floating side CTAs (vertical rectangular) ===== */
.netri-floats {
    position: fixed;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 9990;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.float-cta {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 14px 10px;
    width: 56px;
    text-decoration: none !important;
    font-weight: 700;
    font-size: 9px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    text-align: center;
    transition: width 0.2s ease, box-shadow 0.2s ease;
    color: #fff !important;
    line-height: 1.2;
    border-radius: 0;
}
.float-cta i {
    font-size: 18px;
}
.float-trial {
    background: var(--netri-orange);
    box-shadow: -3px 3px 16px rgba(43,125,233,0.38);
    border-radius: 8px 0 0 0;
}
.float-trial:hover {
    width: 66px;
    box-shadow: -4px 4px 22px rgba(43,125,233,0.5);
    color: #fff !important;
}
.float-admissions {
    background: var(--netri-navy);
    box-shadow: -3px 3px 16px rgba(10,37,64,0.35);
    font-size: 8px;
    border-radius: 0 0 0 8px;
}
.float-admissions:hover {
    width: 66px;
    box-shadow: -4px 4px 22px rgba(10,37,64,0.5);
    color: #fff !important;
}
.pulse-dot {
    width: 8px;
    height: 8px;
    background: #fff;
    border-radius: 50%;
    flex-shrink: 0;
    animation: netri-pulse 1.8s ease-in-out infinite;
}
@keyframes netri-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: 0.45; transform: scale(0.6); }
}
@media (max-width: 767px) {
    /* Keep the vertical side-stacked CTAs on mobile, just slimmer */
    .netri-floats {
        right: 0;
        top: 50%;
        bottom: auto;
        transform: translateY(-50%);
        flex-direction: column;
        gap: 0;
    }
    .float-cta {
        width: 48px;
        padding: 12px 2px;
        font-size: 8px;
        flex-direction: column;
        gap: 4px;
        letter-spacing: 0px;
    }
    .float-cta i { font-size: 16px; }
    .float-trial { border-radius: 8px 0 0 0; }
    .float-admissions { border-radius: 0 0 0 8px; font-size: 6.5px; }
    .float-trial:hover, .float-admissions:hover { width: 56px; }
}

/* Program student gains cards */
.netri-gains-card {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: 16px;
    padding: 32px 22px 28px;
    height: 100%;
    transition: background 0.2s, transform 0.2s;
}
.netri-gains-card:hover {
    background: rgba(255,255,255,0.14);
    transform: translateY(-4px);
}
.netri-gains-card .icn {
    font-size: 36px;
    margin-bottom: 16px;
    display: block;
    line-height: 1;
}
.netri-gains-card h5 {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 10px;
}
.netri-gains-card p {
    font-size: 13.5px;
    line-height: 1.65;
    margin: 0;
}

/* ===== Program cards (new design — replaces course-wrap) ===== */
.netri-prog-card {
    background: #fff;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 6px 28px rgba(10,37,64,0.08);
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: transform 0.28s ease, box-shadow 0.28s ease;
}
.netri-prog-card:hover {
    transform: translateY(-7px);
    box-shadow: 0 16px 44px rgba(10,37,64,0.15);
}
.netri-prog-card .card-img { position: relative; overflow: hidden; }
.netri-prog-card .card-img img {
    width: 100%; height: 250px; object-fit: cover;
    transition: transform 0.45s ease;
    border-radius: 0 !important;
    display: block;
}
.netri-prog-card:hover .card-img img { transform: scale(1.06); }
.netri-prog-card .card-badge {
    position: absolute; top: 14px; left: 14px;
    background: #3b82f6; color: #fff;
    font-size: 11px; font-weight: 800; text-transform: uppercase;
    letter-spacing: 1px; padding: 6px 12px; border-radius: 4px;
}
.netri-prog-card .card-body { padding: 28px 28px 0; flex: 1; }
.netri-prog-card .card-title { color: var(--netri-navy); margin-bottom: 12px; font-size: 22px; font-weight: 700; }
.netri-prog-card .card-title a { color: var(--netri-navy); text-decoration: none; }
.netri-prog-card .card-title a:hover { color: #3b82f6; }
.netri-prog-card .card-desc { color: #4b5563; font-size: 15px; font-weight: 500; line-height: 1.6; margin-bottom: 0; }
.netri-prog-card .card-foot {
    padding: 20px 28px 28px;
    display: flex; gap: 12px; align-items: center;
    border-top: 1px solid #f0f3f8;
    margin-top: 20px;
}
.netri-prog-card .btn-learn {
    background: var(--netri-navy); color: #fff !important;
    padding: 10px 20px; border-radius: 6px; text-decoration: none;
    font-size: 14px; font-weight: 700; transition: background 0.2s;
    display: inline-flex; align-items: center; justify-content: center; height: 42px; gap: 6px;
}
.netri-prog-card .btn-learn:hover { background: #3b82f6; }
.netri-prog-card .btn-enquire {
    background: #fff; color: #3b82f6;
    border: 2px solid #3b82f6;
    padding: 8px 20px; border-radius: 6px;
    font-size: 14px; font-weight: 700; cursor: pointer;
    transition: all 0.2s; text-decoration: none;
    display: inline-flex; align-items: center; justify-content: center; height: 42px;
}
.netri-prog-card .btn-enquire:hover { background: #3b82f6; color: #fff; }

/* Coming-soon card variant */
.netri-prog-card--soon { opacity: 0.72; pointer-events: none; }
.netri-prog-card--soon .card-img img { filter: grayscale(40%); }
.card-badge--soon { background: #8a9ab5 !important; }
.netri-prog-card .btn-soon {
    color: #8a9ab5;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.3px;
}
.netri-card-link--soon { cursor: default; display: block; }

/* ===== Program enquiry modal ===== */
.netri-modal-overlay {
    display: none;
    position: fixed; inset: 0;
    background: rgba(10,37,64,0.72);
    z-index: 99990;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.netri-modal-overlay.active { display: flex; }
.netri-modal {
    background: #fff;
    border-radius: 16px;
    padding: 40px 36px;
    max-width: 520px; width: 100%;
    position: relative;
    box-shadow: 0 24px 70px rgba(0,0,0,0.22);
    animation: modal-in 0.22s ease;
}
@keyframes modal-in { from { transform:scale(0.94); opacity:0; } to { transform:scale(1); opacity:1; } }
.modal-close {
    position: absolute; top: 14px; right: 18px;
    background: none; border: none; font-size: 30px;
    cursor: pointer; color: #9aa5b8; line-height: 1;
    transition: color 0.15s;
}
.modal-close:hover { color: var(--netri-navy); }

/* ===== Date input wrapper ===== */
.netri-date-wrap { position: relative; }
.netri-date-wrap > i {
    position: absolute; left: 14px; top: 50%;
    transform: translateY(-50%);
    color: var(--netri-orange); pointer-events: none; z-index: 1; font-size: 15px;
}
.netri-date-wrap input[type="date"] { padding-left: 40px; color: #5a6378; }

/* ===== Rich text rendered output ===== */
.netri-rich-content p { color: #5a6378; font-size: 15px; line-height: 1.8; margin-bottom: 14px; }
.netri-rich-content h3 { color: var(--netri-navy); font-size: 20px; margin: 22px 0 10px; }
.netri-rich-content h4 { color: var(--netri-navy); font-size: 18px; margin: 18px 0 8px; }
.netri-rich-content h5 { color: var(--netri-navy); font-size: 16px; margin: 14px 0 6px; }
.netri-rich-content ul.netri-list { padding-left: 0; }
.netri-rich-content ul.netri-list li { padding: 6px 0 6px 26px; position: relative; color: #5a6378; font-size: 15px; border-bottom: none; }
.netri-rich-content ul.netri-list li:before { content:"\f00c"; font-family:FontAwesome; color:var(--netri-orange); position:absolute; left:0; top:8px; }
.netri-rich-content strong { color: var(--netri-navy); }

/* ===== Workshop detail page ===== */
.netri-workshop-meta { display: flex; gap: 20px; flex-wrap: wrap; justify-content: center; }
.netri-workshop-meta span { color: #cfd6e2; font-size: 15px; }
.netri-workshop-meta span i { color: var(--netri-orange); margin-right: 5px; }
.netri-badge-hero {
    display: inline-block; background: var(--netri-orange); color: #fff;
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 1.2px; padding: 5px 14px; border-radius: 4px;
}
.netri-takehome-box {
    display: flex; gap: 16px; align-items: flex-start;
    background: #eef5ff; border-left: 4px solid var(--netri-orange);
    padding: 18px 20px; border-radius: 0 8px 8px 0; margin: 28px 0;
}
.netri-takehome-box i { color: var(--netri-orange); font-size: 24px; flex-shrink: 0; margin-top: 2px; }
.netri-takehome-box strong { color: var(--netri-navy); display: block; margin-bottom: 4px; }
.netri-takehome-box p { color: #5a6378; margin: 0; font-size: 14px; }
.netri-detail-chip {
    background: #f7f9fc; border-radius: 10px; padding: 16px;
    display: flex; flex-direction: column; align-items: center; text-align: center;
    border: 1px solid #e8edf5;
}
.netri-detail-chip i { font-size: 22px; color: var(--netri-orange); margin-bottom: 6px; }
.netri-detail-chip .lbl { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: #9aa5b8; display: block; }
.netri-detail-chip .val { font-size: 14px; font-weight: 700; color: var(--netri-navy); display: block; margin-top: 2px; }
.netri-register-box {
    background: #fff; border-radius: 14px; padding: 32px;
    box-shadow: 0 8px 36px rgba(10,37,64,0.1);
    border-top: 4px solid var(--netri-orange);
    position: sticky; top: 100px;
}

/* Newsletter form expanded (footer) */
.newsletter-form input[type="text"] {
    width: 100%; padding: 12px 16px; border: 1px solid rgba(255,255,255,0.2);
    border-radius: 6px; background: rgba(255,255,255,0.1);
    color: #fff; font-size: 14px; outline: none;
}
.newsletter-form input[type="text"]::placeholder { color: rgba(255,255,255,0.55); }

/* General spacing cleanup */
.rs-subject.style1 { padding-top: 80px; padding-bottom: 60px; }
@media (max-width: 991px) {
    .netri-register-box { position: static; margin-top: 40px; }
    /* keep .netri-floats visible on mobile */
}
@media (max-width: 575px) {
    .netri-modal { padding: 28px 20px; }
    .netri-prog-card .card-foot { flex-direction: row; flex-wrap: wrap; align-items: center; justify-content: flex-start; gap: 8px; }
    .netri-prog-card .btn-learn, .netri-prog-card .btn-enquire { flex: 1 1 auto; text-align: center; justify-content: center; }
}

/* Logo sizing — high specificity to override base theme */
.full-width-header .rs-header .logo-part img,
.full-width-header .rs-header .menu-area .logo-part img {
    max-height: 110px !important;
    width: auto !important;
    transition: all 0.3s ease;
}
.full-width-header.header-style2.modify1 .rs-header .menu-area.sticky .logo-part img,
.full-width-header .rs-header .menu-area.sticky .logo-part img {
    max-height: 110px !important;
    width: auto !important;
}
.footer-logo img {
    max-height: 90px !important;
    width: auto !important;
}

/* ---------- Mobile header fixes ---------- */
.netri-mobile-menu-header { display: none; }
.netri-menu-backdrop { display: none; }

@media only screen and (max-width: 991px) {
    .netri-mobile-menu-header { display: flex; }
    .netri-menu-backdrop { display: block; }

    /* Lock the header (sticky) on mobile too */
    .full-width-header .rs-header .menu-area.menu-sticky,
    .full-width-header .rs-header .menu-area.menu-sticky.sticky {
        position: fixed !important;
        top: 0; left: 0; right: 0;
        width: 100%;
        z-index: 999;
        background: #fff !important;
        box-shadow: 0 2px 12px rgba(0,0,0,0.08) !important;
    }
    /* Push the body down so content isn't hidden under the fixed header */
    body { padding-top: 70px; }
    /* Remove the desktop hero top padding offset on mobile (body padding already handles it) */
    .netri-hero-carousel { padding-top: 0 !important; }

    /* Compact header height on mobile */
    .full-width-header .rs-header .menu-area .logo-cat-wrap,
    .full-width-header .rs-header .menu-area .rs-menu-area,
    .full-width-header .rs-header .menu-area.sticky .logo-cat-wrap {
        height: 70px !important;
        line-height: 70px !important;
    }
    .full-width-header .rs-header .logo-part img,
    .full-width-header .rs-header .menu-area .logo-part img,
    .full-width-header .rs-header .menu-area.sticky .logo-part img {
        max-height: 52px !important;
    }

    /* Make the hamburger icon visible against the white header */
    .rs-menu-toggle,
    .rs-menu-toggle i,
    .full-width-header .rs-header .menu-area .rs-menu-toggle {
        color: var(--netri-navy) !important;
        height: 70px !important;
        line-height: 70px !important;
    }

    /* === Off-canvas right-side mobile menu (replaces theme's inline dropdown) === */
    /* Lift the whole header above backdrop while menu is open so the panel isn't covered */
    body.netri-menu-open .full-width-header,
    body.netri-menu-open .full-width-header .menu-area,
    body.netri-menu-open .full-width-header .menu-area .container,
    body.netri-menu-open .full-width-header .menu-area .row,
    body.netri-menu-open .full-width-header .menu-area .main-menu {
        z-index: 100002 !important;
        position: relative;
    }
    /* Hide floating side CTAs while the off-canvas menu is open */
    body.netri-menu-open .netri-floats { opacity: 0; pointer-events: none; }

    /* Hide theme-injected sub-menu close button + expand chevrons inside our sidebar */
    .full-width-header .rs-header .menu-area .main-menu .rs-menu .sub-menu-close,
    .full-width-header .rs-header .menu-area .main-menu .rs-menu .rs-menu-parent,
    .full-width-header .rs-header .menu-area .main-menu .rs-menu .rs-menu-parent-arrow {
        display: none !important;
    }

    .full-width-header .rs-header .menu-area .main-menu .rs-menu {
        position: fixed !important;
        top: 0;
        right: 0;
        width: 86%;
        max-width: 340px;
        height: 100vh !important;
        background: #fff !important;
        z-index: 100001;
        transform: translateX(100%);
        transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: -10px 0 30px rgba(0,0,0,0.18);
        overflow-y: auto !important;
        padding: 0 !important;
        margin: 0 !important;
        display: block !important;
    }
    body.netri-menu-open .full-width-header .rs-header .menu-area .main-menu .rs-menu {
        transform: translateX(0);
    }
    .full-width-header .rs-header .menu-area .main-menu .rs-menu.rs-menu-close {
        overflow-y: auto !important;
    }
    .netri-mobile-menu-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 18px 22px;
        background: var(--netri-navy);
        color: #fff;
        position: sticky;
        top: 0;
        z-index: 2;
    }
    .netri-mobile-menu-title {
        font-size: 16px;
        font-weight: 700;
        letter-spacing: 1.5px;
        text-transform: uppercase;
        color: #fff;
    }
    .netri-mobile-menu-close {
        background: transparent;
        border: 0;
        color: #fff;
        font-size: 32px;
        line-height: 1;
        cursor: pointer;
        padding: 0 6px;
        transition: color 0.2s ease;
    }
    .netri-mobile-menu-close:hover { color: var(--netri-orange); }

    .full-width-header .rs-header .menu-area .main-menu .rs-menu ul.nav-menu {
        display: block !important;
        padding: 12px 0 80px !important;
        margin: 0 !important;
        background: #fff;
    }
    .full-width-header .rs-header .menu-area .main-menu .rs-menu ul.nav-menu > li {
        display: block !important;
        margin: 0 !important;
        border-bottom: 1px solid #eef0f5;
    }
    .full-width-header .rs-header .menu-area .main-menu .rs-menu ul.nav-menu li a,
    .full-width-header .rs-header .menu-area.sticky .main-menu .rs-menu ul.nav-menu li a {
        display: block !important;
        padding: 16px 24px !important;
        font-size: 15px !important;
        font-weight: 600 !important;
        letter-spacing: 0.5px;
        color: var(--netri-navy) !important;
        text-transform: uppercase;
        height: auto !important;
        line-height: 1.4 !important;
        transition: background 0.2s ease, color 0.2s ease, padding 0.2s ease;
    }
    .full-width-header .rs-header .menu-area .main-menu .rs-menu ul.nav-menu > li > a:hover,
    .full-width-header .rs-header .menu-area .main-menu .rs-menu ul.nav-menu > li.current-menu-item > a {
        background: #f4f6fa;
        color: var(--netri-orange) !important;
        padding-left: 30px !important;
    }
    .full-width-header .rs-header .menu-area .main-menu .rs-menu ul.sub-menu {
        position: static !important;
        opacity: 1 !important;
        visibility: visible !important;
        background: #f9fafc !important;
        box-shadow: none !important;
        padding: 4px 0 !important;
        margin: 0 !important;
        width: 100% !important;
        display: block !important;
    }
    .full-width-header .rs-header .menu-area .main-menu .rs-menu ul.sub-menu li a {
        padding: 12px 36px !important;
        font-size: 13px !important;
        color: #5b6b80 !important;
        text-transform: none !important;
        letter-spacing: 0 !important;
        font-weight: 500 !important;
    }
    .full-width-header .rs-header .menu-area .main-menu .rs-menu ul.sub-menu li a:hover {
        color: var(--netri-orange) !important;
        background: #fff;
    }

    /* Backdrop overlay (sibling of header) */
    .netri-menu-backdrop {
        position: fixed;
        inset: 0;
        background: rgba(10, 37, 64, 0.55);
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.3s ease, visibility 0.3s ease;
        z-index: 100000;
    }
    body.netri-menu-open .netri-menu-backdrop {
        opacity: 1;
        visibility: visible;
    }
    body.netri-menu-open { overflow: hidden; }

    /* Show the header "Free Demo" CTA on mobile (theme hides it by default) */
    .full-width-header.header-style2.modify1 .rs-header .menu-area .apply-btn,
    .full-width-header.header-style2 .rs-header .menu-area .expand-btn-inner ul,
    .full-width-header .rs-header .menu-area .expand-btn-inner ul,
    .full-width-header .rs-header .menu-area .expand-btn-inner .apply-btn {
        display: inline-block !important;
    }
    .full-width-header .rs-header .menu-area .expand-btn-inner {
        margin-right: 12px !important;
    }
    .full-width-header .rs-header .menu-area .expand-btn-inner .apply-btn {
        padding: 8px 16px !important;
        font-size: 12px !important;
    }
    .full-width-header .rs-header .menu-area .rs-menu-area {
        justify-content: flex-end;
    }

    /* Hero slide CTAs — make sure both are visible and readable on mobile */
    .netri-hero-slide h1 { font-size: 28px !important; line-height: 1.2 !important; margin-bottom: 14px !important; }
    .netri-hero-slide p  { font-size: 15px !important; margin-bottom: 20px !important; }
    .netri-hero-slide .btns { display: flex; flex-wrap: wrap; gap: 10px; }
    .netri-hero-slide .btns a {
        display: inline-block !important;
        margin: 0 !important;
        padding: 10px 20px !important;
        font-size: 13px !important;
    }

    /* Hero carousel side nav arrows — keep visible on mobile, smaller & tighter */
    .netri-hero-carousel .owl-nav { display: block !important; }
    .netri-hero-carousel .owl-nav button {
        display: flex !important;
        align-items: center;
        justify-content: center;
        width: 38px !important;
        height: 38px !important;
        font-size: 18px !important;
        opacity: 1 !important;
    }
    .netri-hero-carousel .owl-nav button.owl-prev { left: 8px !important; }
    .netri-hero-carousel .owl-nav button.owl-next { right: 8px !important; }
}

/* ---------- Program card "Learn More" button ---------- */
.netri-card-link,
.netri-card-link:hover,
.netri-card-link:focus {
    display: block;
    text-decoration: none !important;
    color: inherit !important;
}
.netri-card-link .subject-wrap {
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    cursor: pointer;
}
.netri-card-link:hover .subject-wrap {
    transform: translateY(-6px);
    box-shadow: 0 14px 36px rgba(0,0,0,0.12);
}
.netri-card-link:hover .netri-learn-more {
    background: var(--netri-orange);
    color: #fff;
}
.subject-wrap .netri-learn-more {
    display: inline-block;
    margin-top: 16px;
    padding: 9px 22px;
    background: var(--netri-navy);
    color: #fff !important;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    transition: all 0.25s ease;
}
.subject-wrap .netri-learn-more:hover {
    background: var(--netri-orange);
    color: #fff !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0,0,0,0.15);
}

/* ── Program inner page — card grid sections ── */
.prog-section { padding: 70px 0; }
.prog-section.alt-bg { background: #f7f9fc; }
.prog-section-header { margin-bottom: 36px; }
.prog-section-header h3 {
    color: var(--netri-navy);
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 6px;
    position: relative;
    padding-bottom: 14px;
}
.prog-section-header h3::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 48px;
    height: 3px;
    background: var(--netri-orange);
    border-radius: 2px;
}

/* Bullet-item cards */
.prog-card-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
@media (max-width: 991px) {
    .prog-card-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
    .prog-card-grid { grid-template-columns: 1fr; }
}

.prog-item-card {
    background: #fff;
    border-radius: 10px;
    padding: 18px 20px;
    box-shadow: 0 3px 16px rgba(10,37,64,0.07);
    display: flex;
    align-items: flex-start;
    gap: 14px;
    border-left: 3px solid var(--netri-orange);
    transition: box-shadow .25s, transform .25s;
}
.prog-item-card:hover {
    box-shadow: 0 8px 28px rgba(10,37,64,0.12);
    transform: translateY(-3px);
}
.prog-item-card .pic-icon {
    font-size: 17px;
    color: var(--netri-orange);
    margin-top: 2px;
    flex-shrink: 0;
    width: 34px;
    height: 34px;
    background: rgba(43,125,233,0.10);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.prog-item-card .pic-text {
    color: #3a4f69;
    font-size: 14.5px;
    line-height: 1.6;
}
.prog-item-card.outcome {
    border-left-color: #17a76c;
}
.prog-item-card.outcome .pic-icon {
    color: #17a76c;
    background: rgba(23,167,108,0.10);
}
.prog-item-card.audience {
    border-left-color: #f59e0b;
}
.prog-item-card.audience .pic-icon {
    color: #f59e0b;
    background: rgba(245,158,11,0.10);
}

/* Coming soon fallback card */
.prog-coming-soon-card {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    background: #fff;
    border: 2px dashed #c8d6e8;
    border-radius: 12px;
    padding: 28px 30px;
    max-width: 520px;
}
.prog-coming-soon-card .pic-icon {
    font-size: 22px;
    color: #8fa8c8;
    width: 44px;
    height: 44px;
    background: #edf2f9;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.prog-coming-soon-card strong {
    display: block;
    color: var(--netri-navy);
    font-size: 15px;
    margin-bottom: 4px;
}
.prog-coming-soon-card p {
    color: #6b7f96;
    font-size: 14px;
    margin: 0;
}

/* Program quick-info sidebar card */
.prog-info-card {
    background: #fff;
    border-radius: 12px;
    padding: 32px 30px;
    box-shadow: 0 10px 40px rgba(10,37,64,0.12);
    border: 1px solid #e1e4e8;
    position: sticky;
    top: 110px;
}
.prog-info-card h5 {
    color: var(--netri-navy);
    font-size: 16px;
    font-weight: 800;
    margin-bottom: 22px;
    display: flex;
    align-items: center;
    gap: 10px;
    letter-spacing: .5px;
    text-transform: uppercase;
    border-bottom: 2px solid #f0f2f5;
    padding-bottom: 15px;
}
.prog-info-card h5 i { color: var(--netri-orange); font-size: 18px; }
.prog-detail-list { list-style: none; padding: 0; margin: 0; }
.prog-detail-list li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px dashed #edf1f7;
    font-size: 15px;
    color: #44566c;
    line-height: 1.6;
}
.prog-detail-list li:last-child { border-bottom: 0; }
.prog-detail-list li i {
    color: var(--netri-orange);
    font-size: 15px;
    margin-top: 4px;
    flex-shrink: 0;
}

/* Responsive breakpoints */
@media (max-width: 991px) {
    .prog-card-grid { grid-template-columns: repeat(2, 1fr); }
    .prog-info-card { position: static; margin-bottom: 30px; }
}
@media (max-width: 575px) {
    .prog-card-grid { grid-template-columns: 1fr; }
    .prog-section { padding: 50px 0; }
}

