/* Swadhina Biology Academy Pro - Frontend */
.sbap-page,
.sbap-page * {
    box-sizing: border-box;
}
.sbap-page {
    --sbap-radius: 22px;
    --sbap-shadow: 0 18px 55px rgba(15, 47, 36, .12);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: #163226;
    background: #fff;
    overflow-x: hidden;
}
.sbap-page a { text-decoration: none; }
.sbap-container {
    width: min(1220px, calc(100% - 32px));
    margin: 0 auto;
}
.sbap-hero {
    position: relative;
    min-height: 640px;
    display: flex;
    align-items: center;
    background-color: #0f2f24;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: #fff;
    overflow: hidden;
}
.sbap-hero:before,
.sbap-hero:after {
    content: "";
    position: absolute;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    filter: blur(2px);
}
.sbap-hero:before { width: 340px; height: 340px; top: -120px; left: -70px; }
.sbap-hero:after { width: 420px; height: 420px; bottom: -190px; right: 8%; }
.sbap-hero-inner {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, .55fr);
    gap: 44px;
    align-items: center;
    padding: 92px 0;
}
.sbap-hero h1,
.sbap-page-head h1 {
    margin: 14px 0 18px;
    line-height: 1.04;
    letter-spacing: -.04em;
    font-weight: 900;
}
.sbap-hero h1 { font-size: clamp(42px, 6vw, 76px); max-width: 850px; text-shadow: 0 4px 22px rgba(0,0,0,.42); }
.sbap-hero p {
    font-size: clamp(17px, 1.6vw, 22px);
    line-height: 1.7;
    max-width: 760px;
    color: rgba(255,255,255,.98);
    text-shadow: 0 3px 18px rgba(0,0,0,.42);
}
.sbap-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(27,143,90,.1);
    color: var(--sbap-accent);
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .03em;
    text-transform: uppercase;
}
.sbap-hero .sbap-pill { background: rgba(255,255,255,.14); color: #eaffef; }
.sbap-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 30px;
}
.sbap-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: 0;
    border-radius: 999px;
    min-height: 46px;
    padding: 12px 22px;
    font-weight: 800;
    cursor: pointer;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
    white-space: nowrap;
}
.sbap-btn:hover { transform: translateY(-2px); }
.sbap-btn-primary {
    background: var(--sbap-accent);
    color: #fff !important;
    box-shadow: 0 14px 35px rgba(27,143,90,.28);
}
.sbap-btn-light {
    background: #fff;
    color: var(--sbap-dark) !important;
    box-shadow: 0 12px 28px rgba(15,47,36,.11);
}
.sbap-hero-card {
    background: rgba(255,255,255,.94);
    color: var(--sbap-dark);
    border-radius: 30px;
    padding: 30px;
    box-shadow: var(--sbap-shadow);
    border: 1px solid rgba(255,255,255,.5);
}
.sbap-hero-card strong { font-size: 24px; display: block; margin-bottom: 16px; }
.sbap-class-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-bottom: 16px;
}
.sbap-class-grid span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 70px;
    background: var(--sbap-soft);
    border-radius: 18px;
    color: var(--sbap-accent);
    font-size: 28px;
    font-weight: 900;
}
.sbap-hero-card p { color: #4b6359; font-size: 15px; line-height: 1.6; }
.sbap-section { padding: 74px 0; }
.sbap-soft { background: linear-gradient(180deg, var(--sbap-soft), #fff); }
.sbap-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 28px;
}
.sbap-section-head > span {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    background: var(--sbap-dark);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    flex: 0 0 auto;
}
.sbap-section-head h2,
.sbap-form-card h2,
.sbap-content-card h2,
.sbap-teacher-card h2,
.sbap-page-head h1 {
    color: var(--sbap-dark);
}
.sbap-section-head h2 {
    flex: 1;
    font-size: clamp(28px, 3vw, 46px);
    margin: 0;
    letter-spacing: -.03em;
}
.sbap-section-head a,
.sbap-text-link {
    color: var(--sbap-accent);
    font-weight: 900;
}
.sbap-large-text {
    background: #fff;
    border: 1px solid rgba(27,143,90,.13);
    box-shadow: var(--sbap-shadow);
    border-radius: var(--sbap-radius);
    padding: clamp(24px, 4vw, 42px);
    font-size: clamp(18px, 2vw, 24px);
    line-height: 1.7;
    color: #405a4f;
}
.sbap-two-col {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, .8fr);
    gap: 34px;
}
.sbap-align-start { align-items: start; }
.sbap-teacher-card,
.sbap-form-card,
.sbap-content-card,
.sbap-info-card,
.sbap-course-card,
.sbap-blog-card,
.sbap-resource-card,
.sbap-test-box {
    background: #fff;
    border: 1px solid rgba(27,143,90,.12);
    border-radius: var(--sbap-radius);
    box-shadow: var(--sbap-shadow);
}
.sbap-teacher-card {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 28px;
    padding: 26px;
}
.sbap-teacher-photo-wrap { min-height: 300px; }
.sbap-teacher-photo,
.sbap-photo-placeholder {
    width: 100%;
    height: 100%;
    min-height: 310px;
    border-radius: 22px;
    object-fit: cover;
    background: linear-gradient(135deg, #dff5e7, #fff);
}
.sbap-photo-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--sbap-accent);
    font-weight: 900;
}

