@import '_content/RapidFireUI/RapidFireUI.mqcw54sdph.bundle.scp.css';
@import '_content/SwiftCoreUI/SwiftCoreUI.wvjt3n8tqu.bundle.scp.css';

/* /BAD/Bill/RegisterProgress.razor.rz.scp.css */
/* Animations */
@keyframes spin-b-e6jvzejb24 {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes pulse-b-e6jvzejb24 {
    0%, 100% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }
}

@keyframes slideIn-b-e6jvzejb24 {
    from {
        transform: translateX(-20px);
        opacity: 0;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes checkmark-b-e6jvzejb24 {
    0% {
        transform: scale(0);
    }

    50% {
        transform: scale(1.2);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes float-b-e6jvzejb24 {
    0%, 100% {
        transform: translateY(0px);
    }

    50% {
        transform: translateY(-10px);
    }
}

@keyframes fadeInUp-b-e6jvzejb24 {
    from {
        transform: translateY(30px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes scaleIn-b-e6jvzejb24 {
    from {
        transform: scale(0.8);
        opacity: 0;
    }

    to {
        transform: scale(1);
        opacity: 1;
    }
}

/* Animation Classes */
.animate-spin[b-e6jvzejb24] {
    animation: spin-b-e6jvzejb24 1s linear infinite;
}

.animate-pulse[b-e6jvzejb24] {
    animation: pulse-b-e6jvzejb24 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

.animate-slide-in[b-e6jvzejb24] {
    animation: slideIn-b-e6jvzejb24 0.5s ease-out;
}

.animate-checkmark[b-e6jvzejb24] {
    animation: checkmark-b-e6jvzejb24 0.3s ease-out;
}

.animate-float[b-e6jvzejb24] {
    animation: float-b-e6jvzejb24 3s ease-in-out infinite;
}

.animate-fade-in-up[b-e6jvzejb24] {
    animation: fadeInUp-b-e6jvzejb24 0.8s ease-out;
}

.animate-scale-in[b-e6jvzejb24] {
    animation: scaleIn-b-e6jvzejb24 0.6s ease-out;
}

/* Progress Bar */
.progress-bar[b-e6jvzejb24] {
    transition: width 0.8s ease-in-out;
}

/* Background Pattern */
.bg-pattern[b-e6jvzejb24] {
    background-image: radial-gradient(circle at 25% 25%, rgba(99, 102, 241, 0.1) 0%, transparent 50%), radial-gradient(circle at 75% 75%, rgba(168, 85, 247, 0.1) 0%, transparent 50%);
}
/* /BAD/Bill/RegisterTenant.razor.rz.scp.css */
 Add this to your wwwroot/css/app.css or site.css 

.minimal-bg[b-te4f8z08jo] {
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
}

.glass-card[b-te4f8z08jo] {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
}

.floating-animation[b-te4f8z08jo] {
    animation: float-b-te4f8z08jo 4s ease-in-out infinite;
}

    .floating-animation:nth-child(2)[b-te4f8z08jo] {
        animation-delay: 1.5s;
    }

    .floating-animation:nth-child(3)[b-te4f8z08jo] {
        animation-delay: 3s;
    }

@keyframes float-b-te4f8z08jo {
    0%, 100% {
        transform: translateY(0px);
    }

    50% {
        transform: translateY(-8px);
    }
}

.illustration-side[b-te4f8z08jo] {
    background: linear-gradient(135deg, #ffffff 0%, #f1f5f9 100%);
}

 Ensure full height for the page 
html[b-te4f8z08jo], body[b-te4f8z08jo] {
    height: 100%;
    margin: 0;
    padding: 0;
}

#app[b-te4f8z08jo] {
    height: 100%;
}

 Override default validation styling 
.validation-message[b-te4f8z08jo] {
    color: #dc2626;
    font-size: 0.75rem;
    margin-top: 0.25rem;
}

.valid.modified:not([type=checkbox])[b-te4f8z08jo] {
    border-color: #10b981;
}

.invalid[b-te4f8z08jo] {
    border-color: #ef4444;
}

 Custom checkbox styling 
input[type="checkbox"][b-te4f8z08jo] {
    cursor: pointer;
}

 Ensure icons render properly 
svg[b-te4f8z08jo] {
    display: inline-block;
    vertical-align: middle;
}

 Loading spinner animation 
@keyframes spin[b-te4f8z08jo] {
    from {
        transform: rotate(0deg);
    }

    to[b-te4f8z08jo] {
        transform: rotate(360deg);
    }
}

.animate-spin[b-te4f8z08jo] {
    animation: spin 1s linear infinite;
}

 Responsive adjustments 
@media (max-width: 768px)[b-te4f8z08jo] {
    .illustration-side {
        display: none;
    }
}
/* /BAD/TenantHome.razor.rz.scp.css */
/* ===================================================
   EduFlow Academy – Blazor Stylesheet
   Place in: wwwroot/css/eduflow.css
   Reference in: App.razor / _Host.cshtml
   External deps (add to <head>):
     - https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css
     - https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&display=swap
     - https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap
   =================================================== */

/* ── Reset / Base ─────────────────────────────────── */
*[b-whpnq9ioru], *[b-whpnq9ioru]::before, *[b-whpnq9ioru]::after { box-sizing: border-box; margin: 0; padding: 0; }
:root[b-whpnq9ioru] {
    --blue:   #2563eb;
    --purple: #7c3aed;
    --green:  #16a34a;
    --orange: #ea580c;
    --teal:   #0d9488;
    --red:    #dc2626;
    --yellow: #ca8a04;
    --font-heading: 'Outfit', sans-serif;
    --font-body:    'Plus Jakarta Sans', sans-serif;
    --radius-sm: 0.75rem;
    --radius-lg: 1.25rem;
    --shadow:      0 8px 24px -4px rgba(20,20,60,.08);
    --shadow-hover:0 16px 40px -4px rgba(20,20,60,.14);
}
body[b-whpnq9ioru] { font-family: var(--font-body); background:#f9fafb; color:#111827; }
img[b-whpnq9ioru]  { display:block; max-width:100%; }
a[b-whpnq9ioru]    { text-decoration:none; color:inherit; }
ul[b-whpnq9ioru]   { list-style:none; }
.container[b-whpnq9ioru] { max-width:80rem; margin:0 auto; padding:0 1.5rem; }

/* ── Navigation ──────────────────────────────────── */
.nav-bar[b-whpnq9ioru] {
    position:sticky; top:0; z-index:50;
    background:rgba(255,255,255,.9); backdrop-filter:blur(12px);
    border-bottom:1px solid #f3f4f6;
    box-shadow:0 1px 4px rgba(0,0,0,.04);
}
.nav-inner[b-whpnq9ioru]  { display:flex; justify-content:space-between; align-items:center; height:5rem; }
.nav-brand[b-whpnq9ioru]  { display:flex; align-items:center; gap:3rem; }
.brand-link[b-whpnq9ioru] { display:flex; align-items:center; gap:.75rem; }
.brand-icon[b-whpnq9ioru] {
    width:2.5rem; height:2.5rem; border-radius:.75rem;
    background:linear-gradient(135deg,#2563eb,#7c3aed);
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size:1.1rem;
}
.brand-name[b-whpnq9ioru] { font-family:var(--font-heading); font-weight:700; font-size:1.25rem; color:#111827; display:block; line-height:1; }
.brand-sub[b-whpnq9ioru]  { font-size:.65rem; color:#6b7280; font-weight:500; letter-spacing:.08em; text-transform:uppercase; }
.nav-links[b-whpnq9ioru]  { display:none; gap:.25rem; }
@media(min-width:1024px){ .nav-links[b-whpnq9ioru]{display:flex;} }
.nav-link[b-whpnq9ioru]   { padding:.5rem 1rem; border-radius:9999px; font-size:.875rem; font-weight:500; color:#4b5563; transition:.2s; }
.nav-link:hover[b-whpnq9ioru]{ color:var(--blue); background:#f9fafb; }
.nav-link.active[b-whpnq9ioru]{ color:var(--blue); background:#eff6ff; font-weight:600; }
.nav-actions[b-whpnq9ioru]{ display:flex; align-items:center; gap:.75rem; }
.nav-divider[b-whpnq9ioru]{ width:1px; height:1.5rem; background:#e5e7eb; }
.btn-search[b-whpnq9ioru] { display:none; align-items:center; gap:.5rem; font-size:.875rem; color:#6b7280; background:none; border:none; cursor:pointer; }
@media(min-width:768px){ .btn-search[b-whpnq9ioru]{display:flex;} }
.btn-signin[b-whpnq9ioru] { background:none; border:none; font-size:.875rem; font-weight:500; color:#374151; cursor:pointer; padding:.5rem 1rem; }
.btn-signin:hover[b-whpnq9ioru]{ color:var(--blue); }
.btn-register[b-whpnq9ioru] {
    background:var(--blue); color:#fff; font-weight:600; font-size:.875rem;
    padding:.625rem 1.5rem; border:none; border-radius:9999px; cursor:pointer;
    transition:.2s; box-shadow:0 4px 12px rgba(37,99,235,.3);
}
.btn-register:hover[b-whpnq9ioru]{ background:#1d4ed8; }

/* ── Hero ────────────────────────────────────────── */
.hero-section[b-whpnq9ioru] { position:relative; background:#fff; overflow:hidden; padding:6rem 0 8rem; }
.hero-blob[b-whpnq9ioru] { position:absolute; border-radius:9999px; opacity:.6; pointer-events:none; }
.hero-blob-right[b-whpnq9ioru] { width:600px; height:600px; background:radial-gradient(circle,#eff6ff,transparent); top:-10rem; right:-10rem; }
.hero-blob-left[b-whpnq9ioru]  { width:24rem; height:24rem; background:#f5f3ff; filter:blur(3rem); bottom:-5rem; left:-5rem; opacity:.4; }
.hero-grid[b-whpnq9ioru] { display:grid; grid-template-columns:1fr; gap:4rem; align-items:center; }
@media(min-width:1024px){ .hero-grid[b-whpnq9ioru]{ grid-template-columns:1fr 1fr; } }

/* Left */
.hero-content[b-whpnq9ioru]{ text-align:center; }
@media(min-width:1024px){ .hero-content[b-whpnq9ioru]{ text-align:left; } }
.hero-badge[b-whpnq9ioru] {
    display:inline-flex; align-items:center; gap:.75rem;
    padding:.5rem 1rem; border-radius:9999px;
    background:#eff6ff; border:1px solid #bfdbfe;
    color:#1d4ed8; font-size:.875rem; font-weight:600; margin-bottom:1.5rem;
}
.badge-dot[b-whpnq9ioru] {
    width:.5rem; height:.5rem; background:#3b82f6; border-radius:9999px;
    animation:ping-b-whpnq9ioru 1.5s ease-in-out infinite;
}
@keyframes ping-b-whpnq9ioru {
    0%,100%{ transform:scale(1); opacity:1; }
    50%    { transform:scale(1.8); opacity:.4; }
}
.hero-heading[b-whpnq9ioru] {
    font-family:var(--font-heading); font-size:clamp(2.5rem,6vw,4.5rem);
    font-weight:800; color:#111827; line-height:1.1; letter-spacing:-.02em; margin-bottom:1.5rem;
}
.hero-heading-gradient[b-whpnq9ioru] { background:linear-gradient(90deg,var(--blue),var(--purple)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.hero-sub[b-whpnq9ioru] { font-size:1.125rem; color:#6b7280; line-height:1.75; margin-bottom:2.5rem; max-width:36rem; margin-left:auto; margin-right:auto; }
@media(min-width:1024px){ .hero-sub[b-whpnq9ioru]{ margin-left:0; } }
.hero-cta[b-whpnq9ioru] { display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; margin-bottom:2.5rem; }
@media(min-width:1024px){ .hero-cta[b-whpnq9ioru]{justify-content:flex-start;} }
.btn-primary-lg[b-whpnq9ioru] {
    background:var(--blue); color:#fff; padding:1rem 2rem; border-radius:var(--radius-lg);
    font-size:1.125rem; font-weight:600; border:none; cursor:pointer;
    box-shadow:0 12px 24px -4px rgba(37,99,235,.35); transition:.2s;
}
.btn-primary-lg:hover[b-whpnq9ioru]{ background:#1d4ed8; transform:translateY(-2px); }
.btn-secondary-lg[b-whpnq9ioru] {
    background:#fff; color:#374151; padding:1rem 2rem; border-radius:var(--radius-lg);
    font-size:1.125rem; font-weight:600; border:2px solid #f3f4f6; cursor:pointer; transition:.2s;
}
.btn-secondary-lg:hover[b-whpnq9ioru]{ border-color:#bfdbfe; color:var(--blue); box-shadow:var(--shadow); }

/* Role Panel */
.role-panel[b-whpnq9ioru] { background:#f9fafb; border-radius:1rem; padding:1.5rem; border:1px solid #f3f4f6; }
.role-panel-label[b-whpnq9ioru] { font-size:.7rem; font-weight:700; color:#9ca3af; text-transform:uppercase; letter-spacing:.1em; margin-bottom:1rem; }
.role-grid[b-whpnq9ioru] { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; }
@media(min-width:640px){ .role-grid[b-whpnq9ioru]{ grid-template-columns:repeat(4,1fr); } }
.role-btn[b-whpnq9ioru] {
    display:flex; flex-direction:column; align-items:center; gap:.5rem;
    padding:1rem; border-radius:.75rem; border:1px solid #e5e7eb;
    background:#fff; font-weight:600; font-size:.875rem; cursor:pointer; transition:.3s;
    box-shadow:0 1px 3px rgba(0,0,0,.06);
}
.role-icon[b-whpnq9ioru] { width:2.5rem; height:2.5rem; border-radius:9999px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; transition:.2s; }
.role-btn-blue  .role-icon[b-whpnq9ioru]{ background:#eff6ff; color:var(--blue); }
.role-btn-green .role-icon[b-whpnq9ioru]{ background:#f0fdf4; color:var(--green); }
.role-btn-purple.role-icon[b-whpnq9ioru]{ background:#f5f3ff; color:var(--purple); }
.role-btn-orange.role-icon[b-whpnq9ioru]{ background:#fff7ed; color:var(--orange); }
.role-btn-blue:hover[b-whpnq9ioru]  { background:var(--blue);   color:#fff; border-color:var(--blue);   box-shadow:0 8px 20px rgba(37,99,235,.25); }
.role-btn-green:hover[b-whpnq9ioru] { background:var(--green);  color:#fff; border-color:var(--green);  box-shadow:0 8px 20px rgba(22,163,74,.25); }
.role-btn-purple:hover[b-whpnq9ioru]{ background:var(--purple); color:#fff; border-color:var(--purple); box-shadow:0 8px 20px rgba(124,58,237,.25); }
.role-btn-orange:hover[b-whpnq9ioru]{ background:var(--orange); color:#fff; border-color:var(--orange); box-shadow:0 8px 20px rgba(234,88,12,.25); }
.role-btn:hover .role-icon[b-whpnq9ioru]{ background:rgba(255,255,255,.2); color:#fff; }
.role-selected-msg[b-whpnq9ioru] { margin-top:1rem; font-size:.875rem; color:var(--green); font-weight:500; }

/* Hero image */
.hero-image-wrap[b-whpnq9ioru] { position:relative; display:flex; align-items:center; justify-content:center; }
.hero-image-glow[b-whpnq9ioru] {
    position:absolute; inset:0; border-radius:9999px;
    background:linear-gradient(135deg,#dbeafe,#ede9fe); opacity:.6; filter:blur(3rem);
}
.hero-img[b-whpnq9ioru] { position:relative; z-index:1; width:100%; max-width:32rem; height:30rem; object-fit:cover; border-radius:1.5rem; box-shadow:0 24px 64px rgba(0,0,0,.18); }
.hero-float[b-whpnq9ioru] {
    position:absolute; z-index:2; background:#fff; padding:1rem; border-radius:1rem;
    box-shadow:0 8px 24px rgba(0,0,0,.12); display:flex; align-items:center; gap:.75rem;
    animation:float-b-whpnq9ioru 3s ease-in-out infinite;
}
@keyframes float-b-whpnq9ioru{ 0%,100%{transform:translateY(0);} 50%{transform:translateY(-6px);} }
.hero-float-tl[b-whpnq9ioru] { top:2rem; left:-1.5rem; animation-duration:3s; }
.hero-float-br[b-whpnq9ioru] { bottom:4rem; right:-1.5rem; animation-duration:4s; animation-delay:.5s; }
.hero-float-mr[b-whpnq9ioru] { top:50%; right:-1.5rem; transform:translateY(-50%); animation:none; }
.float-icon[b-whpnq9ioru] { width:2.5rem; height:2.5rem; border-radius:9999px; display:flex; align-items:center; justify-content:center; font-size:1rem; }
.float-icon-green[b-whpnq9ioru] { background:#dcfce7; color:var(--green); }
.float-icon-blue[b-whpnq9ioru]  { background:#dbeafe; color:var(--blue); }
.float-icon-purple[b-whpnq9ioru]{ background:#ede9fe; color:var(--purple); }
.float-label[b-whpnq9ioru] { font-size:.7rem; color:#9ca3af; font-weight:500; }
.float-value[b-whpnq9ioru] { font-size:.875rem; font-weight:700; color:#111827; }

/* ── Stats Bar ───────────────────────────────────── */
.stats-bar[b-whpnq9ioru] { background:var(--blue); padding:3rem 0; }
.stats-grid[b-whpnq9ioru] { display:grid; grid-template-columns:1fr 1fr; gap:2rem; text-align:center; }
@media(min-width:768px){ .stats-grid[b-whpnq9ioru]{ grid-template-columns:repeat(4,1fr); border-left: none; } }
.stat-item[b-whpnq9ioru] { padding:.5rem 0; border-left: 1px solid rgba(255,255,255,.2); }
.stat-item:first-child[b-whpnq9ioru]{ border-left:none; }
.stat-value[b-whpnq9ioru] { font-family:var(--font-heading); font-size:2.5rem; font-weight:700; color:#fff; line-height:1.1; }
.stat-label[b-whpnq9ioru] { font-size:.75rem; color:#bfdbfe; font-weight:500; text-transform:uppercase; letter-spacing:.08em; margin-top:.25rem; }

/* ── Section Helpers ─────────────────────────────── */
.section-white[b-whpnq9ioru]{ padding:6rem 0; background:#fff; }
.section-gray[b-whpnq9ioru] { padding:5rem 0; background:#f9fafb; }
.section-eyebrow[b-whpnq9ioru] { font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--blue); }
.eyebrow-purple[b-whpnq9ioru]{ color:var(--purple); }
.section-title[b-whpnq9ioru] { font-family:var(--font-heading); font-size:clamp(1.75rem,4vw,2.5rem); font-weight:700; color:#111827; margin-top:.5rem; }
.section-sub[b-whpnq9ioru]   { color:#6b7280; margin-top:.5rem; max-width:36rem; }
.section-header-row[b-whpnq9ioru] { display:flex; flex-direction:column; gap:1rem; margin-bottom:2.5rem; }
@media(min-width:768px){ .section-header-row[b-whpnq9ioru]{ flex-direction:row; justify-content:space-between; align-items:flex-end; } }
.section-header-center[b-whpnq9ioru]{ text-align:center; margin-bottom:4rem; }
.section-sub-center[b-whpnq9ioru]{ color:#6b7280; margin:1rem auto 0; max-width:40rem; }
.link-arrow[b-whpnq9ioru] { color:#6b7280; font-weight:500; font-size:.875rem; display:none; }
@media(min-width:768px){ .link-arrow[b-whpnq9ioru]{display:flex; align-items:center; gap:.5rem;} }
.link-arrow:hover[b-whpnq9ioru]{ color:var(--blue); }

/* ── Buttons (shared) ────────────────────────────── */
.btn-dark-pill[b-whpnq9ioru] { background:#111827; color:#fff; padding:.75rem 1.5rem; border-radius:9999px; font-size:.875rem; font-weight:600; transition:.2s; display:inline-flex; align-items:center; gap:.5rem; }
.btn-dark-pill:hover[b-whpnq9ioru]{ background:var(--blue); }
.btn-outline-pill[b-whpnq9ioru] { background:#fff; color:#374151; border:1px solid #d1d5db; padding:.625rem 1.5rem; border-radius:9999px; font-size:.875rem; font-weight:500; cursor:pointer; transition:.2s; }
.btn-outline-pill:hover[b-whpnq9ioru]{ background:#f9fafb; }

/* ── Filter Tabs ─────────────────────────────────── */
.filter-tabs[b-whpnq9ioru] { display:flex; flex-wrap:wrap; gap:.75rem; margin-bottom:2.5rem; }
.filter-btn[b-whpnq9ioru] {
    padding:.625rem 1.25rem; border-radius:9999px; border:1px solid #e5e7eb;
    font-size:.875rem; font-weight:600; color:#6b7280; background:#fff; cursor:pointer; transition:.2s;
}
.filter-btn:hover[b-whpnq9ioru]{ border-color:#93c5fd; color:var(--blue); }
.filter-btn-active[b-whpnq9ioru]{ background:var(--blue); color:#fff; border-color:var(--blue); }
.filter-icon[b-whpnq9ioru] { margin-right:.5rem; }
.filter-icon-blue[b-whpnq9ioru]  { color:#60a5fa; }
.filter-icon-purple[b-whpnq9ioru]{ color:#a78bfa; }
.filter-icon-yellow[b-whpnq9ioru]{ color:#fbbf24; }
.filter-icon-green[b-whpnq9ioru] { color:#4ade80; }
.filter-icon-orange[b-whpnq9ioru]{ color:#fb923c; }
.filter-btn-active .filter-icon[b-whpnq9ioru] { color:#fff !important; }

/* ── Course Cards ────────────────────────────────── */
.course-grid[b-whpnq9ioru] { display:grid; grid-template-columns:1fr; gap:2rem; }
@media(min-width:768px) { .course-grid[b-whpnq9ioru]{ grid-template-columns:1fr 1fr; } }
@media(min-width:1024px){ .course-grid[b-whpnq9ioru]{ grid-template-columns:repeat(3,1fr); } }
.course-card[b-whpnq9ioru] {
    background:#fff; border-radius:var(--radius-lg); border:1px solid #f3f4f6;
    overflow:hidden; box-shadow:var(--shadow); transition:all .3s; display:flex; flex-direction:column;
}
.course-card:hover[b-whpnq9ioru]{ box-shadow:var(--shadow-hover); transform:translateY(-4px); }
.course-card:hover .course-img[b-whpnq9ioru]{ transform:scale(1.07); }
.course-img-wrap[b-whpnq9ioru] { position:relative; height:12rem; overflow:hidden; }
.course-img[b-whpnq9ioru] { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.course-img-overlay[b-whpnq9ioru] { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.4),transparent); }
.course-badge[b-whpnq9ioru] { position:absolute; top:1rem; left:1rem; font-size:.7rem; font-weight:700; padding:.25rem .75rem; border-radius:9999px; text-transform:uppercase; letter-spacing:.06em; }
.course-badge-yellow[b-whpnq9ioru] { background:#fef08a; color:#854d0e; }
.course-badge-purple[b-whpnq9ioru] { background:var(--purple); color:#fff; }
.course-badge-blue[b-whpnq9ioru]   { background:#3b82f6; color:#fff; }
.course-badge-green[b-whpnq9ioru]  { background:#22c55e; color:#fff; }
.course-badge-orange[b-whpnq9ioru] { background:var(--orange); color:#fff; }
.course-level[b-whpnq9ioru] { position:absolute; top:1rem; right:1rem; background:rgba(255,255,255,.9); font-size:.7rem; font-weight:600; padding:.25rem .75rem; border-radius:9999px; color:#374151; }
.course-body[b-whpnq9ioru] { padding:1.5rem; display:flex; flex-direction:column; flex:1; }
.course-title[b-whpnq9ioru] { font-family:var(--font-heading); font-weight:700; color:#111827; font-size:1.05rem; margin-bottom:.5rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.course-card:hover .course-title[b-whpnq9ioru]{ color:var(--blue); }
.course-desc[b-whpnq9ioru]  { color:#9ca3af; font-size:.875rem; margin-bottom:1rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.course-instructor[b-whpnq9ioru] { display:flex; align-items:center; gap:.75rem; padding-bottom:1rem; border-bottom:1px solid #f3f4f6; margin-bottom:1rem; }
.instructor-avatar[b-whpnq9ioru] { width:2rem; height:2rem; border-radius:9999px; object-fit:cover; }
.instructor-label[b-whpnq9ioru]  { font-size:.7rem; color:#9ca3af; }
.instructor-name[b-whpnq9ioru]   { font-size:.875rem; font-weight:600; color:#374151; }
.course-meta[b-whpnq9ioru] { display:flex; justify-content:space-between; align-items:center; margin-bottom:1.25rem; font-size:.875rem; }
.course-rating[b-whpnq9ioru] { display:flex; align-items:center; gap:.2rem; }
.star-icon[b-whpnq9ioru] { color:#f59e0b; font-size:.7rem; }
.rating-val[b-whpnq9ioru]   { font-weight:600; color:#374151; margin-left:.25rem; }
.rating-count[b-whpnq9ioru] { color:#9ca3af; }
.course-stats[b-whpnq9ioru] { display:flex; gap:.75rem; color:#9ca3af; font-size:.7rem; }
.course-footer[b-whpnq9ioru] { display:flex; justify-content:space-between; align-items:center; margin-top:auto; }
.price-current[b-whpnq9ioru] { font-family:var(--font-heading); font-size:1.5rem; font-weight:700; color:#111827; }
.price-old[b-whpnq9ioru]     { font-size:.875rem; color:#9ca3af; text-decoration:line-through; margin-left:.5rem; }
.btn-enroll[b-whpnq9ioru] {
    color:#fff; padding:.625rem 1.25rem; border-radius:var(--radius-sm);
    font-size:.875rem; font-weight:600; border:none; cursor:pointer; transition:.2s;
}
.btn-enroll-blue[b-whpnq9ioru]  { background:var(--blue);   } .btn-enroll-blue:hover[b-whpnq9ioru]  { background:#1d4ed8; box-shadow:0 6px 16px rgba(37,99,235,.3); }
.btn-enroll-purple[b-whpnq9ioru]{ background:var(--purple); } .btn-enroll-purple:hover[b-whpnq9ioru]{ background:#6d28d9; box-shadow:0 6px 16px rgba(124,58,237,.3); }
.btn-enroll-green[b-whpnq9ioru] { background:var(--green);  } .btn-enroll-green:hover[b-whpnq9ioru] { background:#15803d; box-shadow:0 6px 16px rgba(22,163,74,.3); }
.btn-enroll-orange[b-whpnq9ioru]{ background:var(--orange); } .btn-enroll-orange:hover[b-whpnq9ioru]{ background:#c2410c; box-shadow:0 6px 16px rgba(234,88,12,.3); }

/* Enroll toast */
.enroll-toast[b-whpnq9ioru] {
    margin-top:2rem; padding:1rem 1.5rem; background:#f0fdf4; border:1px solid #bbf7d0;
    color:var(--green); border-radius:.75rem; font-weight:500; text-align:center;
    display:flex; align-items:center; justify-content:center; gap:.5rem;
}

/* CTA Banner */
.cta-banner[b-whpnq9ioru] {
    margin-top:3.5rem; border-radius:1.25rem; padding:2.5rem 3rem;
    background:linear-gradient(90deg,#2563eb,#1e40af,#7c3aed);
    display:flex; flex-direction:column; gap:1.5rem;
}
@media(min-width:768px){ .cta-banner[b-whpnq9ioru]{ flex-direction:row; justify-content:space-between; align-items:center; } }
.cta-title[b-whpnq9ioru] { font-family:var(--font-heading); font-size:1.75rem; font-weight:700; color:#fff; }
.cta-sub[b-whpnq9ioru]   { color:#bfdbfe; margin-top:.25rem; }
.cta-actions[b-whpnq9ioru] { display:flex; flex-wrap:wrap; gap:1rem; }
.btn-cta-white[b-whpnq9ioru]   { background:#fff; color:#1d4ed8; padding:.875rem 1.75rem; border-radius:9999px; font-weight:600; border:none; cursor:pointer; transition:.2s; white-space:nowrap; }
.btn-cta-white:hover[b-whpnq9ioru]{ background:#eff6ff; }
.btn-cta-outline[b-whpnq9ioru] { background:transparent; color:#fff; padding:.875rem 1.75rem; border-radius:9999px; font-weight:600; border:2px solid rgba(255,255,255,.5); cursor:pointer; transition:.2s; white-space:nowrap; }
.btn-cta-outline:hover[b-whpnq9ioru]{ border-color:#fff; }

/* ── Events ──────────────────────────────────────── */
.events-grid[b-whpnq9ioru] { display:grid; grid-template-columns:1fr; gap:2rem; }
@media(min-width:768px){ .events-grid[b-whpnq9ioru]{ grid-template-columns:repeat(3,1fr); } }
.event-card[b-whpnq9ioru] {
    background:#fff; border-radius:1rem; border:1px solid #f3f4f6;
    padding:1.5rem; transition:.3s;
}
.event-card:hover[b-whpnq9ioru]{ transform:translateY(-4px); box-shadow:0 12px 32px rgba(37,99,235,.08); }
.event-card-top[b-whpnq9ioru] { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:1.5rem; }
.event-date[b-whpnq9ioru] { border-radius:.75rem; padding:.5rem 1rem; text-align:center; min-width:5rem; }
.event-date-blue[b-whpnq9ioru]   { background:#eff6ff; color:#1d4ed8; }
.event-date-purple[b-whpnq9ioru] { background:#f5f3ff; color:#6d28d9; }
.event-date-green[b-whpnq9ioru]  { background:#f0fdf4; color:#15803d; }
.event-month[b-whpnq9ioru] { display:block; font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; }
.event-day[b-whpnq9ioru]   { display:block; font-size:1.5rem; font-weight:700; }
.event-tag[b-whpnq9ioru]   { font-size:.75rem; color:#6b7280; background:#f3f4f6; padding:.25rem .75rem; border-radius:9999px; font-weight:500; }
.event-title[b-whpnq9ioru] { font-family:var(--font-heading); font-size:1.125rem; font-weight:700; color:#111827; margin-bottom:.75rem; }
.event-card:hover .event-title[b-whpnq9ioru] { color:var(--blue); }
.event-desc[b-whpnq9ioru]  { font-size:.875rem; color:#6b7280; margin-bottom:1rem; }
.event-time[b-whpnq9ioru]  { font-size:.875rem; color:#9ca3af; display:flex; align-items:center; gap:.5rem; }

/* ── Academic Services ───────────────────────────── */
.services-grid[b-whpnq9ioru] { display:grid; grid-template-columns:1fr; gap:1.5rem; }
@media(min-width:768px) { .services-grid[b-whpnq9ioru]{ grid-template-columns:1fr 1fr; } }
@media(min-width:1024px){ .services-grid[b-whpnq9ioru]{ grid-template-columns:repeat(3,1fr); } }
.service-card[b-whpnq9ioru] {
    position:relative; overflow:hidden; border-radius:1rem; padding:2rem;
    background:#fff; border:1px solid #f3f4f6; box-shadow:0 1px 3px rgba(0,0,0,.05);
    display:block; transition:.3s;
}
.service-card:hover[b-whpnq9ioru]{ transform:translateY(-4px); }
.service-corner[b-whpnq9ioru] {
    position:absolute; top:0; right:0; width:4rem; height:4rem;
    transform:translate(2rem,-2rem) rotate(45deg); transition:transform .2s;
}
.service-card:hover .service-corner[b-whpnq9ioru]{ transform:translate(1.5rem,-1.5rem) rotate(45deg) scale(1.1); }
.service-corner-blue[b-whpnq9ioru]  { background:var(--blue); }
.service-corner-purple[b-whpnq9ioru]{ background:var(--purple); }
.service-corner-orange[b-whpnq9ioru]{ background:var(--orange); }
.service-corner-green[b-whpnq9ioru] { background:var(--green); }
.service-corner-teal[b-whpnq9ioru]  { background:var(--teal); }
.service-corner-red[b-whpnq9ioru]   { background:var(--red); }
.service-icon[b-whpnq9ioru] {
    width:3.5rem; height:3.5rem; border-radius:1rem;
    display:flex; align-items:center; justify-content:center;
    font-size:1.4rem; margin-bottom:1.5rem; transition:.2s;
}
.service-icon-blue[b-whpnq9ioru]   { background:#eff6ff; color:var(--blue); }
.service-icon-purple[b-whpnq9ioru] { background:#f5f3ff; color:var(--purple); }
.service-icon-orange[b-whpnq9ioru] { background:#fff7ed; color:var(--orange); }
.service-icon-green[b-whpnq9ioru]  { background:#f0fdf4; color:var(--green); }
.service-icon-teal[b-whpnq9ioru]   { background:#f0fdfa; color:var(--teal); }
.service-icon-red[b-whpnq9ioru]    { background:#fef2f2; color:var(--red); }
.service-card-blue:hover   .service-icon[b-whpnq9ioru] { background:var(--blue);   color:#fff; }
.service-card-purple:hover .service-icon[b-whpnq9ioru] { background:var(--purple); color:#fff; }
.service-card-orange:hover .service-icon[b-whpnq9ioru] { background:var(--orange); color:#fff; }
.service-card-green:hover  .service-icon[b-whpnq9ioru] { background:var(--green);  color:#fff; }
.service-card-teal:hover   .service-icon[b-whpnq9ioru] { background:var(--teal);   color:#fff; }
.service-card-red:hover    .service-icon[b-whpnq9ioru] { background:var(--red);    color:#fff; }
.service-card-blue:hover[b-whpnq9ioru]   { box-shadow:0 12px 32px rgba(37,99,235,.1); border-color:#bfdbfe; }
.service-card-purple:hover[b-whpnq9ioru] { box-shadow:0 12px 32px rgba(124,58,237,.1); border-color:#ddd6fe; }
.service-card-orange:hover[b-whpnq9ioru] { box-shadow:0 12px 32px rgba(234,88,12,.1); border-color:#fed7aa; }
.service-card-green:hover[b-whpnq9ioru]  { box-shadow:0 12px 32px rgba(22,163,74,.1); border-color:#bbf7d0; }
.service-card-teal:hover[b-whpnq9ioru]   { box-shadow:0 12px 32px rgba(13,148,136,.1); border-color:#99f6e4; }
.service-card-red:hover[b-whpnq9ioru]    { box-shadow:0 12px 32px rgba(220,38,38,.1); border-color:#fecaca; }
.service-title[b-whpnq9ioru] { font-family:var(--font-heading); font-size:1.125rem; font-weight:700; color:#111827; margin-bottom:.75rem; }
.service-desc[b-whpnq9ioru]  { color:#6b7280; font-size:.9rem; line-height:1.6; margin-bottom:1.5rem; }
.service-link[b-whpnq9ioru]  { font-size:.875rem; font-weight:600; display:inline-flex; align-items:center; gap:.5rem; transition:transform .2s; }
.service-card:hover .service-link[b-whpnq9ioru]{ transform:translateX(4px); }
.service-link-blue[b-whpnq9ioru]  { color:var(--blue); }
.service-link-purple[b-whpnq9ioru]{ color:var(--purple); }
.service-link-orange[b-whpnq9ioru]{ color:var(--orange); }
.service-link-green[b-whpnq9ioru] { color:var(--green); }
.service-link-teal[b-whpnq9ioru]  { color:var(--teal); }
.service-link-red[b-whpnq9ioru]   { color:var(--red); }

/* ── Campus Life ─────────────────────────────────── */
.campus-grid[b-whpnq9ioru] { display:grid; grid-template-columns:1fr; gap:3rem; }
@media(min-width:1024px){ .campus-grid[b-whpnq9ioru]{ grid-template-columns:1fr 2fr; } }
.campus-desc[b-whpnq9ioru] { color:#6b7280; margin-bottom:2rem; line-height:1.75; }
.campus-activities[b-whpnq9ioru] { display:flex; flex-direction:column; gap:1rem; }
.activity-item[b-whpnq9ioru] {
    display:flex; align-items:center; gap:1rem;
    padding:1rem; border-radius:.75rem; border:1px solid #f3f4f6;
    background:#fff; cursor:pointer; transition:.2s;
}
.activity-item:hover[b-whpnq9ioru] { }
.activity-item-purple:hover[b-whpnq9ioru]{ background:#f5f3ff; }
.activity-item-blue:hover[b-whpnq9ioru]  { background:#eff6ff; }
.activity-item-green:hover[b-whpnq9ioru] { background:#f0fdf4; }
.activity-icon[b-whpnq9ioru] {
    width:2.5rem; height:2.5rem; border-radius:9999px;
    background:#fff; border:1px solid #f3f4f6; box-shadow:0 1px 3px rgba(0,0,0,.06);
    display:flex; align-items:center; justify-content:center; transition:transform .2s;
}
.activity-item:hover .activity-icon[b-whpnq9ioru] { transform:scale(1.1); }
.activity-icon-purple[b-whpnq9ioru]{ color:var(--purple); }
.activity-icon-blue[b-whpnq9ioru]  { color:var(--blue); }
.activity-icon-green[b-whpnq9ioru] { color:var(--green); }
.activity-title[b-whpnq9ioru] { font-weight:700; color:#111827; font-size:.9rem; }
.activity-sub[b-whpnq9ioru]   { font-size:.75rem; color:#9ca3af; }
.campus-photos[b-whpnq9ioru] { display:grid; grid-template-columns:1fr 1fr; gap:1rem; height:26rem; }
.campus-photo-main[b-whpnq9ioru], .campus-photo-sm[b-whpnq9ioru] { position:relative; border-radius:1rem; overflow:hidden; }
.campus-photo-col[b-whpnq9ioru]  { display:grid; grid-template-rows:1fr 1fr; gap:1rem; }
.campus-img[b-whpnq9ioru] { width:100%; height:100%; object-fit:cover; transition:transform .7s; }
.campus-photo-main:hover .campus-img[b-whpnq9ioru],
.campus-photo-sm:hover   .campus-img[b-whpnq9ioru] { transform:scale(1.1); }
.campus-img-caption[b-whpnq9ioru] {
    position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.6),transparent);
    opacity:0; transition:.3s; display:flex; align-items:flex-end; padding:1.5rem;
    color:#fff; font-weight:500; font-size:.875rem;
}
.campus-photo-main:hover .campus-img-caption[b-whpnq9ioru],
.campus-photo-sm:hover   .campus-img-caption[b-whpnq9ioru] { opacity:1; }

/* ── News ────────────────────────────────────────── */
.news-grid[b-whpnq9ioru] { display:grid; grid-template-columns:1fr; gap:2rem; }
@media(min-width:768px){ .news-grid[b-whpnq9ioru]{ grid-template-columns:repeat(3,1fr); } }
.news-card[b-whpnq9ioru] {
    background:#fff; border-radius:1rem; border:1px solid #f3f4f6;
    overflow:hidden; box-shadow:0 1px 3px rgba(0,0,0,.05);
    display:flex; flex-direction:column; transition:.3s;
}
.news-card:hover[b-whpnq9ioru]{ transform:translateY(-4px); box-shadow:0 12px 32px rgba(37,99,235,.08); }
.news-img-wrap[b-whpnq9ioru] { height:14rem; overflow:hidden; position:relative; }
.news-img[b-whpnq9ioru] { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.news-card:hover .news-img[b-whpnq9ioru]{ transform:scale(1.05); }
.news-tag[b-whpnq9ioru] {
    position:absolute; top:1rem; left:1rem;
    background:rgba(255,255,255,.9); backdrop-filter:blur(4px);
    font-size:.65rem; font-weight:700; color:#111827; padding:.25rem .75rem; border-radius:.5rem;
}
.news-body[b-whpnq9ioru] { padding:1.5rem; flex:1; display:flex; flex-direction:column; }
.news-date[b-whpnq9ioru]  { font-size:.75rem; color:#9ca3af; margin-bottom:.75rem; display:flex; align-items:center; gap:.5rem; }
.news-title[b-whpnq9ioru] { font-family:var(--font-heading); font-size:1.1rem; font-weight:700; color:#111827; margin-bottom:.75rem; }
.news-card:hover .news-title[b-whpnq9ioru]{ color:var(--blue); }
.news-excerpt[b-whpnq9ioru] { font-size:.875rem; color:#6b7280; line-height:1.6; flex:1; margin-bottom:1rem; }
.news-link[b-whpnq9ioru] { font-size:.875rem; font-weight:600; color:var(--blue); display:inline-flex; align-items:center; gap:.5rem; }
.news-link:hover[b-whpnq9ioru]{ text-decoration:underline; }

/* ── Footer ──────────────────────────────────────── */
.footer[b-whpnq9ioru] { background:#111827; color:#fff; padding:5rem 1.5rem 2.5rem; }
.footer-grid[b-whpnq9ioru] { display:grid; grid-template-columns:1fr; gap:3rem; margin-bottom:4rem; }
@media(min-width:768px) { .footer-grid[b-whpnq9ioru]{ grid-template-columns:1fr 1fr; } }
@media(min-width:1024px){ .footer-grid[b-whpnq9ioru]{ grid-template-columns:2fr 1fr 1fr 1.5fr; } }
.footer-logo[b-whpnq9ioru] { display:flex; align-items:center; gap:.75rem; margin-bottom:1.5rem; }
.footer-logo-icon[b-whpnq9ioru] {
    width:2.5rem; height:2.5rem; border-radius:.5rem;
    background:linear-gradient(135deg,var(--blue),var(--purple));
    display:flex; align-items:center; justify-content:center; color:#fff;
}
.footer-logo-name[b-whpnq9ioru] { font-family:var(--font-heading); font-size:1.5rem; font-weight:700; }
.footer-tagline[b-whpnq9ioru] { color:#9ca3af; font-size:.875rem; line-height:1.7; margin-bottom:1.5rem; }
.footer-socials[b-whpnq9ioru] { display:flex; gap:.75rem; }
.social-btn[b-whpnq9ioru] {
    width:2.5rem; height:2.5rem; border-radius:9999px;
    background:#1f2937; color:#9ca3af;
    display:flex; align-items:center; justify-content:center; transition:.2s;
}
.social-btn:hover[b-whpnq9ioru]{ background:var(--blue); color:#fff; }
.footer-col-title[b-whpnq9ioru] { font-family:var(--font-heading); font-weight:700; font-size:1.125rem; margin-bottom:1.5rem; }
.footer-links li[b-whpnq9ioru] { margin-bottom:.75rem; }
.footer-links a[b-whpnq9ioru] { color:#9ca3af; font-size:.875rem; transition:.2s; }
.footer-links a:hover[b-whpnq9ioru]{ color:#60a5fa; }
.footer-contact[b-whpnq9ioru] { display:flex; flex-direction:column; gap:1rem; }
.footer-contact li[b-whpnq9ioru] { display:flex; align-items:flex-start; gap:.75rem; color:#9ca3af; font-size:.875rem; }
.footer-contact li i[b-whpnq9ioru] { color:var(--blue); margin-top:.15rem; min-width:1rem; }
.footer-bottom[b-whpnq9ioru] {
    border-top:1px solid #1f2937; padding-top:2rem;
    display:flex; flex-direction:column; gap:1rem;
    color:#6b7280; font-size:.875rem;
}
@media(min-width:768px){ .footer-bottom[b-whpnq9ioru]{ flex-direction:row; justify-content:space-between; align-items:center; } }
.footer-bottom-links[b-whpnq9ioru] { display:flex; gap:1.5rem; }
.footer-bottom-links a[b-whpnq9ioru] { color:#6b7280; transition:.2s; }
.footer-bottom-links a:hover[b-whpnq9ioru]{ color:#fff; }
/* /Pages/Home.razor.rz.scp.css */
/* ===================================================
   EduFlow Academy – Blazor Stylesheet  (FINAL)
   All var() calls include hardcoded fallbacks so they
   work even if :root is partially blocked by Bootstrap.
   Critical backgrounds use !important to beat framework resets.
   =================================================== */

*[b-mb31mmi986], *[b-mb31mmi986]::before, *[b-mb31mmi986]::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

:root[b-mb31mmi986] {
    --blue: #2563eb;
    --blue-dark: #1d4ed8;
    --purple: #7c3aed;
    --purple-dark: #6d28d9;
    --green: #16a34a;
    --green-dark: #15803d;
    --orange: #ea580c;
    --orange-dark: #c2410c;
    --teal: #0d9488;
    --red: #dc2626;
    --font-heading: 'Outfit', sans-serif;
    --font-body: 'Plus Jakarta Sans', sans-serif;
    --shadow: 0 8px 24px -4px rgba(20,20,60,.08);
    --shadow-hover: 0 16px 40px -4px rgba(20,20,60,.14);
}

body[b-mb31mmi986] {
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
    background: #f9fafb;
    color: #111827;
}

img[b-mb31mmi986] {
    display: block;
    max-width: 100%;
}

a[b-mb31mmi986] {
    text-decoration: none;
    color: inherit;
}

ul[b-mb31mmi986] {
    list-style: none;
}

button[b-mb31mmi986] {
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
}

.container[b-mb31mmi986] {
    max-width: 80rem;
    margin: 0 auto;
    padding: 0 1rem;
}

@media (min-width: 640px) {
    .container[b-mb31mmi986] {
        padding: 0 1.5rem;
    }
}

/* ══════════════════════════════════════════════════════
   NAVIGATION
══════════════════════════════════════════════════════ */
.nav-bar[b-mb31mmi986] {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(255,255,255,.95) !important;
    backdrop-filter: blur(12px);
    border-bottom: 1px solid #f3f4f6;
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

.nav-inner[b-mb31mmi986] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 4rem;
}

@media (min-width: 768px) {
    .nav-inner[b-mb31mmi986] {
        height: 5rem;
    }
}

.nav-brand[b-mb31mmi986] {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    min-width: 0;
}

@media (min-width: 1024px) {
    .nav-brand[b-mb31mmi986] {
        gap: 3rem;
    }
}

.brand-link[b-mb31mmi986] {
    display: flex;
    align-items: center;
    gap: .6rem;
    min-width: 0;
}

/* ── Logo icon: gradient blue→purple ── */
.brand-icon[b-mb31mmi986] {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: .75rem;
    flex-shrink: 0;
    background: linear-gradient(135deg, #2563eb, #7c3aed) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff !important;
    font-size: 1rem;
    box-shadow: 0 4px 12px rgba(37,99,235,.3);
}

@media (min-width: 768px) {
    .brand-icon[b-mb31mmi986] {
        width: 2.5rem;
        height: 2.5rem;
        font-size: 1.1rem;
    }
}

.brand-name[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-weight: 700;
    font-size: 1.1rem;
    color: #111827 !important;
    display: block;
    line-height: 1;
    white-space: nowrap;
}

@media (min-width: 768px) {
    .brand-name[b-mb31mmi986] {
        font-size: 1.25rem;
    }
}

.brand-sub[b-mb31mmi986] {
    font-size: .6rem;
    color: #6b7280;
    font-weight: 500;
    letter-spacing: .08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.nav-links[b-mb31mmi986] {
    display: none;
    align-items: center;
    gap: .25rem;
}

@media (min-width: 1024px) {
    .nav-links[b-mb31mmi986] {
        display: flex;
    }
}

.nav-link[b-mb31mmi986] {
    padding: .5rem 1rem;
    border-radius: 9999px;
    font-size: .875rem;
    font-weight: 500;
    color: #4b5563;
    transition: .2s;
    white-space: nowrap;
}

    .nav-link:hover[b-mb31mmi986] {
        color: #2563eb;
        background: #f9fafb;
    }

    .nav-link.active[b-mb31mmi986] {
        color: #2563eb;
        background: #eff6ff;
        font-weight: 600;
    }

.nav-actions[b-mb31mmi986] {
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-shrink: 0;
}

@media (min-width: 640px) {
    .nav-actions[b-mb31mmi986] {
        gap: .75rem;
    }
}

.nav-divider[b-mb31mmi986] {
    width: 1px;
    height: 1.5rem;
    background: #e5e7eb;
    display: none;
}

@media (min-width: 768px) {
    .nav-divider[b-mb31mmi986] {
        display: block;
    }
}

.btn-search[b-mb31mmi986] {
    display: none;
    align-items: center;
    gap: .5rem;
    font-size: .875rem;
    color: #6b7280;
    background: none;
    border: none;
    cursor: pointer;
}

@media (min-width: 768px) {
    .btn-search[b-mb31mmi986] {
        display: flex;
    }
}

.btn-signin[b-mb31mmi986] {
    display: none;
    background: none !important;
    border: none;
    font-size: .875rem;
    font-weight: 500;
    color: #374151;
    cursor: pointer;
    padding: .5rem .75rem;
    transition: .2s;
}

@media (min-width: 480px) {
    .btn-signin[b-mb31mmi986] {
        display: block;
    }
}

.btn-signin:hover[b-mb31mmi986] {
    color: #2563eb;
}

/* ── Register button: solid blue ── */
.btn-register[b-mb31mmi986] {
    background-color: #2563eb !important;
    color: #fff !important;
    font-weight: 600;
    font-size: .8rem;
    padding: .5rem 1rem;
    border: none !important;
    border-radius: 9999px;
    cursor: pointer;
    white-space: nowrap;
    box-shadow: 0 10px 15px -3px rgba(191,219,254,.9), 0 4px 6px -4px rgba(191,219,254,.9);
    transition: all .25s ease;
}

@media (min-width: 640px) {
    .btn-register[b-mb31mmi986] {
        font-size: .875rem;
        padding: .625rem 1.5rem;
    }
}

.btn-register:hover[b-mb31mmi986] {
    background-color: #1d4ed8 !important;
    box-shadow: 0 10px 15px -3px rgba(147,197,253,.9), 0 4px 6px -4px rgba(147,197,253,.9);
}

/* ══════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════ */
.hero-section[b-mb31mmi986] {
    position: relative;
    background: #fff !important;
    overflow: hidden;
    padding: 3rem 0 4rem;
}

@media (min-width: 768px) {
    .hero-section[b-mb31mmi986] {
        padding: 4rem 0 6rem;
    }
}

@media (min-width: 1024px) {
    .hero-section[b-mb31mmi986] {
        padding: 6rem 0 8rem;
    }
}

.hero-blob[b-mb31mmi986] {
    position: absolute;
    border-radius: 9999px;
    pointer-events: none;
}

.hero-blob-right[b-mb31mmi986] {
    width: 400px;
    height: 400px;
    background: radial-gradient(circle,#eff6ff,transparent);
    top: -8rem;
    right: -8rem;
    opacity: .7;
}

@media (min-width: 768px) {
    .hero-blob-right[b-mb31mmi986] {
        width: 600px;
        height: 600px;
        top: -10rem;
        right: -10rem;
    }
}

.hero-blob-left[b-mb31mmi986] {
    width: 16rem;
    height: 16rem;
    background: #f5f3ff;
    filter: blur(3rem);
    bottom: -4rem;
    left: -4rem;
    opacity: .5;
}

@media (min-width: 768px) {
    .hero-blob-left[b-mb31mmi986] {
        width: 24rem;
        height: 24rem;
        bottom: -5rem;
        left: -5rem;
    }
}

.hero-grid[b-mb31mmi986] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    align-items: center;
}

@media (min-width: 1024px) {
    .hero-grid[b-mb31mmi986] {
        grid-template-columns: 1fr 1fr;
        gap: 4rem;
    }
}

.hero-content[b-mb31mmi986] {
    text-align: center;
    position: relative;
    z-index: 1;
}

@media (min-width: 1024px) {
    .hero-content[b-mb31mmi986] {
        text-align: left;
    }
}

.hero-badge[b-mb31mmi986] {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    padding: .4rem .875rem;
    border-radius: 9999px;
    background: #eff6ff !important;
    border: 1px solid #bfdbfe;
    color: #1d4ed8 !important;
    font-size: .8rem;
    font-weight: 600;
    margin-bottom: 1.25rem;
}

@media (min-width: 640px) {
    .hero-badge[b-mb31mmi986] {
        padding: .5rem 1rem;
        font-size: .875rem;
        margin-bottom: 1.5rem;
    }
}

.badge-dot[b-mb31mmi986] {
    position: relative;
    display: inline-flex;
    width: .5rem;
    height: .5rem;
    flex-shrink: 0;
}

    .badge-dot[b-mb31mmi986]::before {
        content: '';
        position: absolute;
        inset: 0;
        border-radius: 9999px;
        background: #3b82f6;
        opacity: .75;
        animation: pingAnim-b-mb31mmi986 1.5s cubic-bezier(0,0,.2,1) infinite;
    }

    .badge-dot[b-mb31mmi986]::after {
        content: '';
        position: relative;
        display: block;
        width: .5rem;
        height: .5rem;
        border-radius: 9999px;
        background: #3b82f6;
    }

@keyframes pingAnim-b-mb31mmi986 {
    75%,100% {
        transform: scale(2);
        opacity: 0;
    }
}

.hero-heading[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-size: clamp(2rem,8vw,4.5rem);
    font-weight: 800;
    color: #111827;
    line-height: 1.1;
    letter-spacing: -.02em;
    margin-bottom: 1.25rem;
}

.hero-heading-gradient[b-mb31mmi986] {
    display: inline-block;
    background: linear-gradient(90deg, #2563eb, #7c3aed) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    color: transparent !important;
}

.hero-sub[b-mb31mmi986] {
    font-size: 1rem;
    color: #6b7280;
    line-height: 1.75;
    margin: 0 auto 2rem;
    max-width: 36rem;
}

@media (min-width: 640px) {
    .hero-sub[b-mb31mmi986] {
        font-size: 1.125rem;
        margin-bottom: 2.5rem;
    }
}

@media (min-width: 1024px) {
    .hero-sub[b-mb31mmi986] {
        margin-left: 0;
    }
}

.hero-cta[b-mb31mmi986] {
    display: flex;
    flex-direction: column;
    gap: .875rem;
    align-items: center;
    margin-bottom: 2rem;
}

@media (min-width: 480px) {
    .hero-cta[b-mb31mmi986] {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
    }
}

@media (min-width: 1024px) {
    .hero-cta[b-mb31mmi986] {
        justify-content: flex-start;
        margin-bottom: 2.5rem;
    }
}

/* ── Student Registration button: solid blue, xl blue shadow ── */
.btn-primary-lg[b-mb31mmi986] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    background-color: #2563eb !important;
    color: #fff !important;
    padding: .875rem 1.75rem;
    border-radius: 1.25rem;
    width: 100%;
    font-size: 1rem;
    font-weight: 600;
    border: none !important;
    cursor: pointer;
    box-shadow: 0 20px 25px -5px rgba(191,219,254,.9), 0 8px 10px -6px rgba(191,219,254,.9);
    transition: all .25s ease;
}

@media (min-width: 480px) {
    .btn-primary-lg[b-mb31mmi986] {
        width: auto;
        font-size: 1.125rem;
        padding: 1rem 2rem;
    }
}

.btn-primary-lg:hover[b-mb31mmi986] {
    background-color: #1d4ed8 !important;
    box-shadow: 0 20px 25px -5px rgba(147,197,253,.9), 0 8px 10px -6px rgba(147,197,253,.9);
    transform: translateY(-2px);
}

.btn-secondary-lg[b-mb31mmi986] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    background: #fff !important;
    color: #374151 !important;
    padding: .875rem 1.75rem;
    border-radius: 1.25rem;
    width: 100%;
    font-size: 1rem;
    font-weight: 600;
    border: 2px solid #e5e7eb !important;
    cursor: pointer;
    transition: all .2s;
}

@media (min-width: 480px) {
    .btn-secondary-lg[b-mb31mmi986] {
        width: auto;
        font-size: 1.125rem;
        padding: 1rem 2rem;
    }
}

.btn-secondary-lg:hover[b-mb31mmi986] {
    border-color: #bfdbfe !important;
    color: #2563eb !important;
    box-shadow: 0 8px 24px -4px rgba(20,20,60,.08);
}

/* ── Role Panel ── */
.role-panel[b-mb31mmi986] {
    background: #f9fafb !important;
    border-radius: 1rem;
    padding: 1.25rem;
    border: 1px solid #f3f4f6;
}

@media (min-width: 640px) {
    .role-panel[b-mb31mmi986] {
        padding: 1.5rem;
    }
}

.role-panel-label[b-mb31mmi986] {
    font-size: .7rem;
    font-weight: 700;
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: .1em;
    margin-bottom: 1rem;
    text-align: center;
}

@media (min-width: 1024px) {
    .role-panel-label[b-mb31mmi986] {
        text-align: left;
    }
}

.role-grid[b-mb31mmi986] {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap: .625rem;
}

@media (min-width: 400px) {
    .role-grid[b-mb31mmi986] {
        grid-template-columns: repeat(4,1fr);
    }
}

.role-btn[b-mb31mmi986] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .4rem;
    padding: .75rem .5rem;
    border-radius: .75rem;
    border: 1px solid #e5e7eb !important;
    background: #fff !important;
    font-weight: 600;
    font-size: .8rem;
    color: #374151 !important;
    cursor: pointer;
    transition: all .3s;
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
}

@media (min-width: 640px) {
    .role-btn[b-mb31mmi986] {
        padding: 1rem;
        font-size: .875rem;
    }
}

.role-icon[b-mb31mmi986] {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    transition: all .2s;
}

/* icon tints default */
.role-btn-blue .role-icon[b-mb31mmi986] {
    background: #eff6ff !important;
    color: #2563eb !important;
}

.role-btn-green .role-icon[b-mb31mmi986] {
    background: #f0fdf4 !important;
    color: #16a34a !important;
}

.role-btn-purple .role-icon[b-mb31mmi986] {
    background: #f5f3ff !important;
    color: #7c3aed !important;
}

.role-btn-orange .role-icon[b-mb31mmi986] {
    background: #fff7ed !important;
    color: #ea580c !important;
}

/* hover: card fills accent, icon goes white translucent */
.role-btn-blue:hover[b-mb31mmi986] {
    background: #2563eb !important;
    color: #fff !important;
    border-color: #2563eb !important;
    box-shadow: 0 8px 24px rgba(37,99,235,.35);
}

.role-btn-green:hover[b-mb31mmi986] {
    background: #16a34a !important;
    color: #fff !important;
    border-color: #16a34a !important;
    box-shadow: 0 8px 24px rgba(22,163,74,.35);
}

.role-btn-purple:hover[b-mb31mmi986] {
    background: #7c3aed !important;
    color: #fff !important;
    border-color: #7c3aed !important;
    box-shadow: 0 8px 24px rgba(124,58,237,.35);
}

.role-btn-orange:hover[b-mb31mmi986] {
    background: #ea580c !important;
    color: #fff !important;
    border-color: #ea580c !important;
    box-shadow: 0 8px 24px rgba(234,88,12,.35);
}

    .role-btn-blue:hover .role-icon[b-mb31mmi986],
    .role-btn-green:hover .role-icon[b-mb31mmi986],
    .role-btn-purple:hover .role-icon[b-mb31mmi986],
    .role-btn-orange:hover .role-icon[b-mb31mmi986] {
        background: rgba(255,255,255,.2) !important;
        color: #fff !important;
    }

.role-selected-msg[b-mb31mmi986] {
    margin-top: 1rem;
    font-size: .875rem;
    color: #16a34a;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
}

/* ── Hero image floats ── */
.hero-image-wrap[b-mb31mmi986] {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-image-glow[b-mb31mmi986] {
    position: absolute;
    inset: 0;
    border-radius: 9999px;
    background: linear-gradient(135deg,#dbeafe,#ede9fe);
    opacity: .6;
    filter: blur(3rem);
}

.hero-img[b-mb31mmi986] {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 22rem;
    object-fit: cover;
    border-radius: 1.5rem;
    box-shadow: 0 24px 64px rgba(0,0,0,.18);
    transition: transform .5s;
}

@media (min-width: 640px) {
    .hero-img[b-mb31mmi986] {
        height: 26rem;
    }
}

@media (min-width: 1024px) {
    .hero-img[b-mb31mmi986] {
        max-width: 38rem;
        height: 30rem;
    }
}

.hero-img:hover[b-mb31mmi986] {
    transform: scale(1.02);
}

.hero-float[b-mb31mmi986] {
    display: none;
    position: absolute;
    z-index: 2;
    background: #fff !important;
    padding: .75rem 1rem;
    border-radius: 1rem;
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    align-items: center;
    gap: .75rem;
}

@media (min-width: 640px) {
    .hero-float[b-mb31mmi986] {
        display: flex;
    }
}

.hero-float-tl[b-mb31mmi986] {
    top: 1.5rem;
    left: -1rem;
    animation: floatBob-b-mb31mmi986 3s ease-in-out infinite;
}

.hero-float-br[b-mb31mmi986] {
    bottom: 3rem;
    right: -1rem;
    animation: floatBob-b-mb31mmi986 4s ease-in-out infinite;
    animation-delay: 1s;
}

.hero-float-mr[b-mb31mmi986] {
    top: 50%;
    right: -1rem;
    transform: translateY(-50%);
}

@media (min-width: 1024px) {
    .hero-float-tl[b-mb31mmi986] {
        left: -1.5rem;
    }

    .hero-float-br[b-mb31mmi986] {
        right: -1.5rem;
    }

    .hero-float-mr[b-mb31mmi986] {
        right: -1.5rem;
    }
}

@keyframes floatBob-b-mb31mmi986 {
    0%,100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-6px);
    }
}

.float-icon[b-mb31mmi986] {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    flex-shrink: 0;
}

.float-icon-green[b-mb31mmi986] {
    background: #dcfce7 !important;
    color: #16a34a !important;
}

.float-icon-blue[b-mb31mmi986] {
    background: #dbeafe !important;
    color: #2563eb !important;
}

.float-icon-purple[b-mb31mmi986] {
    background: #ede9fe !important;
    color: #7c3aed !important;
}

.float-label[b-mb31mmi986] {
    font-size: .65rem;
    color: #9ca3af;
    font-weight: 500;
    white-space: nowrap;
}

.float-value[b-mb31mmi986] {
    font-size: .8rem;
    font-weight: 700;
    color: #111827;
    white-space: nowrap;
}

/* ══════════════════════════════════════════════════════
   STATS BAR — solid blue background
══════════════════════════════════════════════════════ */
.stats-bar[b-mb31mmi986] {
    background-color: #2563eb !important;
    padding: 2.5rem 0;
}

@media (min-width: 768px) {
    .stats-bar[b-mb31mmi986] {
        padding: 3rem 0;
    }
}

.stats-grid[b-mb31mmi986] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    text-align: center;
    gap: 1rem;
}

@media (min-width: 768px) {
    .stats-grid[b-mb31mmi986] {
        grid-template-columns: repeat(4,1fr);
        gap: 0;
    }
}

.stat-item[b-mb31mmi986] {
    padding: .5rem 1rem;
}

@media (min-width: 768px) {
    .stat-item[b-mb31mmi986] {
        border-left: 1px solid rgba(255,255,255,.25);
    }

        .stat-item:first-child[b-mb31mmi986] {
            border-left: none;
        }
}

.stat-value[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-size: 2rem;
    font-weight: 700;
    color: #fff !important;
    margin-bottom: .25rem;
    line-height: 1;
}

@media (min-width: 640px) {
    .stat-value[b-mb31mmi986] {
        font-size: 2.5rem;
    }
}

.stat-label[b-mb31mmi986] {
    font-size: .7rem;
    color: #bfdbfe !important;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .06em;
}

/* ══════════════════════════════════════════════════════
   SECTIONS
══════════════════════════════════════════════════════ */
.section-white[b-mb31mmi986] {
    padding: 4rem 0;
    background: #fff !important;
}

.section-gray[b-mb31mmi986] {
    padding: 4rem 0;
    background: #f9fafb !important;
}

@media (min-width: 768px) {
    .section-white[b-mb31mmi986], .section-gray[b-mb31mmi986] {
        padding: 5rem 0;
    }
}

@media (min-width: 1024px) {
    .section-white[b-mb31mmi986] {
        padding: 6rem 0;
    }
}

.section-eyebrow[b-mb31mmi986] {
    display: block;
    font-size: .8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: #2563eb !important;
}

.eyebrow-purple[b-mb31mmi986] {
    color: #7c3aed !important;
}

.section-title[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-size: clamp(1.5rem,4vw,2.5rem);
    font-weight: 700;
    color: #111827;
    margin-top: .5rem;
}

.section-sub[b-mb31mmi986] {
    color: #6b7280;
    margin-top: .5rem;
    max-width: 36rem;
    font-size: .95rem;
}

.section-header-row[b-mb31mmi986] {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 2rem;
}

@media (min-width: 768px) {
    .section-header-row[b-mb31mmi986] {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-end;
        margin-bottom: 2.5rem;
    }
}

.section-header-center[b-mb31mmi986] {
    text-align: center;
    margin-bottom: 3rem;
}

@media (min-width: 768px) {
    .section-header-center[b-mb31mmi986] {
        margin-bottom: 4rem;
    }
}

.section-sub-center[b-mb31mmi986] {
    color: #6b7280;
    margin: 1rem auto 0;
    max-width: 40rem;
    font-size: .95rem;
}

.link-arrow[b-mb31mmi986] {
    display: none;
    align-items: center;
    gap: .5rem;
    color: #6b7280;
    font-weight: 500;
    font-size: .875rem;
    white-space: nowrap;
}

@media (min-width: 768px) {
    .link-arrow[b-mb31mmi986] {
        display: flex;
    }
}

.link-arrow:hover[b-mb31mmi986] {
    color: #2563eb;
}

/* ── Browse All Courses pill ── */
.btn-dark-pill[b-mb31mmi986] {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: #111827 !important;
    color: #fff !important;
    padding: .625rem 1.25rem;
    border-radius: 9999px;
    font-size: .8rem;
    font-weight: 600;
    transition: .2s;
    white-space: nowrap;
    box-shadow: 0 4px 12px rgba(0,0,0,.15);
    border: none !important;
}

@media (min-width: 640px) {
    .btn-dark-pill[b-mb31mmi986] {
        padding: .75rem 1.5rem;
        font-size: .875rem;
    }
}

.btn-dark-pill:hover[b-mb31mmi986] {
    background: #2563eb !important;
}

.btn-outline-pill[b-mb31mmi986] {
    background: #fff;
    color: #374151;
    border: 1px solid #d1d5db;
    padding: .5rem 1.25rem;
    border-radius: 9999px;
    font-size: .875rem;
    font-weight: 500;
    cursor: pointer;
    transition: .2s;
}

    .btn-outline-pill:hover[b-mb31mmi986] {
        background: #f9fafb;
    }

/* ── Filter tabs ── */
.filter-tabs[b-mb31mmi986] {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 2rem;
}

@media (min-width: 640px) {
    .filter-tabs[b-mb31mmi986] {
        gap: .75rem;
        margin-bottom: 2.5rem;
    }
}

.filter-btn[b-mb31mmi986] {
    display: inline-flex;
    align-items: center;
    padding: .5rem 1rem;
    border-radius: 9999px;
    border: 1px solid #e5e7eb;
    background: #fff !important;
    font-size: .8rem;
    font-weight: 600;
    color: #6b7280;
    cursor: pointer;
    transition: all .2s;
}

@media (min-width: 640px) {
    .filter-btn[b-mb31mmi986] {
        padding: .625rem 1.25rem;
        font-size: .875rem;
    }
}

.filter-btn:hover[b-mb31mmi986] {
    border-color: #93c5fd;
    color: #2563eb;
}

.filter-btn-active[b-mb31mmi986] {
    background: #2563eb !important;
    color: #fff !important;
    border-color: #2563eb !important;
}

.filter-icon[b-mb31mmi986] {
    margin-right: .35rem;
}

.filter-icon-blue[b-mb31mmi986] {
    color: #60a5fa;
}

.filter-icon-purple[b-mb31mmi986] {
    color: #a78bfa;
}

.filter-icon-yellow[b-mb31mmi986] {
    color: #fbbf24;
}

.filter-icon-green[b-mb31mmi986] {
    color: #4ade80;
}

.filter-icon-orange[b-mb31mmi986] {
    color: #fb923c;
}

.filter-btn-active .filter-icon[b-mb31mmi986] {
    color: #fff !important;
}

/* ══════════════════════════════════════════════════════
   COURSE CARDS
══════════════════════════════════════════════════════ */
.course-grid[b-mb31mmi986] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 640px) {
    .course-grid[b-mb31mmi986] {
        gap: 2rem;
    }
}

@media (min-width: 768px) {
    .course-grid[b-mb31mmi986] {
        grid-template-columns: repeat(2,1fr);
    }
}

@media (min-width: 1024px) {
    .course-grid[b-mb31mmi986] {
        grid-template-columns: repeat(3,1fr);
    }
}

.course-card[b-mb31mmi986] {
    background: #fff !important;
    border-radius: 1.25rem;
    border: 1px solid #f3f4f6;
    overflow: hidden;
    box-shadow: 0 8px 24px -4px rgba(20,20,60,.08);
    transition: all .3s;
    display: flex;
    flex-direction: column;
}

    .course-card:hover[b-mb31mmi986] {
        box-shadow: 0 16px 40px -4px rgba(20,20,60,.14);
        transform: translateY(-4px);
    }

        .course-card:hover .course-img[b-mb31mmi986] {
            transform: scale(1.07);
        }

.course-img-wrap[b-mb31mmi986] {
    position: relative;
    height: 11rem;
    overflow: hidden;
}

@media (min-width: 640px) {
    .course-img-wrap[b-mb31mmi986] {
        height: 12rem;
    }
}

.course-img[b-mb31mmi986] {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s;
}

.course-img-overlay[b-mb31mmi986] {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top,rgba(0,0,0,.4),transparent);
}

.course-badge[b-mb31mmi986] {
    position: absolute;
    top: .75rem;
    left: .75rem;
    font-size: .65rem;
    font-weight: 700;
    padding: .2rem .625rem;
    border-radius: 9999px;
    text-transform: uppercase;
    letter-spacing: .06em;
}

@media (min-width: 640px) {
    .course-badge[b-mb31mmi986] {
        top: 1rem;
        left: 1rem;
        font-size: .7rem;
        padding: .25rem .75rem;
    }
}

.course-badge-yellow[b-mb31mmi986] {
    background: #fef08a !important;
    color: #854d0e !important;
}

.course-badge-purple[b-mb31mmi986] {
    background: #7c3aed !important;
    color: #fff !important;
}

.course-badge-blue[b-mb31mmi986] {
    background: #3b82f6 !important;
    color: #fff !important;
}

.course-badge-green[b-mb31mmi986] {
    background: #22c55e !important;
    color: #fff !important;
}

.course-badge-orange[b-mb31mmi986] {
    background: #ea580c !important;
    color: #fff !important;
}

.course-level[b-mb31mmi986] {
    position: absolute;
    top: .75rem;
    right: .75rem;
    background: rgba(255,255,255,.9);
    font-size: .65rem;
    font-weight: 600;
    padding: .2rem .625rem;
    border-radius: 9999px;
    color: #374151;
    display: inline-flex;
    align-items: center;
    gap: .25rem;
}

@media (min-width: 640px) {
    .course-level[b-mb31mmi986] {
        top: 1rem;
        right: 1rem;
        font-size: .7rem;
        padding: .25rem .75rem;
    }
}

.course-body[b-mb31mmi986] {
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

@media (min-width: 640px) {
    .course-body[b-mb31mmi986] {
        padding: 1.5rem;
    }
}

.course-title[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-weight: 700;
    color: #111827;
    font-size: 1rem;
    margin-bottom: .5rem;
    transition: color .2s;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.course-card:hover .course-title[b-mb31mmi986] {
    color: #2563eb;
}

.course-desc[b-mb31mmi986] {
    color: #9ca3af;
    font-size: .825rem;
    margin-bottom: 1rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.course-instructor[b-mb31mmi986] {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid #f3f4f6;
    margin-bottom: 1rem;
}

.instructor-avatar[b-mb31mmi986] {
    width: 2rem;
    height: 2rem;
    border-radius: 9999px;
    object-fit: cover;
    flex-shrink: 0;
}

.instructor-label[b-mb31mmi986] {
    font-size: .7rem;
    color: #9ca3af;
}

.instructor-name[b-mb31mmi986] {
    font-size: .825rem;
    font-weight: 600;
    color: #374151;
}

.course-meta[b-mb31mmi986] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
    gap: .5rem;
}

.course-rating[b-mb31mmi986] {
    display: flex;
    align-items: center;
    gap: .15rem;
}

.star-icon[b-mb31mmi986] {
    color: #f59e0b;
    font-size: .7rem;
}

.rating-val[b-mb31mmi986] {
    font-weight: 600;
    color: #374151;
    margin-left: .25rem;
    font-size: .825rem;
}

.rating-count[b-mb31mmi986] {
    color: #9ca3af;
    font-size: .825rem;
}

.course-stats[b-mb31mmi986] {
    display: flex;
    gap: .625rem;
    color: #9ca3af;
    font-size: .7rem;
}

.course-footer[b-mb31mmi986] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
    gap: .5rem;
}

.course-price[b-mb31mmi986] {
    display: flex;
    align-items: baseline;
}

.price-current[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-size: 1.375rem;
    font-weight: 700;
    color: #111827;
}

@media (min-width: 640px) {
    .price-current[b-mb31mmi986] {
        font-size: 1.5rem;
    }
}

.price-old[b-mb31mmi986] {
    font-size: .825rem;
    color: #9ca3af;
    text-decoration: line-through;
    margin-left: .5rem;
}

/* ── Enroll Now buttons ── */
.btn-enroll[b-mb31mmi986] {
    color: #fff !important;
    padding: .5rem 1rem;
    border-radius: .75rem;
    font-size: .8rem;
    font-weight: 600;
    border: none !important;
    cursor: pointer;
    transition: all .2s;
    white-space: nowrap;
}

@media (min-width: 640px) {
    .btn-enroll[b-mb31mmi986] {
        padding: .625rem 1.25rem;
        font-size: .875rem;
    }
}

.btn-enroll-blue[b-mb31mmi986] {
    background-color: #2563eb !important;
}

.btn-enroll-purple[b-mb31mmi986] {
    background-color: #7c3aed !important;
}

.btn-enroll-green[b-mb31mmi986] {
    background-color: #16a34a !important;
}

.btn-enroll-orange[b-mb31mmi986] {
    background-color: #ea580c !important;
}

.btn-enroll-blue:hover[b-mb31mmi986] {
    background-color: #1d4ed8 !important;
    box-shadow: 0 6px 16px rgba(37,99,235,.35);
}

.btn-enroll-purple:hover[b-mb31mmi986] {
    background-color: #6d28d9 !important;
    box-shadow: 0 6px 16px rgba(124,58,237,.35);
}

.btn-enroll-green:hover[b-mb31mmi986] {
    background-color: #15803d !important;
    box-shadow: 0 6px 16px rgba(22,163,74,.35);
}

.btn-enroll-orange:hover[b-mb31mmi986] {
    background-color: #c2410c !important;
    box-shadow: 0 6px 16px rgba(234,88,12,.35);
}

.enroll-toast[b-mb31mmi986] {
    margin-top: 1.5rem;
    padding: .875rem 1.25rem;
    background: #f0fdf4 !important;
    border: 1px solid #bbf7d0;
    color: #16a34a !important;
    border-radius: .75rem;
    font-weight: 500;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    font-size: .875rem;
}

/* ══════════════════════════════════════════════════════
   CTA BANNER — blue-to-purple gradient
══════════════════════════════════════════════════════ */
.cta-banner[b-mb31mmi986] {
    margin-top: 2.5rem;
    border-radius: 1.25rem;
    padding: 2rem 1.5rem;
    background: linear-gradient(135deg, #2563eb, #1e40af, #7c3aed) !important;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

@media (min-width: 640px) {
    .cta-banner[b-mb31mmi986] {
        padding: 2rem 2.5rem;
    }
}

@media (min-width: 768px) {
    .cta-banner[b-mb31mmi986] {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        margin-top: 3.5rem;
        padding: 2.5rem 3rem;
    }
}

.cta-title[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-size: clamp(1.125rem,3vw,1.875rem);
    font-weight: 700;
    color: #fff !important;
}

.cta-sub[b-mb31mmi986] {
    color: #bfdbfe !important;
    margin-top: .25rem;
    font-size: .9rem;
}

.cta-actions[b-mb31mmi986] {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

@media (min-width: 768px) {
    .cta-actions[b-mb31mmi986] {
        flex-shrink: 0;
        gap: 1rem;
    }
}

.btn-cta-white[b-mb31mmi986] {
    background: #fff !important;
    color: #1d4ed8 !important;
    padding: .75rem 1.5rem;
    border-radius: 9999px;
    font-weight: 600;
    border: none !important;
    cursor: pointer;
    transition: .2s;
    white-space: nowrap;
    font-size: .875rem;
}

@media (min-width: 640px) {
    .btn-cta-white[b-mb31mmi986] {
        padding: .875rem 1.75rem;
    }
}

.btn-cta-white:hover[b-mb31mmi986] {
    background: #eff6ff !important;
}

.btn-cta-outline[b-mb31mmi986] {
    background: transparent !important;
    color: #fff !important;
    padding: .75rem 1.5rem;
    border-radius: 9999px;
    font-weight: 600;
    border: 2px solid rgba(255,255,255,.5) !important;
    cursor: pointer;
    transition: .2s;
    white-space: nowrap;
    font-size: .875rem;
}

@media (min-width: 640px) {
    .btn-cta-outline[b-mb31mmi986] {
        padding: .875rem 1.75rem;
    }
}

.btn-cta-outline:hover[b-mb31mmi986] {
    border-color: #fff !important;
}

/* ══════════════════════════════════════════════════════
   EVENTS
══════════════════════════════════════════════════════ */
.events-grid[b-mb31mmi986] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

@media (min-width: 640px) {
    .events-grid[b-mb31mmi986] {
        gap: 1.5rem;
    }
}

@media (min-width: 768px) {
    .events-grid[b-mb31mmi986] {
        grid-template-columns: repeat(3,1fr);
        gap: 2rem;
    }
}

.event-card[b-mb31mmi986] {
    background: #fff !important;
    border-radius: 1rem;
    border: 1px solid #f3f4f6;
    padding: 1.25rem;
    transition: all .3s;
}

@media (min-width: 640px) {
    .event-card[b-mb31mmi986] {
        padding: 1.5rem;
    }
}

.event-card:hover[b-mb31mmi986] {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(37,99,235,.08);
}

.event-card-top[b-mb31mmi986] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.25rem;
}

@media (min-width: 640px) {
    .event-card-top[b-mb31mmi986] {
        margin-bottom: 1.5rem;
    }
}

.event-date[b-mb31mmi986] {
    border-radius: .75rem;
    padding: .5rem .875rem;
    text-align: center;
    min-width: 4.5rem;
}

.event-date-blue[b-mb31mmi986] {
    background: #eff6ff !important;
    color: #1d4ed8 !important;
}

.event-date-purple[b-mb31mmi986] {
    background: #f5f3ff !important;
    color: #6d28d9 !important;
}

.event-date-green[b-mb31mmi986] {
    background: #f0fdf4 !important;
    color: #15803d !important;
}

.event-month[b-mb31mmi986] {
    display: block;
    font-size: .6rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.event-day[b-mb31mmi986] {
    display: block;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.2;
}

.event-tag[b-mb31mmi986] {
    font-size: .7rem;
    color: #6b7280;
    background: #f3f4f6;
    padding: .2rem .625rem;
    border-radius: 9999px;
    font-weight: 500;
}

.event-title[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-size: 1rem;
    font-weight: 700;
    color: #111827;
    margin-bottom: .625rem;
    transition: color .2s;
}

@media (min-width: 640px) {
    .event-title[b-mb31mmi986] {
        font-size: 1.125rem;
    }
}

.event-card:hover .event-title[b-mb31mmi986] {
    color: #2563eb;
}

.event-desc[b-mb31mmi986] {
    font-size: .825rem;
    color: #6b7280;
    margin-bottom: .875rem;
    line-height: 1.6;
}

.event-time[b-mb31mmi986] {
    font-size: .8rem;
    color: #9ca3af;
    display: flex;
    align-items: center;
    gap: .5rem;
}

/* ══════════════════════════════════════════════════════
   ACADEMIC SERVICES
══════════════════════════════════════════════════════ */
.services-grid[b-mb31mmi986] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 480px) {
    .services-grid[b-mb31mmi986] {
        grid-template-columns: repeat(2,1fr);
        gap: 1.25rem;
    }
}

@media (min-width: 768px) {
    .services-grid[b-mb31mmi986] {
        gap: 1.5rem;
    }
}

@media (min-width: 1024px) {
    .services-grid[b-mb31mmi986] {
        grid-template-columns: repeat(3,1fr);
    }
}

.service-card[b-mb31mmi986] {
    position: relative;
    overflow: hidden;
    border-radius: 1rem;
    padding: 1.5rem;
    background: #fff !important;
    border: 1px solid #f3f4f6;
    box-shadow: 0 1px 3px rgba(0,0,0,.05);
    display: block;
    transition: all .3s;
}

@media (min-width: 640px) {
    .service-card[b-mb31mmi986] {
        padding: 2rem;
    }
}

.service-card:hover[b-mb31mmi986] {
    transform: translateY(-4px);
}

.service-corner[b-mb31mmi986] {
    position: absolute;
    top: 0;
    right: 0;
    width: 4rem;
    height: 4rem;
    transform: translate(2rem,-2rem) rotate(45deg);
    transition: transform .2s;
}

.service-card:hover .service-corner[b-mb31mmi986] {
    transform: translate(1.5rem,-1.5rem) rotate(45deg) scale(1.1);
}

.service-corner-blue[b-mb31mmi986] {
    background: #2563eb !important;
}

.service-corner-purple[b-mb31mmi986] {
    background: #7c3aed !important;
}

.service-corner-orange[b-mb31mmi986] {
    background: #ea580c !important;
}

.service-corner-green[b-mb31mmi986] {
    background: #16a34a !important;
}

.service-corner-teal[b-mb31mmi986] {
    background: #0d9488 !important;
}

.service-corner-red[b-mb31mmi986] {
    background: #dc2626 !important;
}

.service-icon[b-mb31mmi986] {
    width: 3rem;
    height: 3rem;
    border-radius: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    margin-bottom: 1.25rem;
    transition: all .2s;
}

@media (min-width: 640px) {
    .service-icon[b-mb31mmi986] {
        width: 3.5rem;
        height: 3.5rem;
        font-size: 1.4rem;
        margin-bottom: 1.5rem;
    }
}

.service-icon-blue[b-mb31mmi986] {
    background: #eff6ff !important;
    color: #2563eb !important;
}

.service-icon-purple[b-mb31mmi986] {
    background: #f5f3ff !important;
    color: #7c3aed !important;
}

.service-icon-orange[b-mb31mmi986] {
    background: #fff7ed !important;
    color: #ea580c !important;
}

.service-icon-green[b-mb31mmi986] {
    background: #f0fdf4 !important;
    color: #16a34a !important;
}

.service-icon-teal[b-mb31mmi986] {
    background: #f0fdfa !important;
    color: #0d9488 !important;
}

.service-icon-red[b-mb31mmi986] {
    background: #fef2f2 !important;
    color: #dc2626 !important;
}

.service-card-blue:hover[b-mb31mmi986] {
    box-shadow: 0 12px 32px rgba(37,99,235,.1);
    border-color: #bfdbfe;
}

.service-card-purple:hover[b-mb31mmi986] {
    box-shadow: 0 12px 32px rgba(124,58,237,.1);
    border-color: #ddd6fe;
}

.service-card-orange:hover[b-mb31mmi986] {
    box-shadow: 0 12px 32px rgba(234,88,12,.1);
    border-color: #fed7aa;
}

.service-card-green:hover[b-mb31mmi986] {
    box-shadow: 0 12px 32px rgba(22,163,74,.1);
    border-color: #bbf7d0;
}

.service-card-teal:hover[b-mb31mmi986] {
    box-shadow: 0 12px 32px rgba(13,148,136,.1);
    border-color: #99f6e4;
}

.service-card-red:hover[b-mb31mmi986] {
    box-shadow: 0 12px 32px rgba(220,38,38,.1);
    border-color: #fecaca;
}

.service-card-blue:hover .service-icon[b-mb31mmi986] {
    background: #2563eb !important;
    color: #fff !important;
}

.service-card-purple:hover .service-icon[b-mb31mmi986] {
    background: #7c3aed !important;
    color: #fff !important;
}

.service-card-orange:hover .service-icon[b-mb31mmi986] {
    background: #ea580c !important;
    color: #fff !important;
}

.service-card-green:hover .service-icon[b-mb31mmi986] {
    background: #16a34a !important;
    color: #fff !important;
}

.service-card-teal:hover .service-icon[b-mb31mmi986] {
    background: #0d9488 !important;
    color: #fff !important;
}

.service-card-red:hover .service-icon[b-mb31mmi986] {
    background: #dc2626 !important;
    color: #fff !important;
}

.service-title[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-size: 1rem;
    font-weight: 700;
    color: #111827;
    margin-bottom: .625rem;
}

@media (min-width: 640px) {
    .service-title[b-mb31mmi986] {
        font-size: 1.125rem;
        margin-bottom: .75rem;
    }
}

.service-desc[b-mb31mmi986] {
    color: #6b7280;
    font-size: .85rem;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

.service-link[b-mb31mmi986] {
    font-size: .8rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    transition: transform .2s;
}

@media (min-width: 640px) {
    .service-link[b-mb31mmi986] {
        font-size: .875rem;
    }
}

.service-card:hover .service-link[b-mb31mmi986] {
    transform: translateX(4px);
}

.service-link-blue[b-mb31mmi986] {
    color: #2563eb !important;
}

.service-link-purple[b-mb31mmi986] {
    color: #7c3aed !important;
}

.service-link-orange[b-mb31mmi986] {
    color: #ea580c !important;
}

.service-link-green[b-mb31mmi986] {
    color: #16a34a !important;
}

.service-link-teal[b-mb31mmi986] {
    color: #0d9488 !important;
}

.service-link-red[b-mb31mmi986] {
    color: #dc2626 !important;
}

/* ══════════════════════════════════════════════════════
   CAMPUS LIFE
══════════════════════════════════════════════════════ */
.campus-grid[b-mb31mmi986] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
}

@media (min-width: 1024px) {
    .campus-grid[b-mb31mmi986] {
        grid-template-columns: 1fr 2fr;
        gap: 3rem;
    }
}

.campus-desc[b-mb31mmi986] {
    color: #6b7280;
    margin-bottom: 1.5rem;
    line-height: 1.75;
    font-size: .95rem;
}

.campus-activities[b-mb31mmi986] {
    display: flex;
    flex-direction: column;
    gap: .75rem;
}

.activity-item[b-mb31mmi986] {
    display: flex;
    align-items: center;
    gap: .875rem;
    padding: .875rem;
    border-radius: .75rem;
    border: 1px solid #f3f4f6;
    background: #fff !important;
    cursor: pointer;
    transition: background .2s;
}

@media (min-width: 640px) {
    .activity-item[b-mb31mmi986] {
        padding: 1rem;
    }
}

.activity-item-purple:hover[b-mb31mmi986] {
    background: #f5f3ff !important;
}

.activity-item-blue:hover[b-mb31mmi986] {
    background: #eff6ff !important;
}

.activity-item-green:hover[b-mb31mmi986] {
    background: #f0fdf4 !important;
}

.activity-icon[b-mb31mmi986] {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 9999px;
    background: #fff !important;
    border: 1px solid #f3f4f6;
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform .2s;
    flex-shrink: 0;
}

.activity-item:hover .activity-icon[b-mb31mmi986] {
    transform: scale(1.1);
}

.activity-icon-purple[b-mb31mmi986] {
    color: #7c3aed !important;
}

.activity-icon-blue[b-mb31mmi986] {
    color: #2563eb !important;
}

.activity-icon-green[b-mb31mmi986] {
    color: #16a34a !important;
}

.activity-title[b-mb31mmi986] {
    font-weight: 700;
    color: #111827;
    font-size: .875rem;
}

.activity-sub[b-mb31mmi986] {
    font-size: .75rem;
    color: #9ca3af;
}

.campus-photos[b-mb31mmi986] {
    display: flex;
    flex-direction: column;
    gap: .75rem;
}

@media (min-width: 640px) {
    .campus-photos[b-mb31mmi986] {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
        height: 22rem;
    }
}

@media (min-width: 1024px) {
    .campus-photos[b-mb31mmi986] {
        height: 26rem;
    }
}

.campus-photo-main[b-mb31mmi986] {
    position: relative;
    border-radius: 1rem;
    overflow: hidden;
    height: 14rem;
}

@media (min-width: 640px) {
    .campus-photo-main[b-mb31mmi986] {
        height: 100%;
    }
}

.campus-photo-sm[b-mb31mmi986] {
    position: relative;
    border-radius: 1rem;
    overflow: hidden;
    height: 8rem;
}

@media (min-width: 640px) {
    .campus-photo-sm[b-mb31mmi986] {
        height: 100%;
    }
}

.campus-photo-col[b-mb31mmi986] {
    display: flex;
    flex-direction: column;
    gap: .75rem;
}

@media (min-width: 640px) {
    .campus-photo-col[b-mb31mmi986] {
        display: grid;
        grid-template-rows: 1fr 1fr;
        gap: 1rem;
    }
}

.campus-img[b-mb31mmi986] {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .7s;
}

.campus-photo-main:hover .campus-img[b-mb31mmi986], .campus-photo-sm:hover .campus-img[b-mb31mmi986] {
    transform: scale(1.1);
}

.campus-img-caption[b-mb31mmi986] {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top,rgba(0,0,0,.6),transparent);
    opacity: 0;
    transition: opacity .3s;
    display: flex;
    align-items: flex-end;
    padding: 1rem;
    color: #fff;
    font-weight: 500;
    font-size: .875rem;
}

.campus-photo-main:hover .campus-img-caption[b-mb31mmi986], .campus-photo-sm:hover .campus-img-caption[b-mb31mmi986] {
    opacity: 1;
}

/* ══════════════════════════════════════════════════════
   NEWS
══════════════════════════════════════════════════════ */
.news-grid[b-mb31mmi986] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

@media (min-width: 640px) {
    .news-grid[b-mb31mmi986] {
        gap: 1.5rem;
    }
}

@media (min-width: 768px) {
    .news-grid[b-mb31mmi986] {
        grid-template-columns: repeat(3,1fr);
        gap: 2rem;
    }
}

.news-card[b-mb31mmi986] {
    background: #fff !important;
    border-radius: 1rem;
    border: 1px solid #f3f4f6;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,.05);
    display: flex;
    flex-direction: column;
    transition: all .3s;
}

    .news-card:hover[b-mb31mmi986] {
        transform: translateY(-4px);
        box-shadow: 0 12px 32px rgba(37,99,235,.08);
    }

.news-img-wrap[b-mb31mmi986] {
    height: 12rem;
    overflow: hidden;
    position: relative;
}

@media (min-width: 640px) {
    .news-img-wrap[b-mb31mmi986] {
        height: 14rem;
    }
}

.news-img[b-mb31mmi986] {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s;
}

.news-card:hover .news-img[b-mb31mmi986] {
    transform: scale(1.05);
}

.news-tag[b-mb31mmi986] {
    position: absolute;
    top: .75rem;
    left: .75rem;
    background: rgba(255,255,255,.9);
    backdrop-filter: blur(4px);
    font-size: .65rem;
    font-weight: 700;
    color: #111827;
    padding: .2rem .625rem;
    border-radius: .5rem;
}

.news-body[b-mb31mmi986] {
    padding: 1.25rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}

@media (min-width: 640px) {
    .news-body[b-mb31mmi986] {
        padding: 1.5rem;
    }
}

.news-date[b-mb31mmi986] {
    font-size: .75rem;
    color: #9ca3af;
    margin-bottom: .625rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}

.news-title[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-size: 1rem;
    font-weight: 700;
    color: #111827;
    margin-bottom: .625rem;
    transition: color .2s;
}

@media (min-width: 640px) {
    .news-title[b-mb31mmi986] {
        font-size: 1.1rem;
        margin-bottom: .75rem;
    }
}

.news-card:hover .news-title[b-mb31mmi986] {
    color: #2563eb;
}

.news-excerpt[b-mb31mmi986] {
    font-size: .825rem;
    color: #6b7280;
    line-height: 1.6;
    flex: 1;
    margin-bottom: .875rem;
}

.news-link[b-mb31mmi986] {
    font-size: .875rem;
    font-weight: 600;
    color: #2563eb !important;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
}

    .news-link:hover[b-mb31mmi986] {
        text-decoration: underline;
    }

/* ══════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════ */
.footer[b-mb31mmi986] {
    background: #111827 !important;
    color: #fff;
    padding: 3.5rem 0 2rem;
}

@media (min-width: 768px) {
    .footer[b-mb31mmi986] {
        padding: 5rem 0 2.5rem;
    }
}

.footer-grid[b-mb31mmi986] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    margin-bottom: 3rem;
}

@media (min-width: 640px) {
    .footer-grid[b-mb31mmi986] {
        grid-template-columns: 1fr 1fr;
        gap: 2rem;
    }
}

@media (min-width: 1024px) {
    .footer-grid[b-mb31mmi986] {
        grid-template-columns: 2fr 1fr 1fr 1.5fr;
        gap: 3rem;
        margin-bottom: 4rem;
    }
}

.footer-logo[b-mb31mmi986] {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: 1.25rem;
}

.footer-logo-icon[b-mb31mmi986] {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: .5rem;
    background: linear-gradient(135deg,#2563eb,#7c3aed) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff !important;
    flex-shrink: 0;
}

.footer-logo-name[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-size: 1.5rem;
    font-weight: 700;
    color: #fff !important;
}

.footer-tagline[b-mb31mmi986] {
    color: #9ca3af;
    font-size: .875rem;
    line-height: 1.7;
    margin-bottom: 1.5rem;
}

.footer-socials[b-mb31mmi986] {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
}

.social-btn[b-mb31mmi986] {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 9999px;
    background: #1f2937 !important;
    color: #9ca3af !important;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s;
    flex-shrink: 0;
}

    .social-btn:hover[b-mb31mmi986] {
        background: #2563eb !important;
        color: #fff !important;
    }

.footer-col-title[b-mb31mmi986] {
    font-family: var(--font-heading,'Outfit',sans-serif);
    font-weight: 700;
    font-size: 1rem;
    margin-bottom: 1.25rem;
    color: #fff !important;
}

@media (min-width: 640px) {
    .footer-col-title[b-mb31mmi986] {
        font-size: 1.125rem;
        margin-bottom: 1.5rem;
    }
}

.footer-links li[b-mb31mmi986] {
    margin-bottom: .625rem;
}

.footer-links a[b-mb31mmi986] {
    color: #9ca3af;
    font-size: .875rem;
    transition: color .2s;
}

    .footer-links a:hover[b-mb31mmi986] {
        color: #60a5fa;
    }

.footer-contact[b-mb31mmi986] {
    display: flex;
    flex-direction: column;
    gap: .875rem;
}

    .footer-contact li[b-mb31mmi986] {
        display: flex;
        align-items: flex-start;
        gap: .75rem;
        color: #9ca3af;
        font-size: .875rem;
    }

        .footer-contact li i[b-mb31mmi986] {
            color: #2563eb !important;
            margin-top: .15rem;
            min-width: 1rem;
            flex-shrink: 0;
        }

.footer-bottom[b-mb31mmi986] {
    border-top: 1px solid #1f2937;
    padding-top: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    color: #6b7280;
    font-size: .875rem;
}

@media (min-width: 768px) {
    .footer-bottom[b-mb31mmi986] {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        padding-top: 2rem;
    }
}

.footer-bottom-links[b-mb31mmi986] {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

@media (min-width: 640px) {
    .footer-bottom-links[b-mb31mmi986] {
        gap: 1.5rem;
    }
}

.footer-bottom-links a[b-mb31mmi986] {
    color: #6b7280;
    transition: color .2s;
}

    .footer-bottom-links a:hover[b-mb31mmi986] {
        color: #fff;
    }
