/* ============================================================================
   /for-schools/ — B2B section stylesheet.
   Layered on top of style.css. Re-uses navbar/footer/button primitives;
   adds B2B-specific hero, service list, stats, pain grid, contact form.
   ============================================================================ */

/* ── Nav CTA — "For Schools" button in .nav-buttons ──────────────────────── */
.btn-for-schools {
    background: transparent;
    color: #fff;
    border: 2px solid var(--brand-sky-light, #A9CFE8);
    padding: 0.5rem 1rem;
    border-radius: var(--radius-md);
    font-weight: 600;
}
.btn-for-schools:hover,
.btn-for-schools.active {
    background: var(--brand-sky-light, #A9CFE8);
    color: var(--brand-navy);
    border-color: var(--brand-sky-light, #A9CFE8);
}

/* ── Hero ────────────────────────────────────────────────────────────────── */
.b2b-hero {
    background:
        radial-gradient(circle at 18% 20%, rgba(255,255,255,.08), transparent 28%),
        linear-gradient(135deg, var(--brand-navy) 0%, var(--brand-navy-dark) 100%);
    color: #fff;
    padding: 80px 20px 60px;
    text-align: left;
}
.b2b-hero .container { max-width: 1100px; margin: 0 auto; }
.b2b-hero h1 {
    color: #fff;
    font-size: 2.4rem;
    line-height: 1.2;
    margin: 1rem 0 1rem;
    max-width: 880px;
}
.b2b-hero-lede {
    color: rgba(255,255,255,.92);
    font-size: 1.1rem;
    max-width: 780px;
    margin: 0 0 1.5rem;
}
.b2b-badge {
    display: inline-block;
    background: var(--brand-crimson);
    color: #fff;
    padding: 0.3rem 0.85rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}
.b2b-hero-ctas {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin: 1rem 0 1.5rem;
}
.b2b-hero-disclaim {
    font-size: 0.88rem;
    color: rgba(255,255,255,.78);
    max-width: 880px;
    margin: 0;
}
.b2b-hero-compact { padding: 60px 20px 40px; }
.b2b-hero-compact h1 { font-size: 2rem; }

/* ── Disclaimer band (above-the-fold compliance) ─────────────────────────── */
.b2b-disclaimer-band {
    background: #fff8e1;
    border-top: 3px solid var(--brand-crimson);
    border-bottom: 1px solid #e0d6a4;
    padding: 18px 20px;
}
.b2b-disclaimer-band .container { max-width: 1100px; margin: 0 auto; }
.b2b-disclaimer-band p {
    margin: 0;
    font-size: 0.92rem;
    color: #4a3c12;
    line-height: 1.55;
}

/* ── Generic section wrappers ────────────────────────────────────────────── */
.b2b-section {
    padding: 56px 20px;
}
.b2b-section .container { max-width: 1100px; margin: 0 auto; }
.b2b-section-light { background: #f5f7fa; }
.b2b-section-navy {
    background: linear-gradient(180deg, var(--brand-navy) 0%, var(--brand-navy-dark) 100%);
    color: rgba(255,255,255,.92);
}
.b2b-section-title {
    color: var(--brand-navy);
    font-size: 1.75rem;
    margin-bottom: 1rem;
}
.b2b-section-title-light { color: #fff; }
.b2b-section-lede {
    color: var(--text-gray, #5b6b7f);
    max-width: 780px;
    margin-bottom: 2rem;
}
.b2b-section-foot {
    margin-top: 1.25rem;
    font-size: 0.88rem;
    color: var(--text-gray, #5b6b7f);
}
.b2b-section-foot a { color: var(--brand-navy); text-decoration: underline; }
.b2b-section-navy a { color: var(--brand-sky-light, #A9CFE8); }

/* ── Stat row ───────────────────────────────────────────────────────────── */
.b2b-stat-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.b2b-stat {
    background: #fff;
    border-radius: 12px;
    padding: 24px;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    text-align: center;
}
.b2b-stat-num {
    font-size: 2.4rem;
    font-weight: 800;
    color: var(--brand-navy);
    margin: 0 0 0.4rem;
}
.b2b-stat-num small { font-size: 1.1rem; font-weight: 600; color: var(--text-gray, #5b6b7f); }
.b2b-stat-label {
    font-size: 0.95rem;
    color: var(--text-gray, #5b6b7f);
    margin: 0;
    line-height: 1.5;
}

/* ── Card grids (pathways + pain points) ─────────────────────────────────── */
.b2b-grid {
    display: grid;
    gap: 20px;
}
.b2b-grid-3 { grid-template-columns: repeat(3, 1fr); }
.b2b-grid-2 { grid-template-columns: repeat(2, 1fr); }

.b2b-card {
    background: #fff;
    border-radius: 12px;
    padding: 28px;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    border-top: 4px solid var(--brand-navy);
}
.b2b-card h3 {
    color: var(--brand-navy);
    margin: 0 0 .6rem;
    font-size: 1.15rem;
}
.b2b-card h3 i {
    color: var(--brand-crimson);
    margin-right: 0.4rem;
}
.b2b-card p { margin: 0; line-height: 1.6; }

.b2b-pain {
    background: #fff;
    border-radius: 10px;
    padding: 22px;
    border-left: 4px solid var(--brand-crimson);
    box-shadow: 0 2px 6px rgba(0,0,0,.05);
}
.b2b-pain h4 {
    color: var(--brand-navy);
    margin: 0 0 .4rem;
    font-size: 1.05rem;
}
.b2b-pain h4 i { color: var(--brand-crimson); margin-right: 0.4rem; }
.b2b-pain p { margin: 0; font-size: 0.95rem; line-height: 1.6; }

/* ── Service list (ordered) ─────────────────────────────────────────────── */
.b2b-services {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.b2b-service {
    background: #fff;
    border-radius: 12px;
    padding: 24px;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    display: grid;
    grid-template-columns: 56px 1fr;
    gap: 18px;
    align-items: start;
}
.b2b-service-num {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--brand-navy);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 1.25rem;
}
.b2b-service h3 {
    color: var(--brand-navy);
    margin: 0 0 .4rem;
    font-size: 1.15rem;
}
.b2b-service p { margin: 0 0 .5rem; line-height: 1.6; }
.b2b-price {
    margin: 0;
    font-weight: 700;
    color: var(--brand-crimson);
    font-size: 1.05rem;
}
.b2b-price small {
    font-weight: 500;
    color: var(--text-gray, #5b6b7f);
    font-size: 0.85rem;
}

/* Locked-pricing badge. Public for-schools pages do not show fee ranges;
   they show this badge with a "Sign in for pricing" link. Indicative
   pricing surfaces only inside the SCHOOL-role dashboard after login. */
.b2b-price-locked {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .8rem;
    background: #f4f6fa;
    border: 1px solid #d8dee9;
    border-radius: 6px;
    font-weight: 600;
    font-size: .92rem;
    color: var(--brand-navy);
    text-decoration: none;
}
.b2b-price-locked i { color: var(--brand-crimson); }
.b2b-price-locked a {
    color: var(--brand-navy);
    text-decoration: underline;
}
.b2b-price-locked:hover { background: #eef1f7; }

/* "What we do / What we do not do" delineation block used on every
   stage page to make the consultancy-only scope explicit. */
.b2b-scope-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.25rem;
    margin-top: 1.5rem;
}
.b2b-scope-card {
    padding: 1.25rem 1.4rem;
    border-radius: 8px;
    border: 1px solid #e1e6ee;
    background: #fff;
}
.b2b-scope-card.b2b-scope-yes { border-left: 4px solid #2e7d32; }
.b2b-scope-card.b2b-scope-no  { border-left: 4px solid #a6192e; }
.b2b-scope-card h4 {
    margin: 0 0 .6rem;
    font-size: 1.02rem;
    color: var(--brand-navy);
}
.b2b-scope-card.b2b-scope-yes h4 i { color: #2e7d32; margin-right: .35rem; }
.b2b-scope-card.b2b-scope-no  h4 i { color: #a6192e; margin-right: .35rem; }
.b2b-scope-card ul {
    margin: 0;
    padding-left: 1.1rem;
    line-height: 1.7;
    color: #374151;
    font-size: .94rem;
}

/* ── For Schools dashboard ────────────────────────────────────────────────
   Login-gated SCHOOL-account dashboard. Renders the indicative pricing
   sheet (auth-gated equivalent of what used to live on every public page)
   and, in later phases, the per-engagement stage tracker.            */
.fs-pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.25rem;
    margin-top: 1.5rem;
}
.fs-pricing-card {
    padding: 1.4rem;
    border-radius: 10px;
    border: 1px solid #e1e6ee;
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
    display: flex;
    flex-direction: column;
    gap: .6rem;
}
.fs-pricing-stage {
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--brand-crimson);
    font-weight: 700;
}
.fs-pricing-card h3 {
    margin: 0;
    color: var(--brand-navy);
    font-size: 1.08rem;
    line-height: 1.35;
}
.fs-pricing-range {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--brand-navy);
}
.fs-pricing-unit {
    margin: 0;
    font-size: .85rem;
    color: #5b6b7f;
    line-height: 1.55;
}
.fs-pricing-link {
    margin-top: auto;
    color: var(--brand-navy);
    font-weight: 600;
    font-size: .92rem;
    text-decoration: none;
}
.fs-pricing-link:hover { text-decoration: underline; }

.fs-tracker-placeholder {
    padding: 2.5rem 1.5rem;
    border-radius: 10px;
    border: 1px dashed #c9d2e0;
    background: #fff;
    text-align: center;
    margin-top: 1.25rem;
}
.fs-tracker-placeholder i {
    font-size: 2rem;
    color: var(--brand-navy);
    margin-bottom: .8rem;
}
.fs-tracker-placeholder h3 {
    margin: 0 0 .6rem;
    color: var(--brand-navy);
    font-size: 1.15rem;
}
.fs-tracker-placeholder p {
    color: #374151;
    line-height: 1.7;
    margin: 0 auto 1.25rem;
    max-width: 56ch;
}
.fs-tracker-stage-links {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: center;
}
.fs-tracker-stage-links a {
    padding: .45rem .85rem;
    border-radius: 999px;
    background: #f4f6fa;
    color: var(--brand-navy);
    font-weight: 600;
    font-size: .87rem;
    text-decoration: none;
    border: 1px solid #d8dee9;
}
.fs-tracker-stage-links a:hover {
    background: #eef1f7;
    text-decoration: underline;
}

/* ── For Schools template library ─────────────────────────────────────── */
.fs-tpl-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}
.fs-tpl-filter-group {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}
.fs-tpl-filter {
    padding: .45rem .9rem;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #d8dee9;
    color: var(--brand-navy);
    font-weight: 600;
    font-size: .87rem;
    cursor: pointer;
    transition: all .15s;
}
.fs-tpl-filter:hover {
    border-color: var(--brand-navy);
    background: #f7f9fc;
}
.fs-tpl-filter.active {
    background: var(--brand-navy);
    color: #fff;
    border-color: var(--brand-navy);
}
.fs-tpl-count {
    margin: 0;
    color: #5b6b7f;
    font-size: .9rem;
}
.fs-tpl-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1.1rem;
}
.fs-tpl-card {
    padding: 1.3rem;
    border-radius: 10px;
    border: 1px solid #e1e6ee;
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
    display: flex;
    flex-direction: column;
    gap: .55rem;
}
.fs-tpl-card-pending {
    background: #fbfbfd;
    border-style: dashed;
}
.fs-tpl-card-stage {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--brand-crimson);
    font-weight: 700;
}
.fs-tpl-card-title {
    margin: 0;
    color: var(--brand-navy);
    font-size: 1.05rem;
    line-height: 1.35;
}
.fs-tpl-card-title a {
    color: var(--brand-navy);
    text-decoration: none;
}
.fs-tpl-card-title a:hover { text-decoration: underline; }
.fs-tpl-card-meta {
    margin: 0;
    color: #5b6b7f;
    font-size: .82rem;
}
.fs-tpl-card-summary,
.fs-tpl-card-when {
    margin: 0;
    color: #374151;
    font-size: .9rem;
    line-height: 1.55;
}
.fs-tpl-card-when strong { color: var(--brand-navy); }
.fs-tpl-card-actions {
    margin-top: auto;
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    align-items: center;
}
.fs-tpl-card-link {
    color: var(--brand-navy);
    font-weight: 600;
    font-size: .87rem;
    text-decoration: none;
}
.fs-tpl-card-link:hover { text-decoration: underline; }
.fs-tpl-card-soon {
    color: #5b6b7f;
    font-size: .85rem;
}
.fs-tpl-pending-badge {
    display: inline-block;
    margin-left: .4rem;
    padding: .12rem .55rem;
    border-radius: 999px;
    background: #fff7e6;
    color: #8b5a00;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    vertical-align: middle;
}

/* ── Template detail (viewer) ──────────────────────────────────────────── */
.fs-tpl-detail-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem .8rem;
    color: rgba(255,255,255,.85);
    font-size: .88rem;
    margin: .6rem 0 .8rem;
}
.fs-tpl-detail-meta .fs-tpl-meta-sep {
    opacity: .55;
}
.fs-tpl-doc {
    max-width: 820px;
    margin: 0 auto;
    padding: 2rem 2.2rem;
    background: #fff;
    border: 1px solid #e1e6ee;
    border-radius: 10px;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
    line-height: 1.7;
    color: #1f2933;
    font-size: 1rem;
}
.fs-tpl-section-heading {
    margin: 1.4rem 0 .6rem;
    font-size: 1.1rem;
    color: var(--brand-navy);
    border-bottom: 1px solid #eef0f4;
    padding-bottom: .35rem;
}
.fs-tpl-section-heading:first-child { margin-top: 0; }
.fs-tpl-doc p, .fs-tpl-doc ul, .fs-tpl-doc ol { margin: 0 0 1rem; }
.fs-tpl-doc ul { padding-left: 1.3rem; }
.fs-tpl-doc li { margin-bottom: .35rem; }
.fs-tpl-placeholder {
    color: var(--brand-crimson);
    font-style: italic;
    background: #fff5f5;
    padding: .05rem .25rem;
    border-radius: 3px;
}
.fs-tpl-pending-notice {
    text-align: center;
    padding: 2.5rem 1.5rem;
    color: #374151;
}
.fs-tpl-pending-notice i {
    font-size: 2rem;
    color: var(--brand-navy);
    margin-bottom: .8rem;
}
.fs-tpl-pending-notice h2 {
    margin: 0 0 .6rem;
    color: var(--brand-navy);
    font-size: 1.25rem;
}
.fs-tpl-pending-notice p {
    margin: 0 auto;
    max-width: 56ch;
    line-height: 1.7;
}

/* ── Stage tracker (dashboard Phase 4) ───────────────────────────────── */
.fs-tracker-empty {
    padding: 2rem 1.5rem;
    text-align: center;
    color: #5b6b7f;
    background: #fff;
    border: 1px dashed #c9d2e0;
    border-radius: 10px;
    margin-bottom: 1.5rem;
}
.fs-tracker-empty i { font-size: 1.6rem; color: var(--brand-navy); margin-bottom: .5rem; }
.fs-tracker-empty p { margin: 0; }
.fs-tracker-start-block {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid #e1e6ee;
}
.fs-tracker-start-heading {
    margin: 0 0 .35rem;
    color: var(--brand-navy);
    font-size: 1.15rem;
}
.fs-tracker-start-lede {
    margin: 0 0 1rem;
    color: #5b6b7f;
}
.fs-tracker-start-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
}
.fs-start-card {
    padding: 1.2rem;
    border-radius: 10px;
    border: 1px solid #e1e6ee;
    background: #fff;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}
.fs-start-stage {
    margin: 0;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--brand-crimson);
    font-weight: 700;
}
.fs-start-card h4 {
    margin: 0;
    color: var(--brand-navy);
    font-size: 1rem;
    line-height: 1.35;
}
.fs-start-meta {
    margin: 0;
    color: #5b6b7f;
    font-size: .85rem;
}
.fs-start-btn {
    margin-top: auto;
    padding: .55rem 1rem;
    font-size: .9rem;
}
.fs-start-btn[disabled] {
    background: #d8dee9;
    color: #5b6b7f;
    cursor: not-allowed;
}

.fs-eng-card {
    padding: 1.4rem;
    border-radius: 10px;
    border: 1px solid #e1e6ee;
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
    margin-bottom: 1.25rem;
}
.fs-eng-header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-bottom: .8rem;
}
.fs-eng-stage {
    margin: 0;
    font-weight: 700;
    color: var(--brand-navy);
    font-size: 1.05rem;
}
.fs-eng-meta {
    margin: .2rem 0 0;
    color: #5b6b7f;
    font-size: .85rem;
}
.fs-eng-controls {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
}
.fs-eng-status-badge {
    padding: .25rem .65rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.fs-eng-status-active    { background: #e6f4ea; color: #2e7d32; }
.fs-eng-status-paused    { background: #fff7e6; color: #8b5a00; }
.fs-eng-status-completed { background: #e1ecf7; color: var(--brand-navy); }
.fs-eng-status-cancelled { background: #f4dde0; color: var(--brand-crimson); }
.fs-eng-status-select {
    padding: .35rem .6rem;
    border-radius: 6px;
    border: 1px solid #d8dee9;
    background: #fff;
    font-size: .85rem;
    color: var(--brand-navy);
}
.fs-eng-progress {
    width: 100%;
    height: 6px;
    border-radius: 999px;
    background: #eef1f7;
    overflow: hidden;
    margin-bottom: 1rem;
}
.fs-eng-progress span {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, var(--brand-navy), #1f6dbd);
    transition: width .25s ease;
}

.fs-step-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: .6rem;
}
.fs-step {
    display: flex;
    gap: .85rem;
    padding: .9rem 1rem;
    border-radius: 8px;
    border: 1px solid #eef1f7;
    background: #fbfcfe;
}
.fs-step-done {
    background: #f4faf6;
    border-color: #d4e8d7;
}
.fs-step-toggle {
    display: flex;
    align-items: flex-start;
    cursor: pointer;
}
.fs-step-toggle input {
    width: 20px;
    height: 20px;
    accent-color: #2e7d32;
    cursor: pointer;
    margin-top: 2px;
}
.fs-step-body { flex: 1; }
.fs-step-headline {
    display: flex;
    justify-content: space-between;
    gap: .75rem;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-bottom: .3rem;
}
.fs-step-headline h4 {
    margin: 0;
    color: var(--brand-navy);
    font-size: .98rem;
    line-height: 1.35;
}
.fs-step-done .fs-step-headline h4 {
    color: #2e7d32;
    text-decoration: line-through;
    text-decoration-thickness: 1px;
}
.fs-actor-badge {
    padding: .15rem .5rem;
    border-radius: 999px;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    white-space: nowrap;
}
.fs-actor-inst  { background: #fff5f5; color: var(--brand-crimson); }
.fs-actor-us    { background: #e1ecf7; color: var(--brand-navy); }
.fs-actor-joint { background: #f0e8f7; color: #5b3aa6; }

.fs-step-desc {
    margin: 0 0 .4rem;
    font-size: .9rem;
    color: #374151;
    line-height: 1.55;
}
.fs-step-foot {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
    align-items: center;
    font-size: .82rem;
}
.fs-step-due {
    color: #5b6b7f;
    font-weight: 600;
}
.fs-step-due-soon     { color: #8b5a00; }
.fs-step-due-overdue  { color: var(--brand-crimson); }
.fs-step-due-done     { color: #2e7d32; }
.fs-step-cadence      { color: var(--brand-navy); }
.fs-step-template {
    color: var(--brand-navy);
    font-weight: 600;
    text-decoration: none;
}
.fs-step-template:hover { text-decoration: underline; }
.fs-step-actioned-at {
    color: #5b6b7f;
    font-style: italic;
}

.fs-step-notes {
    margin-top: .6rem;
    font-size: .85rem;
}
.fs-step-notes summary {
    cursor: pointer;
    color: var(--brand-navy);
    font-weight: 600;
    user-select: none;
}
.fs-step-notes textarea {
    display: block;
    width: 100%;
    margin-top: .5rem;
    min-height: 72px;
    padding: .55rem .7rem;
    border-radius: 6px;
    border: 1px solid #d8dee9;
    background: #fff;
    font-family: inherit;
    font-size: .9rem;
    line-height: 1.55;
    resize: vertical;
}
.fs-step-notes-save {
    margin-top: .5rem;
    padding: .35rem .85rem;
    border-radius: 6px;
    border: 1px solid var(--brand-navy);
    background: var(--brand-navy);
    color: #fff;
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
}
.fs-step-notes-save:hover { background: #001f4d; }

/* ── Cohorts (Phase 5) ───────────────────────────────────────────────── */
.fs-cohort-toolbar { margin-bottom: 1.5rem; }
.fs-cohort-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1rem;
}
.fs-cohort-card {
    padding: 1.3rem;
    border-radius: 10px;
    border: 1px solid #e1e6ee;
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
    display: flex;
    flex-direction: column;
    gap: .6rem;
}
.fs-cohort-card-header {
    display: flex;
    justify-content: space-between;
    gap: .8rem;
    align-items: flex-start;
}
.fs-cohort-card-header h3 { margin: 0; font-size: 1.05rem; }
.fs-cohort-card-header h3 a { color: var(--brand-navy); text-decoration: none; }
.fs-cohort-card-header h3 a:hover { text-decoration: underline; }
.fs-cohort-card-meta { margin: .2rem 0 0; color: #5b6b7f; font-size: .85rem; }
.fs-cohort-status-badge {
    padding: .25rem .65rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    white-space: nowrap;
}
.fs-cohort-status-active { background: #e6f4ea; color: #2e7d32; }
.fs-cohort-status-ended  { background: #f4dde0; color: var(--brand-crimson); }
.fs-cohort-card-invite { margin: 0; font-size: .9rem; color: #374151; }
.fs-cohort-card-invite code {
    background: #f4f6fa;
    padding: .15rem .45rem;
    border-radius: 4px;
    font-family: monospace;
    letter-spacing: .05em;
}
.fs-cohort-card-actions { margin-top: auto; }
.fs-cohort-new-form { max-width: 640px; }
.fs-cohort-new-form .form-group { margin-bottom: 1rem; }
.fs-cohort-new-form label { display: block; font-weight: 600; color: var(--brand-navy); margin-bottom: .3rem; }
.fs-cohort-new-form input[type="text"],
.fs-cohort-new-form input[type="url"],
.fs-cohort-new-form input[type="number"] {
    width: 100%;
    padding: .65rem .85rem;
    border-radius: 6px;
    border: 1px solid #d8dee9;
    font-size: .95rem;
}
.fs-cohort-new-form .field-hint { display: block; color: #5b6b7f; font-size: .82rem; margin-top: .3rem; }
.fs-cohort-new-form .checkbox-label { display: flex; align-items: center; gap: .55rem; font-weight: 600; }
.fs-cohort-detail-actions { margin-top: 1rem; }
.fs-cohort-detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
    margin-bottom: 2rem;
}
@media (max-width: 720px) { .fs-cohort-detail-grid { grid-template-columns: 1fr; } }
.fs-cohort-invite-block,
.fs-cohort-roster-upload {
    padding: 1.3rem;
    border-radius: 10px;
    border: 1px solid #e1e6ee;
    background: #fff;
}
.fs-cohort-invite-block h3,
.fs-cohort-roster-upload h3 {
    margin: 0 0 .5rem;
    color: var(--brand-navy);
    font-size: 1.05rem;
}
.fs-cohort-invite-pill {
    display: inline-block;
    margin: .25rem 0 .8rem;
    padding: .55rem 1rem;
    background: #f4f6fa;
    border: 1px solid #d8dee9;
    border-radius: 6px;
    font-family: monospace;
    font-size: 1.05rem;
    letter-spacing: .08em;
    font-weight: 700;
    color: var(--brand-navy);
}
.fs-cohort-invite-link { font-size: .85rem; color: #5b6b7f; margin: 0; }
.fs-cohort-invite-link code { background: #f4f6fa; padding: 1px 4px; border-radius: 3px; }
.fs-cohort-roster-upload input[type="file"] {
    display: block;
    margin: .5rem 0 1rem;
}
.fs-cohort-upload-result {
    margin-top: .8rem;
    padding: .7rem .9rem;
    background: #f4f6fa;
    border-radius: 6px;
    font-size: .9rem;
    color: #374151;
}
.fs-cohort-members-heading { color: var(--brand-navy); margin: 1.5rem 0 .8rem; }
.fs-cohort-members-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border: 1px solid #e1e6ee;
    border-radius: 10px;
    overflow: hidden;
    font-size: .9rem;
}
.fs-cohort-members-table th,
.fs-cohort-members-table td {
    padding: .65rem .8rem;
    text-align: left;
    border-bottom: 1px solid #eef1f7;
}
.fs-cohort-members-table th {
    background: #f4f6fa;
    color: var(--brand-navy);
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.fs-cohort-member-alumni { color: #5b6b7f; background: #fbfbfd; }
.fs-cohort-member-btn {
    padding: .3rem .65rem;
    border-radius: 5px;
    border: 1px solid var(--brand-navy);
    background: #fff;
    color: var(--brand-navy);
    font-size: .82rem;
    cursor: pointer;
}
.fs-cohort-member-btn:hover { background: var(--brand-navy); color: #fff; }

/* ── Staff enrollment (ANO / PRCN institutional, Phase 6) ─────────────── */
.fs-staff-grid {
    display: grid;
    grid-template-columns: minmax(0, 420px) 1fr;
    gap: 2rem;
}
@media (max-width: 820px) { .fs-staff-grid { grid-template-columns: 1fr; } }
.fs-staff-form .form-group { margin-bottom: 1rem; }
.fs-staff-form label { display: block; font-weight: 600; color: var(--brand-navy); margin-bottom: .3rem; }
.fs-staff-form input[type="text"],
.fs-staff-form input[type="email"],
.fs-staff-form select,
.fs-staff-form textarea {
    width: 100%;
    padding: .6rem .8rem;
    border-radius: 6px;
    border: 1px solid #d8dee9;
    font-size: .95rem;
    font-family: inherit;
}
.fs-staff-form .form-group-checkbox {
    display: flex;
    gap: .55rem;
    align-items: flex-start;
    margin-bottom: 1rem;
}
.fs-staff-form .field-hint { font-size: .82rem; color: #5b6b7f; margin-top: .3rem; }
.fs-staff-form-result {
    margin-top: 1rem;
    padding: .9rem 1rem;
    border-radius: 6px;
    font-size: .9rem;
    line-height: 1.55;
}
.fs-staff-form-pending  { background: #f4f6fa; color: #374151; }
.fs-staff-form-success  { background: #e6f4ea; color: #2e7d32; border-left: 4px solid #2e7d32; }
.fs-staff-form-error    { background: #f4dde0; color: var(--brand-crimson); border-left: 4px solid var(--brand-crimson); }
.fs-staff-invite-url {
    display: block;
    margin-top: .6rem;
    padding: .55rem .75rem;
    background: #fff;
    border: 1px solid #d8dee9;
    border-radius: 4px;
    font-family: monospace;
    font-size: .82rem;
    word-break: break-all;
}
.fs-staff-copy-btn {
    margin-top: .5rem;
    padding: .35rem .85rem;
    border-radius: 5px;
    border: 1px solid var(--brand-navy);
    background: #fff;
    color: var(--brand-navy);
    font-weight: 600;
    font-size: .82rem;
    cursor: pointer;
}
.fs-staff-copy-btn:hover { background: var(--brand-navy); color: #fff; }
.fs-staff-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border: 1px solid #e1e6ee;
    border-radius: 10px;
    overflow: hidden;
    font-size: .9rem;
}
.fs-staff-table th,
.fs-staff-table td {
    padding: .65rem .8rem;
    text-align: left;
    border-bottom: 1px solid #eef1f7;
}
.fs-staff-table th {
    background: #f4f6fa;
    color: var(--brand-navy);
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.fs-staff-row-pending_first_login { background: #fffbeb; }
.fs-staff-row-withdrawn,
.fs-staff-row-completed { color: #5b6b7f; background: #fbfbfd; }
.fs-staff-status {
    padding: .15rem .55rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    white-space: nowrap;
}
.fs-staff-status-pending_first_login { background: #fff7e6; color: #8b5a00; }
.fs-staff-status-active              { background: #e6f4ea; color: #2e7d32; }
.fs-staff-status-completed           { background: #e1ecf7; color: var(--brand-navy); }
.fs-staff-status-withdrawn           { background: #f4dde0; color: var(--brand-crimson); }

/* ── How-it-works ───────────────────────────────────────────────────────── */
.b2b-howitworks {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 18px;
}
.b2b-howitworks li {
    background: rgba(255,255,255,.06);
    border-radius: 10px;
    padding: 18px 20px;
    border-left: 3px solid var(--brand-sky-light, #A9CFE8);
}
.b2b-howitworks h4 {
    color: #fff;
    font-size: 1rem;
    margin: 0 0 .4rem;
}
.b2b-howitworks p {
    margin: 0;
    font-size: 0.92rem;
    color: rgba(255,255,255,.85);
    line-height: 1.55;
}

/* ── CTA band ───────────────────────────────────────────────────────────── */
.b2b-cta-band {
    background: var(--brand-crimson);
    color: #fff;
    text-align: center;
}
.b2b-cta-band h2 { color: #fff; margin: 0 0 .6rem; }
.b2b-cta-band p { color: rgba(255,255,255,.92); max-width: 640px; margin: 0 auto 1.5rem; }
.b2b-cta-band .btn-register {
    background: #fff;
    color: var(--brand-crimson);
    border-color: #fff;
}
.b2b-cta-band .btn-register:hover {
    background: var(--brand-navy);
    color: #fff;
    border-color: var(--brand-navy);
}

/* ── Contact form layout ────────────────────────────────────────────────── */
.b2b-contact-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 32px;
}
.b2b-contact-form {
    background: #fff;
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 4px 16px rgba(0,0,0,.08);
}
.b2b-form-row { margin-bottom: 1.1rem; }
.b2b-form-row label,
.b2b-form-row legend {
    display: block;
    font-weight: 600;
    color: var(--brand-navy);
    margin-bottom: .35rem;
    font-size: 0.95rem;
}
.b2b-form-row .req { color: var(--brand-crimson); }
.b2b-form-row input,
.b2b-form-row select,
.b2b-form-row textarea {
    width: 100%;
    padding: 0.6rem 0.85rem;
    border: 1px solid #ccd0d6;
    border-radius: 6px;
    font-family: inherit;
    font-size: 0.95rem;
    background: #fff;
    color: var(--dark-gray, #1f2937);
}
.b2b-form-row input:focus,
.b2b-form-row select:focus,
.b2b-form-row textarea:focus {
    outline: 2px solid var(--brand-navy);
    outline-offset: 1px;
    border-color: var(--brand-navy);
}
.b2b-form-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.b2b-form-row fieldset { border: 0; padding: 0; margin: 0; }
.b2b-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0.3rem 0.85rem 0.3rem 0;
    font-weight: 500;
    color: var(--dark-gray, #1f2937);
    font-size: 0.92rem;
}
.b2b-checkbox input { width: auto; }

.b2b-contact-aside {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.b2b-aside-card {
    background: #fff;
    border-radius: 10px;
    padding: 18px;
    box-shadow: 0 2px 6px rgba(0,0,0,.05);
    border-top: 3px solid var(--brand-sky, #6AAAD7);
}
.b2b-aside-card h3 {
    font-size: 1rem;
    color: var(--brand-navy);
    margin: 0 0 .4rem;
}
.b2b-aside-card h3 i { color: var(--brand-crimson); margin-right: 0.4rem; }
.b2b-aside-card p {
    margin: 0;
    font-size: 0.92rem;
    color: var(--text-gray, #5b6b7f);
    line-height: 1.55;
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .b2b-stat-row { grid-template-columns: 1fr; }
    .b2b-grid-3 { grid-template-columns: 1fr; }
    .b2b-grid-2 { grid-template-columns: 1fr; }
    .b2b-form-grid-2 { grid-template-columns: 1fr; }
    .b2b-contact-grid { grid-template-columns: 1fr; }
    .b2b-hero h1 { font-size: 1.85rem; }
    .b2b-service { grid-template-columns: 1fr; }
    .b2b-service-num { margin-bottom: 0.5rem; }
}