.sbap-teacher-photo-stack {
    display: grid;
    grid-template-rows: auto auto;
    gap: 16px;
}
.sbap-teacher-photo-wrap {
    min-height: 300px;
}
.sbap-teacher-experience-box {
    border-radius: 24px;
    background: linear-gradient(135deg, var(--sbap-dark), var(--sbap-accent));
    color: #fff;
    padding: 24px 20px;
    text-align: center;
    box-shadow: 0 18px 40px rgba(15,47,36,.16);
}
.sbap-teacher-experience-number {
    font-size: clamp(44px, 6vw, 72px);
    line-height: 1;
    font-weight: 900;
    letter-spacing: -.04em;
    margin-bottom: 8px;
}
.sbap-teacher-experience-text {
    font-size: 16px;
    line-height: 1.45;
    font-weight: 700;
    color: rgba(255,255,255,.94);
}
.sbap-teacher-card h2 { margin: 14px 0 10px; font-size: clamp(28px, 3vw, 42px); }
.sbap-teacher-card p { color: #4a665a; line-height: 1.7; }
.sbap-check-list { margin: 18px 0 0; padding: 0; list-style: none; display: grid; gap: 12px; }
.sbap-check-list li {
    position: relative;
    padding-left: 34px;
    line-height: 1.55;
    color: #31493e;
}
.sbap-check-list li:before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0;
    width: 23px;
    height: 23px;
    border-radius: 50%;
    background: var(--sbap-accent);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    font-size: 13px;
}
.sbap-form-card { padding: 28px; }
.sbap-form-card h2,
.sbap-form-card h3 { margin-top: 0; }
.sbap-lead-form label,
.sbap-auth-grid label,
.sbap-filter label,
.sbap-test-box label {
    display: grid;
    gap: 7px;
    font-weight: 800;
    color: #244336;
    font-size: 14px;
}
.sbap-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 18px;
}
.sbap-full { grid-column: 1 / -1; }
.sbap-lead-form input,
.sbap-lead-form select,
.sbap-lead-form textarea,
.sbap-auth-grid input,
.sbap-auth-grid select,
.sbap-filter select,
.sbap-test-box input[type="text"],
.sbap-test-box textarea {
    width: 100%;
    min-height: 46px;
    border-radius: 14px;
    border: 1px solid rgba(27,143,90,.24);
    background: #fbfffc;
    padding: 11px 13px;
    outline: none;
    color: #18382c;
}
.sbap-lead-form textarea { resize: vertical; }
.sbap-lead-form input:focus,
.sbap-lead-form select:focus,
.sbap-lead-form textarea:focus,
.sbap-auth-grid input:focus,
.sbap-auth-grid select:focus,
.sbap-filter select:focus {
    border-color: var(--sbap-accent);
    box-shadow: 0 0 0 4px rgba(27,143,90,.12);
}
.sbap-three-cards,
.sbap-card-grid,
.sbap-resource-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}
.sbap-info-card { padding: 30px; min-height: 260px; }
.sbap-info-card > span {
    display: inline-flex;
    width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    background: var(--sbap-soft);
    color: var(--sbap-accent);
    font-weight: 900;
    margin-bottom: 16px;
}
.sbap-info-card h3,
.sbap-course-card h3,
.sbap-blog-card h3,
.sbap-resource-card h3 {
    margin: 0 0 12px;
    color: var(--sbap-dark);
    line-height: 1.18;
}
.sbap-info-card p,
.sbap-course-card p,
.sbap-blog-card p,
.sbap-resource-card p,
.sbap-content-card p {
    color: #52675e;
    line-height: 1.65;
}
.sbap-page-head {
    position: relative;
    color: #fff;
    padding: 104px 0;
    overflow: hidden;
    background-color: #0f2f24;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.sbap-page-head .sbap-container { position: relative; z-index: 2; }
.sbap-page-head .sbap-pill { background: rgba(255,255,255,.16); color: #fff; }
.sbap-page-head h1 { font-size: clamp(42px, 5vw, 68px); color: #fff; text-shadow: 0 2px 20px rgba(0,0,0,.25); }
.sbap-page-head p { max-width: 900px; color: rgba(255,255,255,.96); line-height: 1.7; font-size: 19px; text-shadow: 0 2px 18px rgba(0,0,0,.34); }
.sbap-content-card { padding: clamp(24px, 4vw, 42px); }
.sbap-prose { font-size: 18px; line-height: 1.75; color: #344c42; }
.sbap-course-card,
.sbap-blog-card { overflow: hidden; }
.sbap-card-thumb { display: block; height: 205px; background: var(--sbap-soft); overflow: hidden; }
.sbap-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .25s ease; }
.sbap-card-thumb:hover img { transform: scale(1.04); }
.sbap-card-body { padding: 24px; }
.sbap-course-meta { display: flex; flex-wrap: wrap; gap: 8px; margin: 16px 0; }
.sbap-course-meta span {
    background: var(--sbap-soft);
    color: var(--sbap-dark);
    border-radius: 999px;
    padding: 7px 11px;
    font-size: 12px;
    font-weight: 800;
}
.sbap-date { color: var(--sbap-accent); font-weight: 900; margin-bottom: 8px; font-size: 13px; }
.sbap-filter {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 28px;
    background: #fff;
    padding: 18px;
    border-radius: var(--sbap-radius);
    box-shadow: var(--sbap-shadow);
    border: 1px solid rgba(27,143,90,.12);
}
.sbap-filter select { min-width: 180px; }
.sbap-resource-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.sbap-resource-card {
    padding: 24px;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: center;
}
.sbap-resource-card small { color: #759085; font-weight: 700; }
.sbap-auth-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
    align-items: start;
}
.sbap-dashboard-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 28px;
    border-radius: var(--sbap-radius);
    background: linear-gradient(135deg, var(--sbap-dark), var(--sbap-accent));
    color: #fff;
    margin-bottom: 28px;
}
.sbap-dashboard-head h2 { color: #fff; margin: 10px 0; }
.sbap-dashboard-head p { color: rgba(255,255,255,.86); }
.sbap-dashboard-head .sbap-pill { background: rgba(255,255,255,.14); color: #fff; }
.sbap-student-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 28px;
    margin-bottom: 28px;
}
.sbap-table-wrap { overflow-x: auto; }
.sbap-table { width: 100%; border-collapse: collapse; min-width: 640px; }
.sbap-table th,
.sbap-table td { padding: 13px; border-bottom: 1px solid rgba(27,143,90,.12); text-align: left; }
.sbap-table th { background: var(--sbap-soft); color: var(--sbap-dark); }
.sbap-test-box { padding: 28px; }
.sbap-question {
    padding: 22px;
    border-radius: 18px;
    background: #fbfffc;
    border: 1px solid rgba(27,143,90,.12);
    margin-bottom: 18px;
}
.sbap-question h3 { margin-top: 0; }
.sbap-question label { display: flex; align-items: center; gap: 10px; margin: 10px 0; font-weight: 600; }
.sbap-empty,
.sbap-notice {
    padding: 18px 20px;
    border-radius: 18px;
    background: var(--sbap-soft);
    color: var(--sbap-dark);
    font-weight: 800;
    border: 1px solid rgba(27,143,90,.12);
}
.sbap-notice { margin: 20px 0; box-shadow: var(--sbap-shadow); }
.sbap-float-wa {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 9999;
    background: #25d366;
    color: #fff !important;
    padding: 14px 18px;
    border-radius: 999px;
    font-weight: 900;
    box-shadow: 0 16px 35px rgba(0,0,0,.18);
}

body.sbap-fullwidth-body .site-content .ast-container,
body.sbap-fullwidth-body .site-content .container,
body.sbap-fullwidth-body .site-main,
body.sbap-fullwidth-body .content-area,
body.sbap-fullwidth-body .entry-content,
body.sbap-fullwidth-body .wp-block-post-content {
    max-width: none !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
body.sbap-fullwidth-body .entry-title,
body.sbap-fullwidth-body .page-title {
    display: none !important;
}

body .site-content .ast-container:has(.sbap-page),
body .site-content .container:has(.sbap-page),
body .entry-content:has(.sbap-page),
body .wp-block-post-content:has(.sbap-page) {
    max-width: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
body:has(.sbap-page) .entry-title,
body:has(.sbap-page) .page-title {
    display: none !important;
}
@media (max-width: 1024px) {
    .sbap-hero-inner,
    .sbap-two-col,
    .sbap-auth-grid { grid-template-columns: 1fr; }
    .sbap-hero { background-color: #0f2f24; background-size: cover; background-position: center; }
    .sbap-teacher-card { grid-template-columns: 220px 1fr; }
    .sbap-three-cards,
    .sbap-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
    .sbap-container { width: min(100% - 22px, 1220px); }
    .sbap-hero { min-height: auto; }
    .sbap-hero-inner { padding: 66px 0; }
    .sbap-actions { flex-direction: column; }
    .sbap-btn { width: 100%; }
    .sbap-section { padding: 48px 0; }
    .sbap-section-head { align-items: flex-start; }
    .sbap-section-head h2 { font-size: 30px; }
    .sbap-teacher-card { grid-template-columns: 1fr; }

    .sbap-teacher-photo-stack { gap: 14px; }
    .sbap-form-grid,
    .sbap-three-cards,
    .sbap-card-grid,
    .sbap-resource-grid { grid-template-columns: 1fr; }
    .sbap-resource-card { align-items: stretch; flex-direction: column; }
    .sbap-dashboard-head { align-items: stretch; flex-direction: column; }
    .sbap-page-head { padding: 62px 0; }
    .sbap-float-wa { right: 12px; bottom: 12px; padding: 12px 15px; }
}


/* v2.2 visual enhancements */
.sbap-page-kicker {
    display: inline-block;
    margin-bottom: 14px;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.10);
    color: #eafbf2;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
}
.sbap-teacher-card {
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, #ffffff 0%, #f7fdf9 100%);
}
.sbap-teacher-card::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
    background: linear-gradient(90deg, var(--sbap-accent), #5ad39a);
}
.sbap-teacher-photo-wrap {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(145deg, rgba(27,143,90,.12), rgba(15,47,36,.03));
    padding: 10px;
}
.sbap-teacher-photo,
.sbap-photo-placeholder {
    box-shadow: 0 18px 40px rgba(15,47,36,.12);
}
.sbap-teacher-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 10px 0 14px;
}
.sbap-teacher-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 8px 12px;
    border-radius: 999px;
    background: var(--sbap-soft);
    border: 1px solid rgba(27,143,90,.12);
    color: var(--sbap-dark);
    font-size: 12px;
    font-weight: 800;
}
.sbap-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.sbap-card-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 54px;
    height: 54px;
    border-radius: 18px;
    background: linear-gradient(135deg, var(--sbap-accent), #57c690);
    color: #fff;
    font-size: 25px;
    box-shadow: 0 16px 32px rgba(27,143,90,.22);
}
.sbap-card-top small {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 42px;
    border-radius: 14px;
    background: var(--sbap-soft);
    color: var(--sbap-accent);
    font-size: 12px;
    font-weight: 900;
}
.sbap-info-card {
    position: relative;
    overflow: hidden;
    transition: transform .18s ease, box-shadow .18s ease;
}
.sbap-info-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 22px 52px rgba(15,47,36,.16);
}
.sbap-float-wa {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 220px;
    padding: 12px 16px 12px 12px;
    background: linear-gradient(135deg, #22c55e, #18a34a);
}
.sbap-float-wa-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(255,255,255,.16);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 44px;
}
.sbap-float-wa-icon svg {
    width: 24px;
    height: 24px;
}
.sbap-float-wa-text {
    display: grid;
    gap: 2px;
    line-height: 1.1;
}
.sbap-float-wa-text strong {
    font-size: 14px;
    font-weight: 900;
    color: #fff;
}
.sbap-float-wa-text small {
    font-size: 11px;
    color: rgba(255,255,255,.92);
}
.sbap-float-wa::after {
    content: '';
    position: absolute;
    inset: -6px;
    border-radius: 999px;
    border: 1px solid rgba(37,211,102,.28);
    animation: sbapWaPulse 2s infinite;
    pointer-events: none;
}
@keyframes sbapWaPulse {
    0% { transform: scale(1); opacity: .8; }
    70% { transform: scale(1.08); opacity: 0; }
    100% { transform: scale(1.08); opacity: 0; }
}
@media (max-width: 760px) {
    .sbap-page-kicker { margin-bottom: 10px; }
        .sbap-float-wa { min-width: 0; padding: 10px 12px; }
    .sbap-float-wa-text small { display: none; }
}

/* v2.5 premium Study Materials and exam-style Online Tests */
.sbap-material-stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin: 0 0 26px; }
.sbap-material-stats > div { border-radius: 22px; padding: 22px; background: linear-gradient(135deg, var(--sbap-dark), var(--sbap-accent)); color: #fff; box-shadow: 0 18px 44px rgba(15,47,36,.13); }
.sbap-material-stats strong { display: block; font-size: clamp(22px, 2.4vw, 32px); line-height: 1.1; margin-bottom: 6px; }
.sbap-material-stats span { color: rgba(255,255,255,.88); font-weight: 700; }
.sbap-premium-material-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.sbap-premium-material-card { display: grid; grid-template-columns: 74px 1fr; gap: 18px; align-items: start; position: relative; padding: 24px; border-radius: 26px; background: #fff; border: 1px solid rgba(27,143,90,.13); box-shadow: 0 18px 48px rgba(15,47,36,.10); transition: transform .18s ease, box-shadow .18s ease; }
.sbap-premium-material-card:hover { transform: translateY(-4px); box-shadow: 0 24px 58px rgba(15,47,36,.15); }
.sbap-material-icon { width: 74px; height: 74px; border-radius: 24px; display: inline-flex; align-items: center; justify-content: center; background: var(--sbap-soft); font-size: 34px; }
.sbap-material-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.sbap-material-tags span { padding: 6px 10px; border-radius: 999px; background: rgba(27,143,90,.09); color: var(--sbap-dark); font-size: 12px; font-weight: 900; }
.sbap-premium-material-card h3 { margin: 0 0 10px; font-size: clamp(20px, 2vw, 27px); color: var(--sbap-dark); line-height: 1.17; }
.sbap-premium-material-card p { margin: 0 0 14px; color: #52675e; line-height: 1.65; }
.sbap-material-chapter { color: #2b4a3d; font-size: 14px; }
.sbap-material-action { grid-column: 1 / -1; display: flex; justify-content: flex-end; }
.sbap-material-action .sbap-btn { width: auto; }
.sbap-exam-panel { display: grid; grid-template-columns: 1fr auto; gap: 22px; align-items: center; border-radius: 30px; padding: clamp(24px, 4vw, 42px); margin: 0 0 28px; background: linear-gradient(135deg, var(--sbap-dark), #0f6845); color: #fff; box-shadow: 0 20px 55px rgba(15,47,36,.14); }
.sbap-exam-label { display: inline-flex; padding: 7px 13px; border-radius: 999px; background: rgba(255,255,255,.14); color: #fff; font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.sbap-exam-panel h2 { margin: 14px 0 8px; font-size: clamp(28px, 3vw, 46px); line-height: 1.1; color: #fff; }
.sbap-exam-panel p { color: rgba(255,255,255,.9); margin: 0; font-size: 17px; }
.sbap-exam-rules { display: grid; gap: 10px; }
.sbap-exam-rules span { display: block; padding: 10px 14px; border-radius: 999px; background: rgba(255,255,255,.13); color: #fff; font-weight: 800; white-space: nowrap; }
.sbap-exam-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.sbap-exam-card { position: relative; border-radius: 28px; background: #fff; border: 1px solid rgba(27,143,90,.13); box-shadow: 0 18px 48px rgba(15,47,36,.10); padding: 26px; overflow: hidden; }
.sbap-exam-card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 5px; background: linear-gradient(90deg, var(--sbap-accent), #57c690); }
.sbap-exam-card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 18px; }
.sbap-exam-class { display: inline-flex; padding: 6px 11px; border-radius: 999px; background: var(--sbap-soft); color: var(--sbap-accent); font-size: 12px; font-weight: 900; }
.sbap-exam-card h3 { margin: 12px 0; color: var(--sbap-dark); font-size: clamp(22px, 2.2vw, 30px); line-height: 1.15; }
.sbap-exam-card p { color: #52675e; line-height: 1.65; }
.sbap-exam-timer { min-width: 72px; height: 72px; border-radius: 22px; background: var(--sbap-dark); color: #fff; display: grid; place-items: center; font-size: 26px; font-weight: 900; line-height: 1; }
.sbap-exam-timer small { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; opacity: .8; }
.sbap-exam-meta { display: flex; flex-wrap: wrap; gap: 8px; margin: 18px 0 20px; }
.sbap-exam-meta span { padding: 8px 10px; border-radius: 999px; background: rgba(27,143,90,.09); color: #244336; font-size: 13px; font-weight: 800; }
.sbap-test-paper { background: #fff; border: 1px solid rgba(27,143,90,.12); border-radius: 30px; box-shadow: 0 20px 55px rgba(15,47,36,.12); overflow: hidden; }
.sbap-test-paper-head { display: grid; grid-template-columns: 1fr auto; gap: 22px; align-items: center; background: linear-gradient(135deg, var(--sbap-dark), #0f6845); color: #fff; padding: clamp(24px, 4vw, 40px); }
.sbap-test-paper-head h2 { color: #fff; margin: 14px 0 8px; font-size: clamp(28px, 3vw, 46px); }
.sbap-test-paper-head p { color: rgba(255,255,255,.9); margin: 0; }
.sbap-test-paper-stats { display: grid; grid-template-columns: repeat(3, minmax(90px, 1fr)); gap: 10px; }
.sbap-test-paper-stats span { border-radius: 18px; padding: 14px; background: rgba(255,255,255,.12); text-align: center; color: rgba(255,255,255,.86); font-size: 12px; font-weight: 800; }
.sbap-test-paper-stats strong { display: block; color: #fff; font-size: 24px; line-height: 1.1; }
.sbap-exam-question { display: grid; grid-template-columns: 70px 1fr; gap: 18px; padding: 28px; border-bottom: 1px solid rgba(27,143,90,.11); }
.sbap-question-number { width: 58px; height: 58px; border-radius: 19px; background: var(--sbap-soft); color: var(--sbap-accent); display: inline-flex; align-items: center; justify-content: center; font-weight: 900; }
.sbap-question-body h3 { margin: 0 0 18px; color: var(--sbap-dark); font-size: 20px; line-height: 1.45; }
.sbap-option-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.sbap-option { position: relative; display: flex !important; align-items: center; gap: 12px !important; border: 1px solid rgba(27,143,90,.16); border-radius: 18px; padding: 14px; background: #fbfffc; cursor: pointer; transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease; }
.sbap-option:hover { border-color: var(--sbap-accent); box-shadow: 0 10px 24px rgba(15,47,36,.08); transform: translateY(-1px); }
.sbap-option input { position: absolute; opacity: 0; }
.sbap-option span { width: 34px; height: 34px; border-radius: 12px; background: var(--sbap-soft); color: var(--sbap-accent); display: inline-flex; align-items: center; justify-content: center; font-weight: 900; flex: 0 0 auto; }
.sbap-option input:checked + span { background: var(--sbap-accent); color: #fff; }
.sbap-option strong { color: #244336; font-size: 14px; line-height: 1.45; }
.sbap-test-submit-bar { display: flex; justify-content: space-between; align-items: center; gap: 18px; padding: 24px 28px; background: #f7fdf9; }
.sbap-test-submit-bar p { margin: 0; color: #52675e; font-weight: 700; }
.sbap-premium-empty { border-radius: 24px; background: linear-gradient(135deg, #ffffff, var(--sbap-soft)); }
@media (max-width: 920px) { .sbap-premium-material-grid, .sbap-exam-grid, .sbap-exam-panel, .sbap-test-paper-head, .sbap-option-grid { grid-template-columns: 1fr; } .sbap-test-paper-stats { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 620px) { .sbap-material-stats { grid-template-columns: 1fr; } .sbap-premium-material-card, .sbap-exam-question { grid-template-columns: 1fr; } .sbap-test-paper-stats { grid-template-columns: 1fr; } .sbap-test-submit-bar { flex-direction: column; align-items: stretch; } }

/* v3.0 LMS Pro frontend */
.sbap-v3-page .sbap-section { background: linear-gradient(180deg, #f7fffa, #ffffff); }
.sbap-v3-hero {
    position: relative;
    min-height: 430px;
    display: flex;
    align-items: center;
    padding: 70px max(24px, calc((100vw - 1220px)/2));
    color: #fff;
    background-image: linear-gradient(90deg, rgba(4,18,15,.78), rgba(8,31,24,.58), rgba(10,39,30,.38)), url("../images/home-banner.png");
    background-size: cover;
    background-position: center;
}
.sbap-v3-lessons-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.78), rgba(8,31,24,.58), rgba(10,39,30,.38)), url("../images/materials-banner.png"); }
.sbap-v3-admission-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.78), rgba(8,31,24,.58), rgba(10,39,30,.38)), url("../images/contact-banner.png"); }
.sbap-v3-assignment-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.78), rgba(8,31,24,.58), rgba(10,39,30,.38)), url("../images/syllabus-banner.png"); }
.sbap-v3-hero > div { max-width: 850px; }
.sbap-v3-hero span,
.sbap-v3-dashboard-head span {
    display:inline-flex;
    padding:7px 13px;
    border-radius:999px;
    background:rgba(255,255,255,.14);
    font-size:12px;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.sbap-v3-hero h1 {
    margin:16px 0;
    font-size:clamp(42px,5vw,72px);
    line-height:1.05;
    color:#fff;
    text-shadow:0 4px 24px rgba(0,0,0,.42);
}
.sbap-v3-hero p {
    font-size:20px;
    line-height:1.65;
    color:rgba(255,255,255,.96);
    text-shadow:0 3px 18px rgba(0,0,0,.38);
}
.sbap-v3-login-card,
.sbap-v3-form-wrap,
.sbap-v3-dashboard-head,
.sbap-v3-card,
.sbap-v3-stat-grid > div {
    background:#fff;
    border:1px solid rgba(27,143,90,.12);
    border-radius:28px;
    box-shadow:0 18px 50px rgba(15,47,36,.11);
}
.sbap-v3-login-card { padding:34px; }
.sbap-v3-dashboard-head {
    padding:30px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    margin-bottom:24px;
    background:linear-gradient(135deg,var(--sbap-dark),#0f6845);
    color:#fff;
}
.sbap-v3-dashboard-head h2 { color:#fff;margin:12px 0 6px;font-size:clamp(30px,3vw,48px); }
.sbap-v3-dashboard-head p { margin:0;color:rgba(255,255,255,.9); }
.sbap-v3-stat-grid {
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:18px;
    margin-bottom:24px;
}
.sbap-v3-stat-grid > div { padding:24px;text-align:center; }
.sbap-v3-stat-grid strong {
    display:block;
    font-size:clamp(26px,3vw,40px);
    color:var(--sbap-accent);
    line-height:1.1;
    margin-bottom:7px;
}
.sbap-v3-stat-grid span { font-weight:800;color:#405a4f; }
.sbap-v3-quick-grid {
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:14px;
    margin-bottom:32px;
}
.sbap-v3-quick-grid a {
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:82px;
    border-radius:22px;
    background:var(--sbap-soft);
    color:var(--sbap-dark);
    font-weight:900;
    text-align:center;
    border:1px solid rgba(27,143,90,.12);
}
.sbap-v3-section-title {
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin:30px 0 20px;
}
.sbap-v3-section-title h2 { margin:0;color:var(--sbap-dark);font-size:clamp(28px,3vw,42px); }
.sbap-v3-section-title a { color:var(--sbap-accent);font-weight:900; }
.sbap-v3-card-grid {
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:22px;
}
.sbap-v3-card {
    padding:24px;
    transition:transform .18s ease, box-shadow .18s ease;
}
.sbap-v3-card:hover { transform:translateY(-4px);box-shadow:0 24px 58px rgba(15,47,36,.15); }
.sbap-v3-card h3 { color:var(--sbap-dark);font-size:24px;line-height:1.2;margin:12px 0; }
.sbap-v3-card p { color:#52675e;line-height:1.65; }
.sbap-v3-tags { display:flex;gap:8px;flex-wrap:wrap; }
.sbap-v3-tags span {
    padding:6px 10px;
    border-radius:999px;
    background:rgba(27,143,90,.09);
    color:var(--sbap-dark);
    font-size:12px;
    font-weight:900;
}
.sbap-v3-card-actions { display:flex;gap:10px;flex-wrap:wrap;margin-top:18px; }
.sbap-v3-filter {
    display:grid;
    grid-template-columns:180px 1fr auto;
    gap:12px;
    background:#fff;
    border:1px solid rgba(27,143,90,.12);
    border-radius:24px;
    padding:18px;
    box-shadow:0 12px 34px rgba(15,47,36,.08);
    margin-bottom:24px;
}
.sbap-v3-filter input,
.sbap-v3-filter select,
.sbap-v3-form input,
.sbap-v3-form select,
.sbap-v3-form textarea {
    min-height:46px;
    border-radius:14px;
    border:1px solid rgba(27,143,90,.24);
    padding:11px 13px;
    background:#fbfffc;
}
.sbap-v3-form-wrap { padding:28px; }
.sbap-v3-honeypot { position:absolute; left:-9999px; opacity:0; }
.sbap-live-timer {
    display:inline-flex;
    align-items:center;
    gap:10px;
    margin-top:16px;
    padding:10px 14px;
    border-radius:999px;
    background:rgba(255,255,255,.14);
    font-weight:900;
}
.sbap-live-timer strong {
    font-size:20px;
    color:#fff;
}
.sbap-live-timer.sbap-danger {
    background:#dc2626;
    animation: sbapTimerBlink 1s infinite;
}
@keyframes sbapTimerBlink { 0%,100%{opacity:1} 50%{opacity:.65} }
@media(max-width:980px){
    .sbap-v3-stat-grid,.sbap-v3-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .sbap-v3-quick-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .sbap-v3-filter{grid-template-columns:1fr}
}
@media(max-width:620px){
    .sbap-v3-stat-grid,.sbap-v3-card-grid,.sbap-v3-quick-grid{grid-template-columns:1fr}
    .sbap-v3-dashboard-head{flex-direction:column;align-items:flex-start}
}

/* v3.1 Professional UI upgrade */
.sbap-v31-kicker {
    display:inline-flex;
    padding:7px 13px;
    border-radius:999px;
    background:rgba(27,143,90,.11);
    color:var(--sbap-accent);
    font-size:12px;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.sbap-v31-home-upgrade {
    background:
        radial-gradient(circle at 10% 0%, rgba(27,143,90,.12), transparent 35%),
        linear-gradient(180deg, #f7fffa, #ffffff);
}
.sbap-v31-split-hero {
    display:grid;
    grid-template-columns:1.2fr .8fr;
    gap:34px;
    align-items:center;
    border-radius:34px;
    padding:clamp(28px,5vw,54px);
    background:#fff;
    border:1px solid rgba(27,143,90,.13);
    box-shadow:0 24px 70px rgba(15,47,36,.12);
}
.sbap-v31-split-hero h2 {
    margin:14px 0;
    color:var(--sbap-dark);
    font-size:clamp(34px,4vw,58px);
    line-height:1.06;
    letter-spacing:-.04em;
}
.sbap-v31-split-hero p {
    color:#52675e;
    font-size:18px;
    line-height:1.7;
    max-width:760px;
}
.sbap-v31-feature-stack {
    display:grid;
    gap:14px;
}
.sbap-v31-feature-stack div {
    display:grid;
    grid-template-columns:56px 1fr;
    gap:14px;
    align-items:center;
    padding:16px;
    border-radius:22px;
    background:var(--sbap-soft);
    border:1px solid rgba(27,143,90,.13);
}
.sbap-v31-feature-stack strong {
    width:56px;
    height:56px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:18px;
    background:var(--sbap-dark);
    color:#fff;
    font-weight:900;
}
.sbap-v31-feature-stack span {
    color:var(--sbap-dark);
    font-weight:800;
    line-height:1.45;
}
.sbap-v31-home-feature-grid {
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:18px;
    margin-top:24px;
}
.sbap-v31-home-feature-grid > div {
    padding:24px;
    border-radius:26px;
    background:#fff;
    border:1px solid rgba(27,143,90,.13);
    box-shadow:0 16px 45px rgba(15,47,36,.09);
}
.sbap-v31-home-feature-grid span {
    font-size:34px;
}
.sbap-v31-home-feature-grid h3 {
    color:var(--sbap-dark);
    margin:14px 0 9px;
    font-size:22px;
}
.sbap-v31-home-feature-grid p {
    color:#52675e;
    line-height:1.65;
    margin:0;
}
.sbap-v31-page-hero {
    position:relative;
    min-height:430px;
    display:flex;
    align-items:center;
    padding:75px max(24px, calc((100vw - 1220px)/2));
    color:#fff;
    background-size:cover;
    background-position:center;
    background-image:linear-gradient(90deg, rgba(4,18,15,.80), rgba(8,31,24,.58), rgba(10,39,30,.36)), url("../images/home-banner.png");
}
.sbap-v31-demo-hero { background-image:linear-gradient(90deg, rgba(4,18,15,.80), rgba(8,31,24,.58), rgba(10,39,30,.36)), url("../images/contact-banner.png"); }
.sbap-v31-pricing-hero { background-image:linear-gradient(90deg, rgba(4,18,15,.80), rgba(8,31,24,.58), rgba(10,39,30,.36)), url("../images/courses-banner.png"); }
.sbap-v31-faq-hero { background-image:linear-gradient(90deg, rgba(4,18,15,.80), rgba(8,31,24,.58), rgba(10,39,30,.36)), url("../images/syllabus-banner.png"); }
.sbap-v31-success-hero { background-image:linear-gradient(90deg, rgba(4,18,15,.80), rgba(8,31,24,.58), rgba(10,39,30,.36)), url("../images/blogs-banner.png"); }
.sbap-v31-dashboard-hero { background-image:linear-gradient(90deg, rgba(4,18,15,.80), rgba(8,31,24,.58), rgba(10,39,30,.36)), url("../images/portal-banner.png"); }
.sbap-v31-page-hero > div {
    max-width:850px;
}
.sbap-v31-page-hero span {
    display:inline-flex;
    padding:7px 13px;
    border-radius:999px;
    background:rgba(255,255,255,.14);
    font-size:12px;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.sbap-v31-page-hero h1 {
    color:#fff;
    margin:16px 0;
    font-size:clamp(42px,5vw,72px);
    line-height:1.04;
    text-shadow:0 4px 24px rgba(0,0,0,.42);
}
.sbap-v31-page-hero p {
    color:rgba(255,255,255,.96);
    font-size:20px;
    line-height:1.65;
    text-shadow:0 3px 18px rgba(0,0,0,.38);
}
.sbap-v31-demo-layout {
    display:grid;
    grid-template-columns:.75fr 1.25fr;
    gap:28px;
    align-items:start;
}
.sbap-v31-demo-info,
.sbap-v31-form,
.sbap-v31-pricing-head,
.sbap-v31-price-card,
.sbap-v31-faq,
.sbap-v31-testimonial,
.sbap-v31-access-card,
.sbap-v31-student-hero-card,
.sbap-v31-progress-grid > div,
.sbap-v31-action-grid a {
    background:#fff;
    border:1px solid rgba(27,143,90,.13);
    border-radius:28px;
    box-shadow:0 18px 50px rgba(15,47,36,.10);
}
.sbap-v31-demo-info,
.sbap-v31-form,
.sbap-v31-pricing-head,
.sbap-v31-access-card {
    padding:30px;
}
.sbap-v31-demo-info h2,
.sbap-v31-pricing-head h2 {
    color:var(--sbap-dark);
    font-size:clamp(30px,3vw,46px);
    line-height:1.1;
    margin:0 0 12px;
}
.sbap-v31-demo-info p,
.sbap-v31-pricing-head p {
    color:#52675e;
    line-height:1.7;
}
.sbap-v31-demo-info ul,
.sbap-v31-price-card ul {
    margin:18px 0 0;
    padding:0;
    list-style:none;
    display:grid;
    gap:10px;
}
.sbap-v31-demo-info li,
.sbap-v31-price-card li {
    position:relative;
    padding-left:30px;
    color:#244336;
    font-weight:700;
}
.sbap-v31-demo-info li:before,
.sbap-v31-price-card li:before {
    content:"✓";
    position:absolute;
    left:0;
    top:0;
    color:var(--sbap-accent);
    font-weight:900;
}
.sbap-v31-form input,
.sbap-v31-form select,
.sbap-v31-form textarea {
    width:100%;
    min-height:46px;
    border-radius:14px;
    border:1px solid rgba(27,143,90,.24);
    background:#fbfffc;
    padding:11px 13px;
}
.sbap-v31-honeypot {
    position:absolute;
    left:-9999px;
    opacity:0;
}
.sbap-v31-pricing-grid {
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:22px;
    margin-top:24px;
}
.sbap-v31-price-card {
    padding:28px;
    position:relative;
    overflow:hidden;
}
.sbap-v31-price-card.featured {
    transform:translateY(-8px);
    border-color:rgba(27,143,90,.28);
    box-shadow:0 28px 70px rgba(15,47,36,.16);
}
.sbap-v31-price-badge {
    display:inline-flex;
    padding:7px 12px;
    border-radius:999px;
    background:var(--sbap-soft);
    color:var(--sbap-accent);
    font-size:12px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.06em;
}
.sbap-v31-price-card h3 {
    color:var(--sbap-dark);
    margin:16px 0 10px;
    font-size:27px;
    line-height:1.15;
}
.sbap-v31-price {
    color:var(--sbap-accent);
    font-weight:900;
    font-size:30px;
    margin-bottom:12px;
}
.sbap-v31-price-card p {
    color:#52675e;
    line-height:1.65;
}
.sbap-v31-faq-list {
    display:grid;
    gap:14px;
    max-width:980px;
    margin:0 auto;
}
.sbap-v31-faq {
    padding:0;
    overflow:hidden;
}
.sbap-v31-faq summary {
    cursor:pointer;
    padding:22px 26px;
    color:var(--sbap-dark);
    font-size:18px;
    font-weight:900;
}
.sbap-v31-faq div {
    padding:0 26px 22px;
    color:#52675e;
    line-height:1.75;
}
.sbap-v31-testimonial-grid {
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:22px;
}
.sbap-v31-testimonial {
    padding:28px;
}
.sbap-v31-testimonial .stars {
    color:#d99a00;
    letter-spacing:2px;
    margin-bottom:14px;
}
.sbap-v31-testimonial p {
    color:#405a4f;
    font-size:17px;
    line-height:1.7;
}
.sbap-v31-testimonial h3 {
    color:var(--sbap-dark);
    margin:18px 0 4px;
}
.sbap-v31-testimonial span {
    color:var(--sbap-accent);
    font-weight:800;
}
.sbap-v31-student-hero-card {
    padding:30px;
    display:flex;
    justify-content:space-between;
    gap:20px;
    align-items:center;
    color:#fff;
    background:linear-gradient(135deg,var(--sbap-dark),#0f6845);
    margin-bottom:22px;
}
.sbap-v31-student-hero-card h2 {
    color:#fff;
    margin:12px 0 6px;
    font-size:clamp(32px,4vw,54px);
}
.sbap-v31-student-hero-card span {
    display:inline-flex;
    padding:7px 13px;
    border-radius:999px;
    background:rgba(255,255,255,.14);
    font-size:12px;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.sbap-v31-student-hero-card p {
    color:rgba(255,255,255,.9);
    margin:0;
}
.sbap-v31-progress-grid {
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:18px;
    margin-bottom:22px;
}
.sbap-v31-progress-grid > div {
    padding:24px;
    text-align:center;
}
.sbap-v31-progress-grid strong {
    display:block;
    color:var(--sbap-accent);
    font-size:clamp(26px,3vw,40px);
    margin-bottom:7px;
}
.sbap-v31-progress-grid span {
    color:#405a4f;
    font-weight:800;
}
.sbap-v31-action-grid {
    display:grid;
    grid-template-columns:repeat(6,minmax(0,1fr));
    gap:14px;
    margin-bottom:30px;
}
.sbap-v31-action-grid a {
    min-height:112px;
    display:grid;
    place-items:center;
    text-align:center;
    color:var(--sbap-dark);
    padding:18px 12px;
    font-size:26px;
}
.sbap-v31-action-grid strong {
    display:block;
    font-size:15px;
    margin-top:8px;
}
.sbap-v31-action-grid span {
    display:block;
    color:#52675e;
    font-size:12px;
    font-weight:700;
}
.sbap-v31-sticky-cta {
    position:fixed;
    left:50%;
    bottom:18px;
    transform:translateX(-50%);
    z-index:99999;
    display:flex;
    gap:8px;
    padding:10px;
    border-radius:999px;
    background:rgba(15,47,36,.92);
    backdrop-filter:blur(12px);
    box-shadow:0 18px 50px rgba(0,0,0,.24);
}
.sbap-v31-sticky-cta a {
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:10px 16px;
    border-radius:999px;
    background:rgba(255,255,255,.12);
    color:#fff !important;
    font-weight:900;
    white-space:nowrap;
}
.sbap-v31-sticky-cta a:first-child {
    background:var(--sbap-accent);
}
@media(max-width:1100px){
    .sbap-v31-home-feature-grid,
    .sbap-v31-pricing-grid,
    .sbap-v31-testimonial-grid,
    .sbap-v31-action-grid {
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
    .sbap-v31-progress-grid {
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}
@media(max-width:820px){
    .sbap-v31-split-hero,
    .sbap-v31-demo-layout {
        grid-template-columns:1fr;
    }
    .sbap-v31-student-hero-card {
        flex-direction:column;
        align-items:flex-start;
    }
}
@media(max-width:620px){
    .sbap-v31-home-feature-grid,
    .sbap-v31-pricing-grid,
    .sbap-v31-testimonial-grid,
    .sbap-v31-progress-grid,
    .sbap-v31-action-grid {
        grid-template-columns:1fr;
    }
    .sbap-v31-sticky-cta {
        width:calc(100% - 20px);
        border-radius:22px;
        justify-content:center;
        overflow-x:auto;
    }
    .sbap-v31-sticky-cta a {
        font-size:13px;
        padding:9px 12px;
    }
}

/* v3.2 Enterprise LMS UI */
.sbap-v32-page .sbap-section {
    background: linear-gradient(180deg, #f7fffa, #ffffff);
}
.sbap-v32-hero {
    min-height: 430px;
    display: flex;
    align-items: center;
    padding: 75px max(24px, calc((100vw - 1220px)/2));
    color: #fff;
    background-size: cover;
    background-position: center;
    background-image: linear-gradient(90deg, rgba(4,18,15,.82), rgba(8,31,24,.60), rgba(10,39,30,.36)), url("../images/home-banner.png");
}
.sbap-v32-live-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.82), rgba(8,31,24,.60), rgba(10,39,30,.36)), url("../images/courses-banner.png"); }
.sbap-v32-attendance-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.82), rgba(8,31,24,.60), rgba(10,39,30,.36)), url("../images/portal-banner.png"); }
.sbap-v32-submit-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.82), rgba(8,31,24,.60), rgba(10,39,30,.36)), url("../images/materials-banner.png"); }
.sbap-v32-parent-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.82), rgba(8,31,24,.60), rgba(10,39,30,.36)), url("../images/contact-banner.png"); }
.sbap-v32-cert-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.82), rgba(8,31,24,.60), rgba(10,39,30,.36)), url("../images/syllabus-banner.png"); }
.sbap-v32-leader-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.82), rgba(8,31,24,.60), rgba(10,39,30,.36)), url("../images/tests-banner.png"); }
.sbap-v32-ai-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.82), rgba(8,31,24,.60), rgba(10,39,30,.36)), url("../images/blogs-banner.png"); }
.sbap-v32-premium-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.82), rgba(8,31,24,.60), rgba(10,39,30,.36)), url("../images/home-banner.png"); }
.sbap-v32-hero > div {
    max-width: 850px;
}
.sbap-v32-hero span {
    display: inline-flex;
    padding: 7px 13px;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.sbap-v32-hero h1 {
    color: #fff;
    margin: 16px 0;
    font-size: clamp(42px, 5vw, 72px);
    line-height: 1.04;
    text-shadow: 0 4px 24px rgba(0,0,0,.42);
}
.sbap-v32-hero p {
    color: rgba(255,255,255,.96);
    font-size: 20px;
    line-height: 1.65;
    text-shadow: 0 3px 18px rgba(0,0,0,.38);
}
.sbap-v32-tool-panel,
.sbap-v32-live-card,
.sbap-v32-form,
.sbap-v32-parent-card,
.sbap-v32-certificate,
.sbap-v32-table-wrap,
.sbap-v32-stat-grid > div {
    background: #fff;
    border: 1px solid rgba(27,143,90,.13);
    border-radius: 28px;
    box-shadow: 0 18px 50px rgba(15,47,36,.10);
}
.sbap-v32-tool-panel,
.sbap-v32-form,
.sbap-v32-parent-card {
    padding: 30px;
    margin-bottom: 22px;
}
.sbap-v32-tool-panel h2,
.sbap-v32-parent-card h2,
.sbap-v32-subtitle {
    color: var(--sbap-dark);
    margin: 0 0 10px;
    font-size: clamp(28px, 3vw, 44px);
    line-height: 1.1;
}
.sbap-v32-tool-panel p,
.sbap-v32-parent-card p {
    color: #52675e;
    line-height: 1.7;
}
.sbap-v32-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}
.sbap-v32-live-card {
    padding: 26px;
    position: relative;
    overflow: hidden;
}
.sbap-v32-live-card h3 {
    color: var(--sbap-dark);
    margin: 14px 0 10px;
    font-size: 25px;
    line-height: 1.17;
}
.sbap-v32-live-card p {
    color: #52675e;
    line-height: 1.65;
}
.sbap-v32-status {
    display: inline-flex;
    padding: 7px 12px;
    border-radius: 999px;
    background: var(--sbap-soft);
    color: var(--sbap-accent);
    font-weight: 900;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.sbap-v32-status.live {
    background: #dc2626;
    color: #fff;
}
.sbap-v32-status.completed {
    background: #1f2937;
    color: #fff;
}
.sbap-v32-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 16px 0 18px;
}
.sbap-v32-meta span {
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(27,143,90,.09);
    color: var(--sbap-dark);
    font-size: 12px;
    font-weight: 800;
}
.sbap-v32-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.sbap-v32-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    margin: 0 0 24px;
}
.sbap-v32-stat-grid > div {
    padding: 24px;
    text-align: center;
}
.sbap-v32-stat-grid strong {
    display: block;
    font-size: clamp(30px, 4vw, 50px);
    color: var(--sbap-accent);
    line-height: 1.1;
    margin-bottom: 6px;
}
.sbap-v32-stat-grid span {
    color: #405a4f;
    font-weight: 800;
}
.sbap-v32-table-wrap {
    overflow-x: auto;
}
.sbap-v32-table-wrap table {
    width: 100%;
    border-collapse: collapse;
    min-width: 760px;
}
.sbap-v32-table-wrap th,
.sbap-v32-table-wrap td {
    padding: 15px 16px;
    border-bottom: 1px solid rgba(27,143,90,.12);
    text-align: left;
}
.sbap-v32-table-wrap th {
    background: var(--sbap-soft);
    color: var(--sbap-dark);
    font-weight: 900;
}
.sbap-v32-badge {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    background: var(--sbap-soft);
    color: var(--sbap-accent);
    font-weight: 900;
    font-size: 12px;
}
.sbap-v32-badge.absent {
    background: #fee2e2;
    color: #b91c1c;
}
.sbap-v32-badge.late {
    background: #fef3c7;
    color: #92400e;
}
.sbap-v32-form input,
.sbap-v32-form select,
.sbap-v32-form textarea {
    width: 100%;
    min-height: 46px;
    border-radius: 14px;
    border: 1px solid rgba(27,143,90,.24);
    background: #fbfffc;
    padding: 11px 13px;
}
.sbap-v32-certificate-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}
.sbap-v32-certificate {
    padding: 38px;
    text-align: center;
    background:
        radial-gradient(circle at 10% 10%, rgba(27,143,90,.10), transparent 30%),
        #fff;
    border: 2px solid rgba(27,143,90,.18);
}
.sbap-v32-seal {
    width: 78px;
    height: 78px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--sbap-accent), var(--sbap-dark));
    color: #fff;
    font-size: 36px;
    margin-bottom: 18px;
}
.sbap-v32-certificate h3 {
    color: var(--sbap-dark);
    font-size: 30px;
    margin: 0 0 12px;
}
.sbap-v32-certificate p {
    color: #405a4f;
    font-size: 18px;
}
.sbap-v32-side-rail {
    position: fixed;
    top: 50%;
    right: 14px;
    transform: translateY(-50%);
    z-index: 99990;
    display: grid;
    gap: 8px;
}
.sbap-v32-side-rail a {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    padding: 12px 9px;
    border-radius: 999px;
    background: rgba(15,47,36,.92);
    color: #fff !important;
    font-weight: 900;
    font-size: 12px;
    box-shadow: 0 12px 30px rgba(0,0,0,.18);
}
@media print {
    body * { visibility: hidden !important; }
    .sbap-v32-certificate,
    .sbap-v32-certificate * { visibility: visible !important; }
    .sbap-v32-certificate { position: absolute; left: 0; top: 0; width: 100%; box-shadow: none; }
    .sbap-v32-side-rail,
    .sbap-v31-sticky-cta,
    .sbap-float-wa { display: none !important; }
}
@media (max-width: 1000px) {
    .sbap-v32-card-grid,
    .sbap-v32-certificate-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .sbap-v32-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .sbap-v32-side-rail {
        display: none;
    }
}
@media (max-width: 620px) {
    .sbap-v32-card-grid,
    .sbap-v32-certificate-grid,
    .sbap-v32-stat-grid {
        grid-template-columns: 1fr;
    }
}

/* v3.3 Ultra Pro UI */
.sbap-v33-page .sbap-section {
    background: linear-gradient(180deg, #f7fffa, #ffffff);
}
.sbap-v33-hero {
    min-height: 430px;
    display: flex;
    align-items: center;
    padding: 75px max(24px, calc((100vw - 1220px)/2));
    color: #fff;
    background-size: cover;
    background-position: center;
    background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/home-banner.png");
}
.sbap-v33-payment-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/contact-banner.png"); }
.sbap-v33-analytics-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/tests-banner.png"); }
.sbap-v33-certverify-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/syllabus-banner.png"); }
.sbap-v33-path-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/materials-banner.png"); }
.sbap-v33-review-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/portal-banner.png"); }
.sbap-v33-hero > div {
    max-width: 850px;
}
.sbap-v33-hero span {
    display: inline-flex;
    padding: 7px 13px;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.sbap-v33-hero h1 {
    color: #fff;
    margin: 16px 0;
    font-size: clamp(42px, 5vw, 72px);
    line-height: 1.04;
    text-shadow: 0 4px 24px rgba(0,0,0,.42);
}
.sbap-v33-hero p {
    color: rgba(255,255,255,.96);
    font-size: 20px;
    line-height: 1.65;
    text-shadow: 0 3px 18px rgba(0,0,0,.38);
}
.sbap-v33-panel,
.sbap-v33-form,
.sbap-v33-payment-card,
.sbap-v33-receipt,
.sbap-v33-verify-result,
.sbap-v33-path article,
.sbap-v33-review-card,
.sbap-v33-table,
.sbap-v33-analytics-head,
.sbap-v33-stat-grid > div {
    background: #fff;
    border: 1px solid rgba(27,143,90,.13);
    border-radius: 28px;
    box-shadow: 0 18px 50px rgba(15,47,36,.10);
}
.sbap-v33-panel,
.sbap-v33-form,
.sbap-v33-payment-card,
.sbap-v33-analytics-head {
    padding: 30px;
    margin-bottom: 22px;
}
.sbap-v33-payment-layout {
    display: grid;
    grid-template-columns: .8fr 1.2fr;
    gap: 24px;
    align-items: start;
}
.sbap-v33-payment-card span,
.sbap-v33-analytics-head span {
    display: inline-flex;
    padding: 7px 12px;
    border-radius: 999px;
    background: var(--sbap-soft);
    color: var(--sbap-accent);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.sbap-v33-payment-card h2,
.sbap-v33-analytics-head h2,
.sbap-v33-panel h2 {
    color: var(--sbap-dark);
    margin: 14px 0 10px;
    font-size: clamp(28px, 3vw, 44px);
    line-height: 1.1;
}
.sbap-v33-payment-card p,
.sbap-v33-analytics-head p,
.sbap-v33-panel p {
    color: #52675e;
    line-height: 1.7;
}
.sbap-v33-upi-box {
    display: grid;
    gap: 10px;
    padding: 18px;
    border-radius: 22px;
    background: var(--sbap-soft);
    margin: 18px 0;
}
.sbap-v33-upi-box code {
    padding: 10px 12px;
    border-radius: 12px;
    background: #fff;
    color: var(--sbap-dark);
    font-weight: 900;
}
.sbap-v33-qr,
.sbap-v33-qr-placeholder {
    width: 220px;
    max-width: 100%;
    aspect-ratio: 1;
    border-radius: 24px;
    border: 1px solid rgba(27,143,90,.18);
    display: grid;
    place-items: center;
    background: #fff;
    margin-top: 18px;
}
.sbap-v33-qr-placeholder span {
    font-size: 54px;
    color: var(--sbap-accent);
}
.sbap-v33-qr-placeholder small {
    display: block;
    color: #52675e;
    font-weight: 700;
    text-align: center;
    padding: 0 20px;
}
.sbap-v33-form input,
.sbap-v33-form select,
.sbap-v33-form textarea,
.sbap-v33-verify-form input,
.sbap-v33-filter select {
    width: 100%;
    min-height: 46px;
    border-radius: 14px;
    border: 1px solid rgba(27,143,90,.24);
    background: #fbfffc;
    padding: 11px 13px;
}
.sbap-v33-section-title h2 {
    color: var(--sbap-dark);
    font-size: clamp(28px, 3vw, 42px);
}
.sbap-v33-receipt-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}
.sbap-v33-receipt {
    padding: 24px;
}
.sbap-v33-receipt > div {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}
.sbap-v33-receipt strong {
    color: var(--sbap-dark);
}
.sbap-v33-status {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    background: #fef3c7;
    color: #92400e;
    font-size: 12px;
    font-weight: 900;
}
.sbap-v33-status.paid {
    background: var(--sbap-soft);
    color: var(--sbap-accent);
}
.sbap-v33-status.rejected {
    background: #fee2e2;
    color: #b91c1c;
}
.sbap-v33-receipt h3 {
    color: var(--sbap-accent);
    font-size: 30px;
    margin: 20px 0 6px;
}
.sbap-v33-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}
.sbap-v33-stat-grid > div {
    padding: 24px;
    text-align: center;
}
.sbap-v33-stat-grid strong {
    display: block;
    color: var(--sbap-accent);
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1.1;
}
.sbap-v33-stat-grid span {
    color: #405a4f;
    font-weight: 800;
}
.sbap-v33-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
}
.sbap-v33-weak-list {
    display: grid;
    gap: 14px;
}
.sbap-v33-weak-list div {
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    background: var(--sbap-soft);
    padding: 16px;
}
.sbap-v33-weak-list div em {
    position: absolute;
    left: 0;
    bottom: 0;
    height: 5px;
    background: var(--sbap-accent);
}
.sbap-v33-weak-list span,
.sbap-v33-weak-list strong {
    position: relative;
    z-index: 2;
}
.sbap-v33-weak-list strong {
    float: right;
    color: var(--sbap-dark);
}
.sbap-v33-checks {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 12px;
}
.sbap-v33-checks li {
    position: relative;
    padding-left: 30px;
    color: #405a4f;
    font-weight: 700;
}
.sbap-v33-checks li:before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--sbap-accent);
    font-weight: 900;
}
.sbap-v33-table {
    overflow-x: auto;
}
.sbap-v33-table table {
    width: 100%;
    min-width: 760px;
    border-collapse: collapse;
}
.sbap-v33-table th,
.sbap-v33-table td {
    padding: 15px 16px;
    border-bottom: 1px solid rgba(27,143,90,.12);
    text-align: left;
}
.sbap-v33-table th {
    background: var(--sbap-soft);
    color: var(--sbap-dark);
    font-weight: 900;
}
.sbap-v33-verify-form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 14px;
    align-items: end;
    padding: 22px;
    border-radius: 26px;
    background: #fff;
    border: 1px solid rgba(27,143,90,.13);
    box-shadow: 0 14px 42px rgba(15,47,36,.08);
    margin-bottom: 24px;
}
.sbap-v33-verify-result {
    padding: 34px;
    text-align: center;
}
.sbap-v33-verify-result .seal {
    width: 76px;
    height: 76px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--sbap-accent);
    color: #fff;
    font-size: 40px;
    font-weight: 900;
    margin-bottom: 14px;
}
.sbap-v33-verify-result.invalid .seal {
    background: #b91c1c;
}
.sbap-v33-path {
    display: grid;
    gap: 18px;
}
.sbap-v33-path article {
    display: grid;
    grid-template-columns: 74px 1fr;
    gap: 18px;
    padding: 24px;
}
.sbap-v33-path .num {
    width: 74px;
    height: 74px;
    border-radius: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--sbap-dark);
    color: #fff;
    font-size: 28px;
    font-weight: 900;
}
.sbap-v33-path h3 {
    color: var(--sbap-dark);
    margin: 0 0 10px;
    font-size: 26px;
}
.sbap-v33-path p {
    color: #52675e;
    line-height: 1.65;
}
.sbap-v33-path .actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.sbap-v33-filter {
    display: grid;
    grid-template-columns: 220px auto;
    gap: 12px;
    margin-bottom: 22px;
    justify-content: start;
}
.sbap-v33-review-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
    margin-bottom: 24px;
}
.sbap-v33-review-card {
    padding: 28px;
    text-align: center;
    color: var(--sbap-dark);
}
.sbap-v33-review-card span {
    display: block;
    font-size: 42px;
    margin-bottom: 12px;
}
.sbap-v33-review-card strong {
    display: block;
    color: var(--sbap-accent);
    font-size: 42px;
    line-height: 1;
    margin-bottom: 8px;
}
.sbap-v33-review-card em {
    font-style: normal;
    font-weight: 900;
}
.sbap-v33-ultra-dock {
    position: fixed;
    left: 50%;
    bottom: 82px;
    transform: translateX(-50%);
    z-index: 99998;
    display: flex;
    gap: 8px;
    padding: 10px;
    border-radius: 999px;
    background: rgba(15,47,36,.92);
    box-shadow: 0 18px 50px rgba(0,0,0,.22);
    backdrop-filter: blur(12px);
}
.sbap-v33-ultra-dock a {
    color: #fff !important;
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    font-weight: 900;
    white-space: nowrap;
}
.sbap-v33-ultra-dock a:first-child {
    background: var(--sbap-accent);
}
@media print {
    .sbap-v33-ultra-dock,
    .sbap-v32-side-rail,
    .sbap-v31-sticky-cta,
    .sbap-float-wa {
        display: none !important;
    }
    .sbap-v33-receipt {
        box-shadow: none !important;
        border: 2px solid #222 !important;
    }
}
@media (max-width: 1024px) {
    .sbap-v33-payment-layout,
    .sbap-v33-two-col {
        grid-template-columns: 1fr;
    }
    .sbap-v33-receipt-grid,
    .sbap-v33-review-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .sbap-v33-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 680px) {
    .sbap-v33-receipt-grid,
    .sbap-v33-review-grid,
    .sbap-v33-stat-grid,
    .sbap-v33-verify-form,
    .sbap-v33-filter,
    .sbap-v33-path article {
        grid-template-columns: 1fr;
    }
    .sbap-v33-ultra-dock {
        display: none;
    }
}

/* v3.4 Premium Automation / App-Like LMS UI */
.sbap-v34-page .sbap-section {
    background: linear-gradient(180deg, #f6fffa, #ffffff);
}
.sbap-v34-hero {
    min-height: 430px;
    display: flex;
    align-items: center;
    padding: 75px max(24px, calc((100vw - 1220px)/2));
    color: #fff;
    background-size: cover;
    background-position: center;
    background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/home-banner.png");
}
.sbap-v34-app-hero-bg { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/portal-banner.png"); }
.sbap-v34-generate-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/tests-banner.png"); }
.sbap-v34-result-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/tests-banner.png"); }
.sbap-v34-premium-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/materials-banner.png"); }
.sbap-v34-parent-hero { background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.36)), url("../images/contact-banner.png"); }
.sbap-v34-hero > div {
    max-width: 850px;
}
.sbap-v34-hero span {
    display: inline-flex;
    padding: 7px 13px;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.sbap-v34-hero h1 {
    color: #fff;
    margin: 16px 0;
    font-size: clamp(42px, 5vw, 72px);
    line-height: 1.04;
    text-shadow: 0 4px 24px rgba(0,0,0,.42);
}
.sbap-v34-hero p {
    color: rgba(255,255,255,.96);
    font-size: 20px;
    line-height: 1.65;
    text-shadow: 0 3px 18px rgba(0,0,0,.38);
}
.sbap-v34-app-shell,
.sbap-v34-form,
.sbap-v34-login-card,
.sbap-v34-lock-card,
.sbap-v34-premium-locked,
.sbap-v34-premium-open,
.sbap-v34-parent-head,
.sbap-v34-continue-panel,
.sbap-v34-result-card,
.sbap-v34-class-showcase .sbap-container {
    background: #fff;
    border: 1px solid rgba(27,143,90,.13);
    border-radius: 32px;
    box-shadow: 0 20px 60px rgba(15,47,36,.11);
}
.sbap-v34-app-shell {
    padding: clamp(20px, 4vw, 34px);
}
.sbap-v34-app-hero {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    padding: 30px;
    border-radius: 30px;
    background: linear-gradient(135deg, var(--sbap-dark), #0f6845);
    color: #fff;
    margin-bottom: 20px;
}
.sbap-v34-app-hero span {
    display: inline-flex;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.sbap-v34-app-hero h2 {
    color: #fff;
    margin: 12px 0 6px;
    font-size: clamp(32px, 4vw, 54px);
    line-height: 1.05;
}
.sbap-v34-app-hero p {
    color: rgba(255,255,255,.9);
    margin: 0;
}
.sbap-v34-mini-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 14px;
    margin: 0 0 20px;
}
.sbap-v34-mini-stats > div {
    padding: 20px;
    border-radius: 24px;
    background: var(--sbap-soft);
    text-align: center;
    border: 1px solid rgba(27,143,90,.12);
}
.sbap-v34-mini-stats strong {
    display: block;
    color: var(--sbap-accent);
    font-size: clamp(26px, 3vw, 42px);
    line-height: 1;
    margin-bottom: 6px;
}
.sbap-v34-mini-stats span {
    color: var(--sbap-dark);
    font-weight: 800;
}
.sbap-v34-app-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 14px;
    margin-bottom: 20px;
}
.sbap-v34-app-grid a {
    min-height: 112px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 18px 10px;
    border-radius: 26px;
    background: #fff;
    border: 1px solid rgba(27,143,90,.13);
    box-shadow: 0 14px 38px rgba(15,47,36,.08);
    color: var(--sbap-dark);
    font-weight: 900;
}
.sbap-v34-app-grid span {
    font-size: 34px;
}
.sbap-v34-app-grid strong {
    display: block;
    margin-top: 8px;
}
.sbap-v34-continue-panel,
.sbap-v34-parent-head,
.sbap-v34-form,
.sbap-v34-lock-card,
.sbap-v34-login-card,
.sbap-v34-premium-locked,
.sbap-v34-premium-open {
    padding: 30px;
    margin-bottom: 22px;
}
.sbap-v34-continue-panel h3,
.sbap-v34-parent-head h2,
.sbap-v34-form h2,
.sbap-v34-lock-card h2,
.sbap-v34-login-card h2,
.sbap-v34-premium-locked h2,
.sbap-v34-premium-open h2 {
    color: var(--sbap-dark);
    font-size: clamp(28px, 3vw, 44px);
    margin: 0 0 10px;
    line-height: 1.1;
}
.sbap-v34-continue-panel li {
    margin: 8px 0;
    color: #405a4f;
    font-weight: 700;
}
.sbap-v34-form input,
.sbap-v34-form select,
.sbap-v34-form textarea {
    width: 100%;
    min-height: 46px;
    border-radius: 14px;
    border: 1px solid rgba(27,143,90,.24);
    background: #fbfffc;
    padding: 11px 13px;
}
.sbap-v34-result-card {
    padding: clamp(24px, 4vw, 42px);
}
.sbap-v34-result-head {
    text-align: center;
}
.sbap-v34-result-head span {
    display: inline-flex;
    padding: 7px 12px;
    border-radius: 999px;
    background: var(--sbap-soft);
    color: var(--sbap-accent);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.sbap-v34-result-head h2 {
    color: var(--sbap-dark);
    margin: 14px 0 8px;
    font-size: clamp(28px, 3vw, 48px);
}
.sbap-v34-result-score {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    margin: 26px auto;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--sbap-accent), var(--sbap-dark));
    color: #fff;
    text-align: center;
}
.sbap-v34-result-score strong {
    display: block;
    font-size: 42px;
    line-height: 1;
}
.sbap-v34-result-score span {
    font-weight: 900;
}
.sbap-v34-result-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 14px;
    margin-bottom: 22px;
}
.sbap-v34-result-grid > div {
    padding: 18px;
    border-radius: 22px;
    background: var(--sbap-soft);
    text-align: center;
}
.sbap-v34-result-grid strong {
    display: block;
    color: var(--sbap-accent);
    font-size: 34px;
    margin-bottom: 4px;
}
.sbap-v34-result-advice {
    border-radius: 24px;
    padding: 24px;
    background: #f7fffa;
    margin-bottom: 20px;
}
.sbap-v34-result-details {
    margin: 20px 0;
}
.sbap-v34-result-details summary {
    cursor: pointer;
    font-weight: 900;
    color: var(--sbap-dark);
    padding: 16px;
    border-radius: 18px;
    background: var(--sbap-soft);
}
.sbap-v34-result-details article {
    padding: 18px;
    border-radius: 18px;
    margin: 12px 0;
    background: #fff;
    border: 1px solid rgba(27,143,90,.12);
}
.sbap-v34-result-details article.correct { border-left: 6px solid #16a34a; }
.sbap-v34-result-details article.wrong { border-left: 6px solid #dc2626; }
.sbap-v34-result-details article.unattempted { border-left: 6px solid #ca8a04; }
.sbap-v34-premium-locked,
.sbap-v34-premium-open {
    text-align: center;
}
.sbap-v34-premium-locked .lock {
    font-size: 60px;
    margin-bottom: 12px;
}
.sbap-v34-class-showcase {
    background: linear-gradient(180deg, #ffffff, #f7fffa);
}
.sbap-v34-class-showcase .sbap-container {
    padding: clamp(28px, 5vw, 54px);
}
.sbap-v34-section-head {
    max-width: 850px;
    margin-bottom: 26px;
}
.sbap-v34-section-head span {
    display: inline-flex;
    padding: 7px 12px;
    border-radius: 999px;
    background: var(--sbap-soft);
    color: var(--sbap-accent);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.sbap-v34-section-head h2 {
    color: var(--sbap-dark);
    font-size: clamp(32px, 4vw, 58px);
    line-height: 1.06;
    margin: 14px 0;
}
.sbap-v34-section-head p {
    color: #52675e;
    font-size: 18px;
    line-height: 1.7;
}
.sbap-v34-class-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 16px;
}
.sbap-v34-class-grid a {
    display: grid;
    gap: 8px;
    padding: 24px;
    border-radius: 26px;
    background: var(--sbap-soft);
    border: 1px solid rgba(27,143,90,.13);
    color: var(--sbap-dark);
}
.sbap-v34-class-grid strong {
    font-size: 42px;
    color: var(--sbap-accent);
}
.sbap-v34-class-grid span {
    font-weight: 900;
}
.sbap-v34-class-grid em {
    font-style: normal;
    color: var(--sbap-accent);
    font-weight: 900;
}
.sbap-v34-parent-head p {
    color: #52675e;
}
.sbap-v34-mobile-nav {
    display: none;
}
@media print {
    .sbap-v34-mobile-nav,
    .sbap-v33-ultra-dock,
    .sbap-v32-side-rail,
    .sbap-v31-sticky-cta,
    .sbap-float-wa {
        display: none !important;
    }
    .sbap-v34-result-card {
        box-shadow: none !important;
        border: 2px solid #222 !important;
    }
}
@media (max-width: 1024px) {
    .sbap-v34-app-grid,
    .sbap-v34-class-grid,
    .sbap-v34-mini-stats,
    .sbap-v34-result-grid {
        grid-template-columns: repeat(2, minmax(0,1fr));
    }
    .sbap-v34-app-hero {
        flex-direction: column;
        align-items: flex-start;
    }
}
@media (max-width: 760px) {
    .sbap-v34-mobile-nav {
        position: fixed;
        left: 10px;
        right: 10px;
        bottom: 10px;
        z-index: 999999;
        display: grid;
        grid-template-columns: repeat(5, 1fr);
        gap: 4px;
        padding: 8px;
        border-radius: 22px;
        background: rgba(15,47,36,.94);
        box-shadow: 0 18px 50px rgba(0,0,0,.25);
        backdrop-filter: blur(12px);
    }
    .sbap-v34-mobile-nav a {
        display: grid;
        place-items: center;
        color: #fff !important;
        font-size: 10px;
        font-weight: 900;
        gap: 2px;
    }
    .sbap-v34-mobile-nav span {
        font-size: 18px;
    }
    .sbap-v34-app-grid,
    .sbap-v34-class-grid,
    .sbap-v34-mini-stats,
    .sbap-v34-result-grid {
        grid-template-columns: 1fr;
    }
    .sbap-v34-result-score {
        width: 150px;
        height: 150px;
    }
}

/* v3.4.1 Professional UI Fix */
body.sbap-professional-ui {
    background: #f6fffa;
}
body.sbap-professional-ui .entry-title,
body.sbap-professional-ui .page-title {
    display: none !important;
}
body.sbap-professional-ui .site-main,
body.sbap-professional-ui article,
body.sbap-professional-ui .entry-content {
    margin: 0 !important;
    padding: 0 !important;
}
body.sbap-professional-ui .sbap-page,
body.sbap-professional-ui .sbap-v31-page,
body.sbap-professional-ui .sbap-v32-page,
body.sbap-professional-ui .sbap-v33-page,
body.sbap-professional-ui .sbap-v34-page {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    overflow-x: hidden;
}
body.sbap-professional-ui .sbap-container {
    width: min(1220px, calc(100% - 40px));
    max-width: 1220px;
    margin-left: auto;
    margin-right: auto;
}
body.sbap-professional-ui .sbap-hero,
body.sbap-professional-ui .sbap-page-head,
body.sbap-professional-ui .sbap-v31-page-hero,
body.sbap-professional-ui .sbap-v32-hero,
body.sbap-professional-ui .sbap-v33-hero,
body.sbap-professional-ui .sbap-v34-hero {
    min-height: 520px;
    background-size: cover !important;
    background-position: center !important;
    display: flex;
    align-items: center;
}
body.sbap-professional-ui .sbap-section {
    padding: clamp(54px, 7vw, 96px) 0;
}
body.sbap-professional-ui .sbap-btn,
body.sbap-professional-ui button.sbap-btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 46px;
    border-radius: 999px !important;
    padding: 12px 20px !important;
    font-weight: 900 !important;
    text-decoration: none !important;
    line-height: 1.1 !important;
}
.sbap-v341-home-polish {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: clamp(60px, 8vw, 110px) 0;
    background:
        radial-gradient(circle at 12% 10%, rgba(27,143,90,.13), transparent 34%),
        radial-gradient(circle at 88% 0%, rgba(15,47,36,.11), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #f6fffa 100%);
}
.sbap-v341-polish-head {
    max-width: 920px;
    margin-bottom: 30px;
}
.sbap-v341-polish-head > span {
    display: inline-flex;
    padding: 8px 14px;
    border-radius: 999px;
    background: var(--sbap-soft);
    color: var(--sbap-accent);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.sbap-v341-polish-head h2 {
    margin: 16px 0 14px;
    color: var(--sbap-dark);
    font-size: clamp(36px, 4.6vw, 66px);
    line-height: 1.04;
    letter-spacing: -.04em;
}
.sbap-v341-polish-head p {
    color: #52675e;
    font-size: 19px;
    line-height: 1.72;
    margin: 0 0 22px;
}
.sbap-v341-class-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    margin: 28px 0;
}
.sbap-v341-class-card {
    display: grid !important;
    gap: 8px;
    min-height: 178px;
    padding: 26px;
    border-radius: 30px;
    background: #fff;
    border: 1px solid rgba(27,143,90,.14);
    box-shadow: 0 18px 46px rgba(15,47,36,.10);
    text-decoration: none !important;
    color: var(--sbap-dark) !important;
    transition: transform .2s ease, box-shadow .2s ease;
}
.sbap-v341-class-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 26px 70px rgba(15,47,36,.16);
}
.sbap-v341-class-card strong {
    font-size: clamp(42px, 4vw, 58px);
    line-height: 1;
    color: var(--sbap-accent);
    font-weight: 950;
}
.sbap-v341-class-card span {
    color: var(--sbap-dark);
    font-size: 18px;
    font-weight: 900;
    line-height: 1.25;
}
.sbap-v341-class-card em {
    font-style: normal;
    color: var(--sbap-accent);
    font-weight: 900;
}
.sbap-v341-feature-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}
.sbap-v341-feature-grid a {
    display: grid;
    gap: 8px;
    padding: 24px;
    border-radius: 28px;
    background: linear-gradient(180deg, #ffffff, #f9fffb);
    border: 1px solid rgba(27,143,90,.14);
    box-shadow: 0 16px 42px rgba(15,47,36,.08);
    text-decoration: none !important;
    color: var(--sbap-dark) !important;
}
.sbap-v341-feature-grid b {
    font-size: 34px;
}
.sbap-v341-feature-grid strong {
    font-size: 19px;
    font-weight: 900;
    color: var(--sbap-dark);
}
.sbap-v341-feature-grid span {
    color: #52675e;
    font-weight: 700;
}
.sbap-v341-footer {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    background: var(--sbap-dark);
    color: #fff;
    padding: 34px 0;
}
.sbap-v341-footer .sbap-container {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    align-items: center;
}
.sbap-v341-footer strong {
    display: block;
    color: #fff;
    font-size: 24px;
    margin-bottom: 6px;
}
.sbap-v341-footer p {
    margin: 0;
    color: rgba(255,255,255,.76);
    max-width: 620px;
    line-height: 1.6;
}
.sbap-v341-footer nav {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}
.sbap-v341-footer a {
    display: inline-flex;
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.10);
    color: #fff !important;
    text-decoration: none !important;
    font-weight: 800;
}
body.sbap-professional-ui .sbap-v34-mobile-nav {
    box-sizing: border-box;
}
@media (max-width: 980px) {
    .sbap-v341-class-grid,
    .sbap-v341-feature-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .sbap-v341-footer .sbap-container {
        align-items: flex-start;
        flex-direction: column;
    }
    .sbap-v341-footer nav {
        justify-content: flex-start;
    }
}
@media (max-width: 640px) {
    body.sbap-professional-ui .sbap-container {
        width: min(100% - 24px, 1220px);
    }
    .sbap-v341-class-grid,
    .sbap-v341-feature-grid {
        grid-template-columns: 1fr;
    }
    .sbap-v341-class-card {
        min-height: auto;
    }
}


/* v3.4.2 Hero readability fix */
body.sbap-professional-ui .sbap-hero.sbap-hero-readable,
.sbap-page .sbap-hero.sbap-hero-readable {
    position: relative !important;
    background-color: #07150f !important;
    isolation: isolate;
}
body.sbap-professional-ui .sbap-hero.sbap-hero-readable::before,
.sbap-page .sbap-hero.sbap-hero-readable::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    border-radius: 0 !important;
    width: auto !important;
    height: auto !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: linear-gradient(90deg, rgba(0,0,0,.64) 0%, rgba(0,0,0,.50) 45%, rgba(0,0,0,.24) 100%) !important;
    filter: none !important;
    pointer-events: none;
}
body.sbap-professional-ui .sbap-hero.sbap-hero-readable::after,
.sbap-page .sbap-hero.sbap-hero-readable::after {
    content: "" !important;
    position: absolute !important;
    z-index: 0 !important;
    inset: auto -120px -170px auto !important;
    width: 460px !important;
    height: 460px !important;
    border-radius: 999px !important;
    background: rgba(27,143,90,.22) !important;
    filter: blur(10px) !important;
    pointer-events: none;
}
body.sbap-professional-ui .sbap-hero-readable .sbap-hero-inner,
.sbap-page .sbap-hero-readable .sbap-hero-inner {
    position: relative !important;
    z-index: 2 !important;
}
body.sbap-professional-ui .sbap-hero-copy-readable,
.sbap-page .sbap-hero-copy-readable {
    max-width: 900px;
    padding: clamp(18px, 3vw, 34px);
    border-radius: 34px;
    background: linear-gradient(135deg, rgba(2,12,9,.52), rgba(2,12,9,.18));
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(2px);
}
body.sbap-professional-ui .sbap-hero .sbap-home-hero-title,
body.sbap-professional-ui .entry-content .sbap-hero .sbap-home-hero-title,
.sbap-page .sbap-hero .sbap-home-hero-title,
.sbap-page .sbap-hero h1.sbap-home-hero-title {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-shadow: 0 6px 30px rgba(0,0,0,.95), 0 1px 2px rgba(0,0,0,1) !important;
    opacity: 1 !important;
    mix-blend-mode: normal !important;
}
body.sbap-professional-ui .sbap-hero .sbap-home-hero-subtitle,
body.sbap-professional-ui .entry-content .sbap-hero .sbap-home-hero-subtitle,
.sbap-page .sbap-hero .sbap-home-hero-subtitle,
.sbap-page .sbap-hero p.sbap-home-hero-subtitle {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-shadow: 0 4px 22px rgba(0,0,0,.90) !important;
    opacity: 1 !important;
}
body.sbap-professional-ui .sbap-hero .sbap-pill,
.sbap-page .sbap-hero .sbap-pill {
    color: #ffffff !important;
    background: rgba(255,255,255,.18) !important;
    border: 1px solid rgba(255,255,255,.24);
    text-shadow: 0 2px 10px rgba(0,0,0,.65);
}
@media (max-width: 760px) {
    body.sbap-professional-ui .sbap-hero-copy-readable,
    .sbap-page .sbap-hero-copy-readable {
        padding: 18px;
        border-radius: 24px;
    }
}


/* v3.4.3 Balanced Homepage Hero - compact, readable and premium */
body.sbap-professional-ui .sbap-hero.sbap-hero-readable,
.sbap-page .sbap-hero.sbap-hero-readable {
    min-height: clamp(390px, 48vh, 460px) !important;
    height: auto !important;
    align-items: center !important;
}
body.sbap-professional-ui .sbap-hero-readable .sbap-hero-inner,
.sbap-page .sbap-hero-readable .sbap-hero-inner {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 340px) !important;
    gap: clamp(20px, 3vw, 34px) !important;
    padding: clamp(42px, 6vw, 64px) 0 !important;
    align-items: center !important;
}
body.sbap-professional-ui .sbap-hero-copy-readable,
.sbap-page .sbap-hero-copy-readable {
    max-width: 760px !important;
    padding: clamp(18px, 2.4vw, 28px) !important;
    border-radius: 28px !important;
    background: linear-gradient(135deg, rgba(2,12,9,.58), rgba(2,12,9,.22)) !important;
}
body.sbap-professional-ui .sbap-hero .sbap-home-hero-title,
body.sbap-professional-ui .entry-content .sbap-hero .sbap-home-hero-title,
.sbap-page .sbap-hero .sbap-home-hero-title,
.sbap-page .sbap-hero h1.sbap-home-hero-title {
    font-size: clamp(30px, 4.2vw, 54px) !important;
    line-height: 1.08 !important;
    letter-spacing: -.035em !important;
    margin: 12px 0 12px !important;
    max-width: 720px !important;
}
body.sbap-professional-ui .sbap-hero .sbap-home-hero-subtitle,
body.sbap-professional-ui .entry-content .sbap-hero .sbap-home-hero-subtitle,
.sbap-page .sbap-hero .sbap-home-hero-subtitle,
.sbap-page .sbap-hero p.sbap-home-hero-subtitle {
    font-size: clamp(15px, 1.35vw, 19px) !important;
    line-height: 1.58 !important;
    max-width: 660px !important;
    margin-bottom: 0 !important;
}
body.sbap-professional-ui .sbap-hero .sbap-pill,
.sbap-page .sbap-hero .sbap-pill {
    padding: 7px 12px !important;
    font-size: 12px !important;
}
body.sbap-professional-ui .sbap-hero .sbap-actions,
.sbap-page .sbap-hero .sbap-actions {
    margin-top: 20px !important;
    gap: 12px !important;
}
body.sbap-professional-ui .sbap-hero-card,
.sbap-page .sbap-hero-card {
    padding: 22px !important;
    border-radius: 24px !important;
    min-height: auto !important;
    box-shadow: 0 16px 44px rgba(0,0,0,.18) !important;
}
body.sbap-professional-ui .sbap-hero-card strong,
.sbap-page .sbap-hero-card strong {
    font-size: 20px !important;
    margin-bottom: 12px !important;
}
body.sbap-professional-ui .sbap-hero-card p,
.sbap-page .sbap-hero-card p {
    font-size: 14px !important;
    line-height: 1.5 !important;
}
body.sbap-professional-ui .sbap-class-grid,
.sbap-page .sbap-class-grid {
    gap: 8px !important;
}
body.sbap-professional-ui .sbap-class-grid span,
.sbap-page .sbap-class-grid span {
    min-height: 42px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
}
@media (max-width: 920px) {
    body.sbap-professional-ui .sbap-hero.sbap-hero-readable,
    .sbap-page .sbap-hero.sbap-hero-readable {
        min-height: auto !important;
    }
    body.sbap-professional-ui .sbap-hero-readable .sbap-hero-inner,
    .sbap-page .sbap-hero-readable .sbap-hero-inner {
        grid-template-columns: 1fr !important;
        padding: 44px 0 !important;
    }
    body.sbap-professional-ui .sbap-hero-card,
    .sbap-page .sbap-hero-card {
        max-width: 520px !important;
    }
}
@media (max-width: 640px) {
    body.sbap-professional-ui .sbap-hero-readable .sbap-hero-inner,
    .sbap-page .sbap-hero-readable .sbap-hero-inner {
        padding: 36px 0 !important;
        gap: 18px !important;
    }
    body.sbap-professional-ui .sbap-hero-copy-readable,
    .sbap-page .sbap-hero-copy-readable {
        padding: 18px !important;
        border-radius: 22px !important;
    }
    body.sbap-professional-ui .sbap-hero .sbap-home-hero-title,
    .sbap-page .sbap-hero h1.sbap-home-hero-title {
        font-size: clamp(28px, 9vw, 38px) !important;
    }
}

/* v3.5 Content Studio professional editable layout */
.sbap-v35-home-polish {
    padding: clamp(50px, 7vw, 90px) 20px;
    background: linear-gradient(180deg, #ffffff, var(--sbap-soft));
}
.sbap-v35-home-polish .sbap-container {
    border-radius: 34px;
    padding: clamp(28px, 5vw, 58px);
    background: #fff;
    border: 1px solid rgba(27,143,90,.14);
    box-shadow: 0 24px 70px rgba(15,47,36,.12);
}
.sbap-v35-polish-head { max-width: 920px; margin-bottom: 30px; }
.sbap-v35-polish-head span {
    display: inline-flex; padding: 7px 13px; border-radius: 999px; background: var(--sbap-soft); color: var(--sbap-accent); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase;
}
.sbap-v35-polish-head h2 { margin: 16px 0 12px; color: var(--sbap-dark); font-size: clamp(34px, 4vw, 58px); line-height: 1.06; letter-spacing: -.035em; }
.sbap-v35-polish-head p { color: #52675e; font-size: 18px; line-height: 1.75; }
.sbap-v35-class-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 18px; }
.sbap-v35-class-card { display: grid; gap: 9px; min-height: 170px; padding: 24px; border-radius: 28px; background: var(--sbap-soft); border: 1px solid rgba(27,143,90,.15); color: var(--sbap-dark); transition: transform .18s ease, box-shadow .18s ease; }
.sbap-v35-class-card:hover { transform: translateY(-4px); box-shadow: 0 18px 45px rgba(15,47,36,.12); }
.sbap-v35-class-card strong { color: var(--sbap-accent); font-size: 44px; line-height: 1; }
.sbap-v35-class-card span { font-size: 18px; font-weight: 900; }
.sbap-v35-class-card em { color: var(--sbap-accent); font-style: normal; font-weight: 900; }
.sbap-v35-footer { padding: 34px 20px; background: var(--sbap-dark); color: #fff; }
.sbap-v35-footer .sbap-container { display: flex; justify-content: space-between; gap: 26px; align-items: center; }
.sbap-v35-footer-brand { display: flex; align-items: center; gap: 16px; max-width: 640px; }
.sbap-v35-footer-brand img { width: 74px; height: 74px; object-fit: contain; border-radius: 16px; background: #fff; padding: 8px; }
.sbap-v35-footer strong { display: block; font-size: 22px; margin-bottom: 6px; }
.sbap-v35-footer p { margin: 0; color: rgba(255,255,255,.82); line-height: 1.6; }
.sbap-v35-footer nav { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }
.sbap-v35-footer nav a { color: #fff; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; padding: 10px 14px; font-weight: 800; }
body.sbap-lms-active .sbap-hero h1,
body.sbap-lms-active .sbap-page-head h1,
body.sbap-lms-active [class*="hero"] h1 { color: #fff !important; text-shadow: 0 5px 24px rgba(0,0,0,.45) !important; }
body.sbap-lms-active .sbap-hero p,
body.sbap-lms-active .sbap-page-head p,
body.sbap-lms-active [class*="hero"] p { text-shadow: 0 3px 18px rgba(0,0,0,.38) !important; }
@media (max-width: 980px) { .sbap-v35-class-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } .sbap-v35-footer .sbap-container { flex-direction: column; align-items: flex-start; } .sbap-v35-footer nav { justify-content: flex-start; } }
@media (max-width: 620px) { .sbap-v35-class-grid { grid-template-columns: 1fr; } .sbap-v35-footer-brand { flex-direction: column; align-items: flex-start; } }

/* Bio Gurukul v3.6 Teacher Dashboard + Protection UI */
.bg-v36-hero {
    min-height: 420px;
    display: flex;
    align-items: center;
    padding: 70px max(24px, calc((100vw - 1220px)/2));
    color: #fff;
    background-image: linear-gradient(90deg, rgba(4,18,15,.84), rgba(8,31,24,.62), rgba(10,39,30,.38)), url("../images/portal-banner.png");
    background-size: cover;
    background-position: center;
}
.bg-v36-hero > div { max-width: 900px; }
.bg-v36-hero span {
    display: inline-flex;
    padding: 7px 13px;
    border-radius: 999px;
    background: rgba(255,255,255,.16);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.bg-v36-hero h1 {
    color: #fff;
    margin: 16px 0;
    font-size: clamp(38px, 4.6vw, 68px);
    line-height: 1.05;
    text-shadow: 0 4px 24px rgba(0,0,0,.45);
}
.bg-v36-hero p {
    color: rgba(255,255,255,.96);
    font-size: 19px;
    line-height: 1.65;
    text-shadow: 0 3px 18px rgba(0,0,0,.38);
}
.bg-v36-wrap { padding-top: 20px; }
.bg-v36-card,
.bg-v36-form,
.bg-v36-stats > div,
.bg-v36-control-card {
    background: #fff;
    border: 1px solid rgba(27,143,90,.13);
    border-radius: 28px;
    box-shadow: 0 18px 50px rgba(15,47,36,.10);
}
.bg-v36-card,
.bg-v36-form { padding: 30px; }
.bg-v36-card h2,
.bg-v36-form h2 {
    margin: 0 0 14px;
    color: var(--sbap-dark, #0f2f24);
    font-size: clamp(28px, 3vw, 44px);
    line-height: 1.1;
}
.bg-v36-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 16px;
    margin: 0 0 22px;
}
.bg-v36-stats > div {
    padding: 22px;
    text-align: center;
}
.bg-v36-stats strong {
    display: block;
    color: var(--sbap-accent, #1b8f5a);
    font-size: clamp(28px, 3.6vw, 48px);
    line-height: 1;
    margin-bottom: 8px;
}
.bg-v36-stats span {
    color: #405a4f;
    font-weight: 800;
}
.bg-v36-control-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 16px;
    margin-bottom: 24px;
}
.bg-v36-control-card {
    display: grid;
    gap: 8px;
    min-height: 160px;
    padding: 22px;
    color: var(--sbap-dark, #0f2f24);
    transition: transform .18s ease, box-shadow .18s ease;
}
.bg-v36-control-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 24px 60px rgba(15,47,36,.15);
}
.bg-v36-control-card span { font-size: 36px; }
.bg-v36-control-card strong { font-size: 20px; line-height: 1.2; }
.bg-v36-control-card em {
    color: #52675e;
    font-style: normal;
    line-height: 1.45;
}
.bg-v36-two-col {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 22px;
}
.bg-v36-form input,
.bg-v36-form select,
.bg-v36-form textarea {
    width: 100%;
    min-height: 46px;
    border-radius: 14px;
    border: 1px solid rgba(27,143,90,.24);
    background: #fbfffc;
    padding: 11px 13px;
}
.bg-v36-admin .form-table th { width: 240px; }
body.bg-v36-protected .sbap-v35-footer,
body.bg-v36-protected .site-content,
body.bg-v36-protected .entry-content { -webkit-touch-callout: none; }
@media (max-width: 1100px) {
    .bg-v36-stats,
    .bg-v36-control-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .bg-v36-two-col { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
    .bg-v36-stats,
    .bg-v36-control-grid { grid-template-columns: 1fr; }
    .bg-v36-hero { min-height: 360px; padding: 56px 22px; }
}


/* v3.6.1 balanced homepage hero + footer teacher login */
body.sbap-lms-active .sbap-hero.sbap-hero-readable,
.sbap-page .sbap-hero.sbap-hero-readable,
.sbap-hero.sbap-hero-readable {
    min-height: 440px !important;
    padding: 0 !important;
    background-position: center center !important;
}
body.sbap-lms-active .sbap-hero-readable .sbap-hero-inner,
.sbap-page .sbap-hero-readable .sbap-hero-inner,
.sbap-hero-readable .sbap-hero-inner {
    min-height: 440px !important;
    padding: 52px 0 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1.1fr) minmax(300px, .72fr) !important;
    align-items: center !important;
    gap: 28px !important;
}
body.sbap-lms-active .sbap-hero-copy-readable,
.sbap-page .sbap-hero-copy-readable,
.sbap-hero-copy-readable {
    max-width: 740px !important;
    padding: 24px 26px !important;
    border-radius: 24px !important;
}
body.sbap-lms-active .sbap-hero .sbap-home-hero-title,
body.sbap-lms-active .entry-content .sbap-hero .sbap-home-hero-title,
.sbap-page .sbap-hero h1.sbap-home-hero-title,
.sbap-hero h1.sbap-home-hero-title {
    font-size: clamp(30px, 4.1vw, 54px) !important;
    line-height: 1.08 !important;
    margin: 12px 0 12px !important;
    max-width: 720px !important;
}
body.sbap-lms-active .sbap-hero .sbap-home-hero-subtitle,
.sbap-page .sbap-hero p.sbap-home-hero-subtitle,
.sbap-hero p.sbap-home-hero-subtitle {
    font-size: clamp(15px, 1.45vw, 18px) !important;
    line-height: 1.55 !important;
    max-width: 690px !important;
    margin-bottom: 18px !important;
}
body.sbap-lms-active .sbap-hero .sbap-actions,
.sbap-page .sbap-hero .sbap-actions,
.sbap-hero .sbap-actions {
    gap: 10px !important;
    margin-top: 16px !important;
}
body.sbap-lms-active .sbap-hero-card,
.sbap-page .sbap-hero-card,
.sbap-hero-card {
    padding: 20px !important;
    border-radius: 22px !important;
    max-width: 360px !important;
    justify-self: end !important;
}
body.sbap-lms-active .sbap-hero-card strong,
.sbap-page .sbap-hero-card strong,
.sbap-hero-card strong {
    font-size: 20px !important;
    margin-bottom: 10px !important;
}
body.sbap-lms-active .sbap-hero-card p,
.sbap-page .sbap-hero-card p,
.sbap-hero-card p {
    font-size: 14px !important;
    line-height: 1.5 !important;
}
.bg-v361-footer nav a.bg-v361-teacher-login {
    background: #ffffff !important;
    color: var(--sbap-dark, #0f2f24) !important;
    border-color: #ffffff !important;
    box-shadow: 0 10px 24px rgba(0,0,0,.16);
}
.bg-v361-footer nav a.bg-v361-teacher-login:hover {
    transform: translateY(-1px);
}
@media (max-width: 980px) {
    body.sbap-lms-active .sbap-hero.sbap-hero-readable,
    .sbap-page .sbap-hero.sbap-hero-readable,
    .sbap-hero.sbap-hero-readable {
        min-height: 390px !important;
    }
    body.sbap-lms-active .sbap-hero-readable .sbap-hero-inner,
    .sbap-page .sbap-hero-readable .sbap-hero-inner,
    .sbap-hero-readable .sbap-hero-inner {
        min-height: 390px !important;
        grid-template-columns: 1fr !important;
        padding: 44px 0 !important;
    }
    body.sbap-lms-active .sbap-hero-card,
    .sbap-page .sbap-hero-card,
    .sbap-hero-card {
        max-width: 100% !important;
        justify-self: stretch !important;
    }
}
@media (max-width: 620px) {
    body.sbap-lms-active .sbap-hero.sbap-hero-readable,
    .sbap-page .sbap-hero.sbap-hero-readable,
    .sbap-hero.sbap-hero-readable {
        min-height: auto !important;
    }
    body.sbap-lms-active .sbap-hero-readable .sbap-hero-inner,
    .sbap-page .sbap-hero-readable .sbap-hero-inner,
    .sbap-hero-readable .sbap-hero-inner {
        min-height: auto !important;
        padding: 34px 0 !important;
        gap: 18px !important;
    }
    body.sbap-lms-active .sbap-hero-copy-readable,
    .sbap-page .sbap-hero-copy-readable,
    .sbap-hero-copy-readable {
        padding: 20px !important;
    }
    body.sbap-lms-active .sbap-hero .sbap-home-hero-title,
    .sbap-page .sbap-hero h1.sbap-home-hero-title,
    .sbap-hero h1.sbap-home-hero-title {
        font-size: clamp(28px, 9vw, 38px) !important;
    }
}

/* v3.6.2 Premium compact spacing + no header-to-hero gap */
html body {
    margin-top: 0 !important;
}

body .site-content,
body .content-area,
body #content,
body .ast-container,
body .entry-content,
body .wp-site-blocks,
body .site-main {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

body .entry-header,
body .page-header,
body .ast-single-entry-banner,
body .ast-archive-entry-banner {
    margin: 0 !important;
    padding: 0 !important;
}

body .entry-content > .sbap-page:first-child,
body .entry-content > .sbap-page:first-child .sbap-hero,
body .entry-content > .sbap-page:first-child .sbap-page-head,
body .entry-content > .sbap-page:first-child .sbap-v31-page-hero,
body .entry-content > .sbap-page:first-child .sbap-v32-hero,
body .entry-content > .sbap-page:first-child .sbap-v33-hero,
body .entry-content > .sbap-page:first-child .sbap-v34-hero {
    margin-top: 0 !important;
}

body .sbap-page {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

body .sbap-hero,
body .sbap-page-head,
body .sbap-v3-hero,
body .sbap-v31-page-hero,
body .sbap-v32-hero,
body .sbap-v33-hero,
body .sbap-v34-hero {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

body .sbap-hero {
    min-height: 430px !important;
    padding-top: clamp(46px, 5vw, 70px) !important;
    padding-bottom: clamp(42px, 5vw, 64px) !important;
}

body .sbap-page-head,
body .sbap-v3-hero,
body .sbap-v31-page-hero,
body .sbap-v32-hero,
body .sbap-v33-hero,
body .sbap-v34-hero {
    min-height: 320px !important;
    padding-top: clamp(46px, 5vw, 68px) !important;
    padding-bottom: clamp(42px, 5vw, 62px) !important;
}

body .sbap-section {
    padding-top: clamp(32px, 4vw, 54px) !important;
    padding-bottom: clamp(32px, 4vw, 54px) !important;
}

body .sbap-section + .sbap-section {
    padding-top: clamp(26px, 3vw, 42px) !important;
}

body .sbap-container > *:first-child {
    margin-top: 0 !important;
}

body .sbap-container > *:last-child {
    margin-bottom: 0 !important;
}

body .sbap-section-head,
body .sbap-v31-section-title,
body .sbap-v33-section-title,
body .sbap-v34-section-head {
    margin-bottom: clamp(16px, 2vw, 24px) !important;
}

body .sbap-section-head h2,
body .sbap-v31-section-title h2,
body .sbap-v34-section-head h2 {
    margin-top: 8px !important;
    margin-bottom: 8px !important;
}

body .sbap-grid,
body .sbap-card-grid,
body .sbap-feature-grid,
body .sbap-resource-grid,
body .sbap-premium-material-grid,
body .sbap-exam-grid,
body .sbap-v3-card-grid,
body .sbap-v31-home-feature-grid,
body .sbap-v31-pricing-grid,
body .sbap-v31-testimonial-grid,
body .sbap-v32-card-grid,
body .sbap-v33-receipt-grid,
body .sbap-v33-review-grid,
body .sbap-v34-app-grid,
body .sbap-v34-class-grid {
    gap: clamp(14px, 2vw, 22px) !important;
}

body .sbap-card,
body .sbap-content-card,
body .sbap-resource-card,
body .sbap-premium-material-card,
body .sbap-exam-card,
body .sbap-v3-card,
body .sbap-v31-price-card,
body .sbap-v31-testimonial,
body .sbap-v32-live-card,
body .sbap-v33-panel,
body .sbap-v34-continue-panel,
body .sbap-v34-form {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

body .sbap-teacher-card,
body .sbap-v31-split-hero,
body .sbap-v34-app-shell,
body .sbap-v34-result-card,
body .sbap-v34-parent-head,
body .sbap-v34-premium-open,
body .sbap-v34-premium-locked {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

body .sbap-actions {
    margin-top: clamp(14px, 2vw, 20px) !important;
}

body .sbap-hero h1,
body .sbap-page-head h1,
body .sbap-v31-page-hero h1,
body .sbap-v32-hero h1,
body .sbap-v33-hero h1,
body .sbap-v34-hero h1 {
    margin-top: 10px !important;
    margin-bottom: 12px !important;
}

body .sbap-hero p,
body .sbap-page-head p,
body .sbap-v31-page-hero p,
body .sbap-v32-hero p,
body .sbap-v33-hero p,
body .sbap-v34-hero p {
    margin-bottom: 0 !important;
}

body .sbap-v34-class-showcase {
    padding-top: clamp(28px, 4vw, 46px) !important;
    padding-bottom: clamp(28px, 4vw, 46px) !important;
}

body .sbap-v34-class-showcase .sbap-container {
    padding: clamp(24px, 4vw, 42px) !important;
}

body.ast-page-builder-template .site-content > .ast-container,
body.ast-page-builder-template .entry-content,
body.ast-separate-container .ast-article-single,
body.ast-separate-container .ast-article-post,
body.ast-separate-container .comments-area {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

@media (max-width: 768px) {
    body .sbap-hero {
        min-height: 360px !important;
        padding-top: 38px !important;
        padding-bottom: 38px !important;
    }

    body .sbap-page-head,
    body .sbap-v3-hero,
    body .sbap-v31-page-hero,
    body .sbap-v32-hero,
    body .sbap-v33-hero,
    body .sbap-v34-hero {
        min-height: 280px !important;
        padding-top: 36px !important;
        padding-bottom: 36px !important;
    }

    body .sbap-section {
        padding-top: 26px !important;
        padding-bottom: 26px !important;
    }

    body .sbap-section + .sbap-section {
        padding-top: 22px !important;
    }

    body .sbap-hero h1,
    body .sbap-page-head h1,
    body .sbap-v31-page-hero h1,
    body .sbap-v32-hero h1,
    body .sbap-v33-hero h1,
    body .sbap-v34-hero h1 {
        margin-top: 8px !important;
        margin-bottom: 10px !important;
    }
}

/* v3.6.3 Remove page title and hero/banner from all inner LMS pages except homepage */
body.biogurukul-lms-inner-page .entry-title,
body.biogurukul-lms-inner-page .page-title,
body.biogurukul-lms-inner-page .entry-header,
body.biogurukul-lms-inner-page .page-header,
body.biogurukul-lms-inner-page .ast-single-entry-banner,
body.biogurukul-lms-inner-page .ast-archive-entry-banner,
body.biogurukul-lms-inner-page .ast-page-title-bar,
body.biogurukul-lms-inner-page .ast-advanced-headers-wrap,
body.biogurukul-lms-inner-page .wp-block-post-title {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}

body.biogurukul-lms-inner-page .sbap-page > .sbap-page-head,
body.biogurukul-lms-inner-page .sbap-page > .sbap-v3-hero,
body.biogurukul-lms-inner-page .sbap-page > .sbap-v31-page-hero,
body.biogurukul-lms-inner-page .sbap-page > .sbap-v32-hero,
body.biogurukul-lms-inner-page .sbap-page > .sbap-v33-hero,
body.biogurukul-lms-inner-page .sbap-page > .sbap-v34-hero,
body.biogurukul-lms-inner-page .sbap-page > section[class*="-hero"],
body.biogurukul-lms-inner-page .sbap-page > section[class*="hero"]:not(.sbap-hero) {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}

body.biogurukul-lms-inner-page .site-content,
body.biogurukul-lms-inner-page .content-area,
body.biogurukul-lms-inner-page #content,
body.biogurukul-lms-inner-page .entry-content,
body.biogurukul-lms-inner-page .site-main,
body.biogurukul-lms-inner-page .ast-container,
body.biogurukul-lms-inner-page .ast-article-single,
body.biogurukul-lms-inner-page .type-page {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

body.biogurukul-lms-inner-page .sbap-page {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

body.biogurukul-lms-inner-page .sbap-page > .sbap-section:first-of-type,
body.biogurukul-lms-inner-page .sbap-page > section.sbap-section:first-of-type {
    padding-top: clamp(22px, 3vw, 38px) !important;
}

body.biogurukul-lms-inner-page .entry-content > .sbap-page:first-child {
    margin-top: 0 !important;
}

/* Keep homepage hero visible and balanced */
body.biogurukul-lms-home-page .sbap-hero {
    display: flex !important;
    visibility: visible !important;
}

/* v3.6.4 Restore app-like features + improve homepage hero readability */

/* Keep app dashboard content visible even on inner pages where page hero is removed */
body.biogurukul-lms-inner-page .sbap-v34-app-shell,
body.biogurukul-lms-inner-page .sbap-v34-app-shell *,
body.biogurukul-lms-inner-page .sbap-v34-app-hero,
body.biogurukul-lms-inner-page .sbap-v34-app-grid,
body.biogurukul-lms-inner-page .sbap-v34-mini-stats,
body.biogurukul-lms-inner-page .sbap-v34-continue-panel,
body.biogurukul-lms-inner-page .sbap-v34-mobile-nav {
    visibility: visible !important;
    opacity: 1 !important;
}

body.biogurukul-lms-inner-page .sbap-v34-app-hero {
    display: flex !important;
    height: auto !important;
    min-height: auto !important;
    max-height: none !important;
    margin-bottom: 20px !important;
    padding: 26px !important;
    overflow: visible !important;
}

body.biogurukul-lms-inner-page .sbap-v34-app-grid {
    display: grid !important;
}

body.biogurukul-lms-inner-page .sbap-v34-mini-stats {
    display: grid !important;
}

/* Make sure only direct page/banner hero sections are removed, not inner app cards */
body.biogurukul-lms-inner-page .sbap-v34-app-shell .sbap-v34-app-hero,
body.biogurukul-lms-inner-page .sbap-v34-app-shell .sbap-v34-app-hero * {
    display: revert-layer;
}

body.biogurukul-lms-inner-page .sbap-v34-app-shell .sbap-v34-app-hero {
    display: flex !important;
}

/* Restore mobile bottom nav for app-like feature */
@media (max-width: 760px) {
    body.biogurukul-lms-inner-page .sbap-v34-mobile-nav,
    body.biogurukul-lms-home-page .sbap-v34-mobile-nav {
        position: fixed !important;
        left: 10px !important;
        right: 10px !important;
        bottom: 10px !important;
        z-index: 999999 !important;
        display: grid !important;
        grid-template-columns: repeat(5, 1fr) !important;
        gap: 4px !important;
        padding: 8px !important;
        border-radius: 22px !important;
        background: rgba(15,47,36,.96) !important;
        box-shadow: 0 18px 50px rgba(0,0,0,.25) !important;
        backdrop-filter: blur(12px) !important;
        height: auto !important;
        min-height: auto !important;
        max-height: none !important;
        overflow: visible !important;
    }
    body .sbap-v34-mobile-nav a {
        display: grid !important;
        place-items: center !important;
        color: #fff !important;
        font-size: 10px !important;
        font-weight: 900 !important;
        gap: 2px !important;
        text-decoration: none !important;
    }
    body .sbap-v34-mobile-nav span {
        display: block !important;
        font-size: 18px !important;
    }
}

/* Homepage hero readability: stronger dark image overlay and readable text panel */
body.biogurukul-lms-home-page .sbap-hero {
    position: relative !important;
    min-height: 390px !important;
    padding-top: clamp(42px, 5vw, 64px) !important;
    padding-bottom: clamp(42px, 5vw, 64px) !important;
    background-blend-mode: multiply !important;
}

body.biogurukul-lms-home-page .sbap-hero::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(90deg, rgba(2,12,9,.88) 0%, rgba(5,22,17,.78) 42%, rgba(5,22,17,.50) 70%, rgba(5,22,17,.62) 100%) !important;
    z-index: 0 !important;
    pointer-events: none !important;
}

body.biogurukul-lms-home-page .sbap-hero .sbap-container,
body.biogurukul-lms-home-page .sbap-hero > * {
    position: relative !important;
    z-index: 2 !important;
}

body.biogurukul-lms-home-page .sbap-hero-content,
body.biogurukul-lms-home-page .sbap-hero-text,
body.biogurukul-lms-home-page .sbap-hero .sbap-hero-copy,
body.biogurukul-lms-home-page .sbap-hero .sbap-hero-left {
    background: rgba(3, 18, 14, .58) !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    box-shadow: 0 18px 48px rgba(0,0,0,.22) !important;
    border-radius: 24px !important;
    padding: clamp(20px, 3vw, 34px) !important;
    backdrop-filter: blur(5px) !important;
}

body.biogurukul-lms-home-page .sbap-hero h1,
body.biogurukul-lms-home-page .sbap-hero h1 *,
body.biogurukul-lms-home-page .sbap-hero .sbap-hero-title,
body.biogurukul-lms-home-page .sbap-hero .sbap-hero-title * {
    color: #ffffff !important;
    opacity: 1 !important;
    text-shadow: 0 4px 18px rgba(0,0,0,.72), 0 1px 2px rgba(0,0,0,.9) !important;
    -webkit-text-fill-color: #ffffff !important;
    background: none !important;
}

body.biogurukul-lms-home-page .sbap-hero p,
body.biogurukul-lms-home-page .sbap-hero p *,
body.biogurukul-lms-home-page .sbap-hero .sbap-hero-subtitle,
body.biogurukul-lms-home-page .sbap-hero .sbap-hero-subtitle * {
    color: rgba(255,255,255,.96) !important;
    opacity: 1 !important;
    text-shadow: 0 3px 14px rgba(0,0,0,.65) !important;
    -webkit-text-fill-color: rgba(255,255,255,.96) !important;
}

body.biogurukul-lms-home-page .sbap-hero span,
body.biogurukul-lms-home-page .sbap-hero .sbap-pill,
body.biogurukul-lms-home-page .sbap-hero .sbap-kicker {
    color: #ffffff !important;
    background: rgba(255,255,255,.15) !important;
    border: 1px solid rgba(255,255,255,.20) !important;
    text-shadow: 0 2px 8px rgba(0,0,0,.55) !important;
}

body.biogurukul-lms-home-page .sbap-hero .sbap-btn-primary {
    color: #fff !important;
    background: var(--sbap-accent) !important;
    box-shadow: 0 14px 32px rgba(0,0,0,.22) !important;
}

body.biogurukul-lms-home-page .sbap-hero .sbap-btn-light {
    color: #0f2f24 !important;
    background: rgba(255,255,255,.95) !important;
}

/* Keep home hero balanced after readability panel */
@media (max-width: 768px) {
    body.biogurukul-lms-home-page .sbap-hero {
        min-height: 340px !important;
        padding-top: 34px !important;
        padding-bottom: 34px !important;
    }
    body.biogurukul-lms-home-page .sbap-hero-content,
    body.biogurukul-lms-home-page .sbap-hero-text,
    body.biogurukul-lms-home-page .sbap-hero .sbap-hero-copy,
    body.biogurukul-lms-home-page .sbap-hero .sbap-hero-left {
        padding: 20px !important;
        border-radius: 20px !important;
    }
}

/* Direct fallback: if body class fails, make homepage shortcode hero readable anyway */
body .sbap-page .sbap-hero h1,
body .sbap-page .sbap-hero h1 * {
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
    text-shadow: 0 4px 18px rgba(0,0,0,.72) !important;
}

body .sbap-page .sbap-hero p,
body .sbap-page .sbap-hero p * {
    color: rgba(255,255,255,.96) !important;
    -webkit-text-fill-color: rgba(255,255,255,.96) !important;
    text-shadow: 0 3px 14px rgba(0,0,0,.65) !important;
}

/* v3.6.5 Final locked homepage hero: balanced size + readable text */
html body .sbap-page .sbap-hero.sbap-hero-readable,
html body .sbap-page .sbap-hero.sbap-home-hero-fixed,
html body.sbap-lms-active .sbap-hero.sbap-hero-readable {
    min-height: 380px !important;
    height: auto !important;
    padding: 0 !important;
    background-color: #06130f !important;
}
html body .sbap-page .sbap-hero-readable .sbap-hero-inner,
html body .sbap-page .sbap-home-hero-fixed .sbap-hero-inner,
html body.sbap-lms-active .sbap-hero-readable .sbap-hero-inner {
    min-height: 380px !important;
    padding: 34px 0 !important;
    grid-template-columns: minmax(0,1fr) minmax(240px,310px) !important;
    gap: 22px !important;
}
html body .sbap-page .sbap-hero-copy-readable,
html body.sbap-lms-active .sbap-hero-copy-readable {
    background: rgba(0,0,0,.74) !important;
    border: 1px solid rgba(255,255,255,.24) !important;
    padding: 20px 22px !important;
    border-radius: 22px !important;
}
html body .sbap-page .sbap-hero h1.sbap-home-hero-title,
html body.sbap-lms-active .sbap-hero h1.sbap-home-hero-title {
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
    font-size: clamp(28px,3.4vw,44px) !important;
    line-height: 1.12 !important;
    margin: 10px 0 !important;
    text-shadow: 0 4px 18px rgba(0,0,0,.98), 0 1px 2px rgba(0,0,0,1) !important;
}
html body .sbap-page .sbap-hero p.sbap-home-hero-subtitle,
html body.sbap-lms-active .sbap-hero p.sbap-home-hero-subtitle {
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
    font-size: clamp(14px,1.25vw,17px) !important;
    line-height: 1.55 !important;
    text-shadow: 0 3px 15px rgba(0,0,0,.95) !important;
}
@media (max-width:980px){
    html body .sbap-page .sbap-hero.sbap-hero-readable,
    html body .sbap-page .sbap-hero.sbap-home-hero-fixed,
    html body.sbap-lms-active .sbap-hero.sbap-hero-readable { min-height:auto !important; }
    html body .sbap-page .sbap-hero-readable .sbap-hero-inner,
    html body .sbap-page .sbap-home-hero-fixed .sbap-hero-inner,
    html body.sbap-lms-active .sbap-hero-readable .sbap-hero-inner {
        min-height:auto !important;
        grid-template-columns:1fr !important;
        padding:28px 0 !important;
    }
}

/* v3.6.6 Global readability fix across all Bio Gurukul LMS pages */
html body.sbap-lms-active .sbap-page,
html body.biogurukul-lms-home-page .sbap-page,
html body.biogurukul-lms-inner-page .sbap-page {
    color: #1d332a !important;
}
html body.sbap-lms-active .sbap-page :is(.sbap-card,.sbap-content-card,.sbap-form-card,.sbap-resource-card,.sbap-premium-material-card,.sbap-exam-card,.sbap-test-paper,.sbap-teacher-card,.sbap-hero-card,.sbap-v3-card,.sbap-v31-price-card,.sbap-v31-testimonial,.sbap-v32-live-card,.sbap-v33-panel,.sbap-v34-app-shell,.sbap-v34-form,.sbap-v34-result-card,.sbap-empty,.sbap-notice),
html body.biogurukul-lms-home-page .sbap-page :is(.sbap-card,.sbap-content-card,.sbap-form-card,.sbap-resource-card,.sbap-premium-material-card,.sbap-exam-card,.sbap-teacher-card,.sbap-hero-card,.sbap-empty,.sbap-notice),
html body.biogurukul-lms-inner-page .sbap-page :is(.sbap-card,.sbap-content-card,.sbap-form-card,.sbap-resource-card,.sbap-premium-material-card,.sbap-exam-card,.sbap-test-paper,.sbap-teacher-card,.sbap-hero-card,.sbap-v3-card,.sbap-v31-price-card,.sbap-v31-testimonial,.sbap-v32-live-card,.sbap-v33-panel,.sbap-v34-app-shell,.sbap-v34-form,.sbap-v34-result-card,.sbap-empty,.sbap-notice) {
    color: #1d332a !important;
    -webkit-text-fill-color: #1d332a !important;
}
html body.sbap-lms-active .sbap-page :is(.sbap-card,.sbap-content-card,.sbap-form-card,.sbap-resource-card,.sbap-premium-material-card,.sbap-exam-card,.sbap-test-paper,.sbap-teacher-card,.sbap-hero-card,.sbap-v3-card,.sbap-v31-price-card,.sbap-v31-testimonial,.sbap-v32-live-card,.sbap-v33-panel,.sbap-v34-app-shell,.sbap-v34-form,.sbap-v34-result-card) :is(h1,h2,h3,h4,h5,h6,strong,b,label,summary) {
    color: #10251d !important;
    -webkit-text-fill-color: #10251d !important;
    text-shadow: none !important;
}
html body.sbap-lms-active .sbap-page :is(.sbap-card,.sbap-content-card,.sbap-form-card,.sbap-resource-card,.sbap-premium-material-card,.sbap-exam-card,.sbap-test-paper,.sbap-teacher-card,.sbap-hero-card,.sbap-v3-card,.sbap-v31-price-card,.sbap-v31-testimonial,.sbap-v32-live-card,.sbap-v33-panel,.sbap-v34-app-shell,.sbap-v34-form,.sbap-v34-result-card) :is(p,li,small,span,em,td,th,div) {
    color: #405a4f !important;
    -webkit-text-fill-color: #405a4f !important;
    text-shadow: none !important;
}
html body.sbap-lms-active .sbap-page :is(.sbap-hero,.sbap-page-head,.sbap-v3-hero,.sbap-v31-page-hero,.sbap-v32-hero,.sbap-v33-hero,.sbap-v34-hero,.sbap-hero-copy-readable,.sbap-v34-app-hero,.sbap-v31-student-hero-card,.sbap-v3-dashboard-head,.sbap-test-paper-head,.sbap-exam-panel,.sbap-v34-result-score,.sbap-teacher-experience-box,.sbap-material-stats > div) :is(h1,h2,h3,h4,h5,h6,p,span,strong,b,small,em,li,div),
html body.biogurukul-lms-home-page .sbap-page :is(.sbap-hero,.sbap-hero-copy-readable,.sbap-teacher-experience-box,.sbap-material-stats > div) :is(h1,h2,h3,h4,h5,h6,p,span,strong,b,small,em,li,div) {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-shadow: 0 2px 10px rgba(0,0,0,.36) !important;
}
html body .sbap-page .sbap-hero .sbap-hero-card,
html body .sbap-page .sbap-hero .sbap-hero-card :is(h1,h2,h3,h4,p,span,strong,b,em,small,div) {
    color: #10251d !important;
    -webkit-text-fill-color: #10251d !important;
    text-shadow: none !important;
}
html body.sbap-lms-active .sbap-page :is(input,select,textarea),
html body.biogurukul-lms-home-page .sbap-page :is(input,select,textarea),
html body.biogurukul-lms-inner-page .sbap-page :is(input,select,textarea) {
    color: #10251d !important;
    -webkit-text-fill-color: #10251d !important;
    background: #ffffff !important;
}
html body.sbap-lms-active .sbap-page .sbap-btn-primary {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    background: #0f6845 !important;
}
html body.sbap-lms-active .sbap-page .sbap-btn-light {
    color: #10251d !important;
    -webkit-text-fill-color: #10251d !important;
    background: #ffffff !important;
}
