/**
 * Kenii Pathways — Frontend Styles
 *
 * Styles for all blocks and templates.
 * Uses Kenii brand tokens via CSS custom properties.
 * Mobile-first responsive. BEM naming convention.
 */

/* ─── Tokens ──────────────────────────────────────────────────── */
/* All tokens come from Catalog's --kenii-* system. No aliases. */

/* ─── Page Layout ─────────────────────────────────────────────── */

.kp-page {
    font-family: var(--kenii-body-font);
    color: var(--kenii-text);
}

.kp-page__header {
    background: var(--kenii-accent);
    color: white;
    padding: 48px 0;
}

.kp-page__header--compass {
    background: linear-gradient(135deg, var(--kenii-primary) 0%, var(--kenii-primary-dark) 100%);
}

.kp-page__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px;
}

.kp-page__container--narrow {
    max-width: 960px;
}

.kp-page__title {
    font-family: var(--kenii-heading-font);
    font-size: 48px;
    font-weight: 500;
    line-height: 1.1;
    margin: 0 0 8px 0;
}

.kp-page__subtitle {
    font-size: 18px;
    line-height: 1.5;
    opacity: 0.85;
    margin: 0;
}

.kp-page__body {
    padding: 48px 0 64px;
}

.kp-page__cta-section {
    padding: 0 0 64px;
}

/* ─── Breadcrumbs ─────────────────────────────────────────────── */

.kp-breadcrumbs {
    font-size: 14px;
    margin-bottom: 16px;
}

.kp-breadcrumbs a {
    color: inherit;
    opacity: 0.7;
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.kp-breadcrumbs a:hover {
    opacity: 1;
}

.kp-breadcrumbs__sep {
    margin: 0 8px;
    opacity: 0.5;
}

/* ─── Career Communities ──────────────────────────────────────── */

.kp-career-communities__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.kp-career-communities__grid--full {
    grid-template-columns: repeat(3, 1fr);
}

.kp-career-communities[data-columns="2"] .kp-career-communities__grid {
    grid-template-columns: repeat(2, 1fr);
}

.kp-career-communities[data-columns="4"] .kp-career-communities__grid {
    grid-template-columns: repeat(4, 1fr);
}

.kp-community-card {
    display: flex;
    flex-direction: column;
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    overflow: hidden;
    text-decoration: none;
    color: var(--kenii-text);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.kp-community-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--kenii-shadow-lg);
}

.kp-community-card__image {
    position: relative;
    height: 180px;
    overflow: hidden;
}

.kp-community-card--large .kp-community-card__image {
    height: 220px;
}

.kp-community-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.kp-community-card:hover .kp-community-card__image img {
    transform: scale(1.05);
}

.kp-community-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.4) 100%);
}

.kp-community-card__image--placeholder {
    background: var(--community-color, var(--kenii-primary));
    display: flex;
    align-items: center;
    justify-content: center;
}

.kp-community-card__icon {
    font-size: 48px;
    color: white;
    opacity: 0.8;
}

.kp-community-card__content {
    padding: 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.kp-community-card__title {
    font-family: var(--kenii-heading-font);
    font-size: 20px;
    font-weight: 500;
    line-height: 1.3;
    margin: 0 0 8px 0;
    color: var(--kenii-text);
}

.kp-community-card__desc {
    font-size: 14px;
    line-height: 1.5;
    color: var(--kenii-text-muted);
    margin: 0 0 auto 0;
}

.kp-community-card__count {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: var(--community-color, var(--kenii-primary));
    margin-top: 12px;
}

/* ─── Program Map ─────────────────────────────────────────────── */

.kp-program-map {
    max-width: 900px;
}

.kp-program-map__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--kenii-border);
}

.kp-program-map__badge {
    display: inline-block;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: var(--kenii-primary);
    background: color-mix(in srgb, var(--kenii-primary) 8%, transparent);
    padding: 4px 10px;
    border-radius: var(--kenii-radius);
    margin-bottom: 8px;
}

.kp-program-map__title {
    font-family: var(--kenii-heading-font);
    font-size: 32px;
    font-weight: 500;
    line-height: 1.2;
    margin: 0 0 4px 0;
}

.kp-program-map__program {
    font-size: 14px;
    color: var(--kenii-text-muted);
    margin: 0;
}

.kp-program-map__program a {
    color: var(--kenii-primary);
    text-decoration: none;
}

.kp-program-map__program a:hover {
    text-decoration: underline;
}

.kp-program-map__quick-stats {
    display: flex;
    gap: 24px;
    flex-shrink: 0;
}

.kp-program-map__stat {
    text-align: center;
}

.kp-program-map__stat-value {
    display: block;
    font-size: 24px;
    font-weight: 700;
    color: var(--kenii-primary);
    line-height: 1;
}

.kp-program-map__stat-label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--kenii-text-muted);
    margin-top: 4px;
}

.kp-program-map__ccp-badge {
    background: #ecfdf5;
    border: 1px solid #a7f3d0;
    border-radius: var(--kenii-radius);
    padding: 12px 16px;
    font-size: 14px;
    color: #064E3B;
    margin-bottom: 24px;
}

/* Pace Toggle */

.kp-program-map__pace-toggle {
    display: flex;
    gap: 0;
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    overflow: hidden;
    width: fit-content;
}

.kp-pace-btn {
    padding: 10px 24px;
    min-height: 44px;
    font-size: 14px;
    font-weight: 600;
    border: none;
    background: var(--kenii-white);
    color: var(--kenii-text-muted);
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
}

.kp-pace-btn--active {
    background: var(--kenii-primary);
    color: white;
}

.kp-pace-btn:hover:not(.kp-pace-btn--active) {
    background: var(--kenii-neutral-lightest);
}

/* Semester Cards */

.kp-program-map__semesters {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 40px;
}

.kp-semester {
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    overflow: hidden;
}

.kp-semester__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    background: var(--kenii-neutral-lightest);
    border-bottom: 1px solid var(--kenii-border);
}

.kp-semester__label {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
    color: var(--kenii-text);
}

.kp-semester__credits {
    font-size: 13px;
    font-weight: 600;
    color: var(--kenii-primary);
}

.kp-semester__milestones {
    padding: 8px 20px;
    background: #fffbeb;
    border-bottom: 1px solid #fef3c7;
}

.kp-milestone {
    display: inline-block;
    font-size: 12px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: var(--kenii-radius);
    background: #fef3c7;
    color: #92400e;
}

.kp-milestone--checkpoint {
    background: #dbeafe;
    color: #1e40af;
}

.kp-semester__courses {
    width: 100%;
    border-collapse: collapse;
}

.kp-semester__courses thead th {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--kenii-text-muted);
    padding: 8px 20px;
    text-align: left;
    border-bottom: 1px solid var(--kenii-border);
}

.kp-semester__th-credits {
    text-align: center !important;
    width: 60px;
}

.kp-course-row td {
    padding: 10px 20px;
    font-size: 14px;
    border-bottom: 1px solid var(--kenii-border);
}

.kp-course-row:last-child td {
    border-bottom: none;
}

.kp-course-row__code {
    font-weight: 600;
    white-space: nowrap;
    width: 100px;
}

.kp-course-row__credits {
    text-align: center;
    width: 60px;
    color: var(--kenii-text-muted);
}

.kp-course-link {
    color: var(--kenii-primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

.kp-course-link:hover {
    color: var(--kenii-primary-dark);
    text-decoration: underline;
}

.kp-semester__connector {
    display: flex;
    justify-content: center;
    padding: 8px 0;
    color: var(--kenii-border);
}

/* Sections */

.kp-program-map__section {
    margin-bottom: 32px;
}

.kp-program-map__section-title {
    font-family: var(--kenii-heading-font);
    font-size: 24px;
    font-weight: 500;
    margin: 0 0 16px 0;
}

/* Career Cards */

.kp-career-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 16px;
}

.kp-career-card {
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    padding: 20px;
}

.kp-career-card__soc {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--kenii-text-muted);
    margin-bottom: 12px;
    display: block;
}

.kp-career-card__salary,
.kp-career-card__growth {
    margin-bottom: 8px;
}

.kp-career-card__value {
    font-size: 24px;
    font-weight: 700;
    display: block;
    line-height: 1.2;
}

.kp-career-card__value--positive {
    color: var(--kenii-success);
}

.kp-career-card__value--negative {
    color: var(--kenii-error, #ef4444);
}

.kp-career-card__label {
    font-size: 12px;
    color: var(--kenii-text-muted);
}

.kp-career-card__year {
    font-size: 11px;
    color: var(--kenii-text-muted);
    font-style: italic;
}

/* Transfer */

.kp-transfer-list {
    display: grid;
    gap: 12px;
}

.kp-transfer-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 20px;
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
}

.kp-transfer-item__institution {
    font-weight: 700;
    font-size: 15px;
    min-width: 160px;
}

.kp-transfer-item__program {
    flex: 1;
    font-size: 14px;
    color: var(--kenii-text-muted);
}

.kp-transfer-item__link {
    font-size: 13px;
    font-weight: 600;
    color: var(--kenii-primary);
    text-decoration: none;
    white-space: nowrap;
}

.kp-transfer-item__link:hover {
    text-decoration: underline;
}

/* Learning Outcomes */

.kp-outcomes-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 8px;
}

.kp-outcomes-list__item {
    padding: 12px 16px 12px 40px;
    background: var(--kenii-neutral-lightest);
    border-radius: var(--kenii-radius);
    font-size: 14px;
    line-height: 1.5;
    position: relative;
}

.kp-outcomes-list__item::before {
    content: '';
    position: absolute;
    left: 16px;
    top: 18px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--kenii-primary);
}

/* Cost Breakdown */

.kp-cost-breakdown {
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    overflow: hidden;
}

.kp-cost-row {
    display: flex;
    justify-content: space-between;
    padding: 12px 20px;
    font-size: 14px;
    border-bottom: 1px solid var(--kenii-border);
}

.kp-cost-row:last-of-type {
    border-bottom: none;
}

.kp-cost-row--total {
    font-weight: 700;
    font-size: 16px;
    background: var(--kenii-neutral-lightest);
    color: var(--kenii-primary);
}

.kp-cost-note {
    padding: 12px 20px;
    font-size: 12px;
    color: var(--kenii-text-muted);
    margin: 0;
    border-top: 1px solid var(--kenii-border);
    font-style: italic;
}

/* ─── CTA ─────────────────────────────────────────────────────── */

.kp-program-map__cta {
    margin-top: 32px;
}

.kp-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    background: var(--kenii-primary);
    color: white;
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--kenii-radius);
    border: none;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.25s ease, box-shadow 0.25s ease;
}

.kp-cta-btn:hover {
    background: var(--kenii-primary-dark);
    transform: translateY(-2px);
    box-shadow: 0px 8px 16px color-mix(in srgb, var(--kenii-primary) 30%, transparent);
}

.kp-cta-btn__icon {
    width: 11px;
    height: 20px;
    flex-shrink: 0;
}

.kp-cta-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    background: var(--kenii-accent);
    color: white;
    padding: 40px 48px;
    border-radius: var(--kenii-radius);
}

.kp-cta-banner__title {
    font-family: var(--kenii-heading-font);
    font-size: 24px;
    font-weight: 500;
    margin: 0 0 4px 0;
}

.kp-cta-banner__desc {
    font-size: 16px;
    opacity: 0.8;
    margin: 0;
}

.kp-cta-btn--banner {
    flex-shrink: 0;
}

.kp-cta-inline {
    text-align: center;
    padding: 24px;
}

/* ─── Compass Explorer ────────────────────────────────────────── */

.kp-compass {
    max-width: 800px;
    margin: 0 auto;
}

.kp-compass__progress {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 48px;
}

.kp-compass__step {
    display: flex;
    align-items: center;
    gap: 8px;
    opacity: 0.3;
    transition: opacity 0.3s ease;
}

.kp-compass__step--active {
    opacity: 1;
}

.kp-compass__step--completed {
    opacity: 0.7;
}

.kp-compass__step-num {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--kenii-border);
    color: var(--kenii-text);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
}

.kp-compass__step--active .kp-compass__step-num {
    background: var(--kenii-primary);
    color: white;
}

.kp-compass__step-label {
    font-size: 14px;
    font-weight: 600;
}

.kp-compass__step-line {
    width: 48px;
    height: 2px;
    background: var(--kenii-border);
    margin: 0 12px;
}

.kp-compass__panel {
    display: none;
}

.kp-compass__panel--active {
    display: block;
}

.kp-compass__heading {
    font-family: var(--kenii-heading-font);
    font-size: 32px;
    font-weight: 500;
    text-align: center;
    margin: 0 0 8px 0;
}

.kp-compass__subheading {
    font-size: 16px;
    color: var(--kenii-text-muted);
    text-align: center;
    margin: 0 0 32px 0;
}

/* Interest Grid */

.kp-compass__interest-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.kp-compass__interest-tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 24px 16px;
    background: var(--kenii-white);
    border: 2px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.kp-compass__interest-tile:hover {
    border-color: var(--tile-color, var(--kenii-primary));
    background: color-mix(in srgb, var(--kenii-primary) 4%, transparent);
    transform: translateY(-2px);
}

.kp-compass__interest-tile--selected {
    border-color: var(--tile-color, var(--kenii-primary));
    background: color-mix(in srgb, var(--kenii-primary) 8%, transparent);
}

.kp-compass__interest-icon {
    font-size: 32px;
    margin-bottom: 8px;
}

.kp-compass__interest-name {
    font-size: 15px;
    font-weight: 700;
    display: block;
    margin-bottom: 4px;
}

.kp-compass__interest-count {
    font-size: 12px;
    color: var(--kenii-text-muted);
}

/* Goal Grid */

.kp-compass__goal-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.kp-compass__goal-card {
    padding: 24px;
    background: var(--kenii-white);
    border: 2px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    text-align: left;
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease;
}

.kp-compass__goal-card:hover {
    border-color: var(--kenii-primary);
    background: color-mix(in srgb, var(--kenii-primary) 4%, transparent);
}

.kp-compass__goal-title {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 8px 0;
}

.kp-compass__goal-desc {
    font-size: 14px;
    color: var(--kenii-text-muted);
    margin: 0;
    line-height: 1.5;
}

/* Pace Grid */

.kp-compass__pace-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    max-width: 500px;
    margin: 0 auto;
}

.kp-compass__pace-card {
    padding: 32px 24px;
    background: var(--kenii-white);
    border: 2px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease;
}

.kp-compass__pace-card:hover {
    border-color: var(--kenii-primary);
    background: color-mix(in srgb, var(--kenii-primary) 4%, transparent);
}

.kp-compass__pace-title {
    font-size: 20px;
    font-weight: 700;
    margin: 0 0 8px 0;
}

.kp-compass__pace-desc {
    font-size: 14px;
    color: var(--kenii-text-muted);
    margin: 0;
}

.kp-compass__back {
    display: block;
    margin: 24px auto 0;
    padding: 8px 24px;
    font-size: 14px;
    font-weight: 600;
    color: var(--kenii-text-muted);
    background: none;
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    cursor: pointer;
    transition: border-color 0.2s ease, color 0.2s ease;
}

.kp-compass__back:hover {
    border-color: var(--kenii-primary);
    color: var(--kenii-primary);
}

/* Compass Results */

.kp-compass__results {
    display: grid;
    gap: 16px;
}

.kp-result-card {
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    padding: 24px;
    transition: box-shadow 0.2s ease;
}

.kp-result-card:hover {
    box-shadow: var(--kenii-shadow-md);
}

.kp-result-card__title {
    font-family: var(--kenii-heading-font);
    font-size: 20px;
    font-weight: 500;
    margin: 0 0 4px 0;
}

.kp-result-card__title a {
    color: inherit;
    text-decoration: none;
}

.kp-result-card__title a:hover {
    color: var(--kenii-primary);
}

.kp-result-card__meta {
    display: flex;
    gap: 16px;
    margin-top: 12px;
    font-size: 13px;
    color: var(--kenii-text-muted);
}

.kp-result-card__meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

.kp-result-card__meta-value {
    font-weight: 700;
    color: var(--kenii-text);
}

.kp-result-card__compare {
    margin-top: 12px;
}

.kp-result-card__compare-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--kenii-text-muted);
    cursor: pointer;
}

/* ─── Program Comparison ──────────────────────────────────────── */

.kp-comparison__title {
    font-family: var(--kenii-heading-font);
    font-size: 28px;
    font-weight: 500;
    margin: 0 0 24px 0;
}

.kp-comparison__table {
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    overflow: hidden;
}

.kp-comparison__row {
    display: grid;
    grid-template-columns: 160px repeat(var(--col-count, 2), 1fr);
    border-bottom: 1px solid var(--kenii-border);
}

.kp-comparison[data-columns="2"] .kp-comparison__row {
    grid-template-columns: 160px 1fr 1fr;
}

.kp-comparison[data-columns="3"] .kp-comparison__row {
    grid-template-columns: 160px 1fr 1fr 1fr;
}

.kp-comparison__row:last-child {
    border-bottom: none;
}

.kp-comparison__row--header {
    background: var(--kenii-neutral-lightest);
}

.kp-comparison__label {
    padding: 12px 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--kenii-text-muted);
    display: flex;
    align-items: center;
    border-right: 1px solid var(--kenii-border);
}

.kp-comparison__cell {
    padding: 12px 16px;
    font-size: 14px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-right: 1px solid var(--kenii-border);
}

.kp-comparison__cell:last-child {
    border-right: none;
}

.kp-comparison__cred-title {
    font-weight: 700;
    font-size: 15px;
    color: var(--kenii-primary);
    text-decoration: none;
    margin-bottom: 4px;
}

.kp-comparison__cred-title:hover {
    text-decoration: underline;
}

.kp-comparison__cred-type {
    font-size: 12px;
    color: var(--kenii-text-muted);
}

.kp-comparison__cred-program {
    font-size: 12px;
    color: var(--kenii-text-muted);
}

.kp-comparison__shared {
    margin-top: 24px;
    padding: 20px;
    background: var(--kenii-neutral-lightest);
    border-radius: var(--kenii-radius);
}

.kp-comparison__shared-title {
    font-size: 16px;
    font-weight: 700;
    margin: 0 0 4px 0;
}

.kp-comparison__shared-desc {
    font-size: 14px;
    color: var(--kenii-text-muted);
    margin: 0 0 12px 0;
}

.kp-comparison__shared-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.kp-comparison__shared-code {
    display: inline-block;
    padding: 4px 10px;
    background: white;
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    font-size: 13px;
    font-weight: 600;
    font-family: monospace;
}

/* ─── Empty / Loading States ──────────────────────────────────── */

.kp-empty {
    text-align: center;
    padding: 32px;
    color: var(--kenii-text-muted);
    font-style: italic;
}

.kp-loading {
    text-align: center;
    padding: 48px;
    color: var(--kenii-text-muted);
}

/* ─── Responsive ──────────────────────────────────────────────── */

@media (max-width: 1024px) {
    .kp-page__title {
        font-size: 36px;
    }

    .kp-career-communities__grid,
    .kp-career-communities__grid--full {
        grid-template-columns: repeat(2, 1fr);
    }

    .kp-program-map__header {
        flex-direction: column;
    }

    .kp-compass__interest-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .kp-cta-banner {
        flex-direction: column;
        text-align: center;
        padding: 32px;
    }
}

@media (max-width: 768px) {
    .kp-page__container {
        padding: 0 16px;
    }

    .kp-page__title {
        font-size: 28px;
    }

    .kp-career-communities__grid,
    .kp-career-communities__grid--full {
        grid-template-columns: 1fr;
    }

    .kp-program-map__quick-stats {
        gap: 16px;
        grid-template-columns: 1fr 1fr;
        display: grid;
    }

    .kp-program-map__title {
        font-size: 24px;
    }

    .kp-program-map__header {
        flex-direction: column;
    }

    .kp-program-map__controls {
        flex-direction: column;
        gap: 12px;
    }

    /* Compass mobile */
    .kp-compass__heading {
        font-size: 24px;
    }

    .kp-compass__interest-grid {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .kp-compass__goal-grid {
        grid-template-columns: 1fr;
    }

    .kp-compass__goal-card {
        width: 100%;
    }

    .kp-compass__pace-grid {
        grid-template-columns: 1fr;
    }

    .kp-compass__pace-card {
        width: 100%;
    }

    .kp-compass__step-label {
        display: none;
    }

    .kp-result-card__meta {
        flex-direction: column;
        gap: 8px;
    }

    /* Program map mobile */
    .kp-semester__connector {
        display: none;
    }

    .kp-career-cards {
        grid-template-columns: 1fr;
    }

    .kp-transfer-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .kp-transfer-list {
        grid-template-columns: 1fr;
    }

    /* Comparison mobile — stacked layout */
    .kp-comparison__row {
        grid-template-columns: 1fr !important;
        gap: 0;
    }

    .kp-comparison__row--header {
        display: none;
    }

    .kp-comparison__label {
        border-right: none;
        border-bottom: 1px solid var(--kenii-border);
        font-size: 11px;
        font-weight: 700;
        padding: 8px 16px;
        background: var(--kenii-neutral-lightest);
    }

    .kp-comparison__cell {
        border-right: none;
        padding: 12px 16px;
        font-size: 14px;
        border-bottom: 1px solid var(--kenii-border);
    }

    .kp-comparison__cell:last-child {
        border-bottom: none;
    }

    .kp-comparison__shared {
        margin-top: 16px;
    }
}

@media (max-width: 480px) {
    .kp-page__header {
        padding: 32px 0;
    }

    .kp-page__title {
        font-size: 24px;
    }

    .kp-program-map__quick-stats {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .kp-compass__interest-grid {
        grid-template-columns: 1fr;
    }

    .kp-compass__interest-tile {
        padding: 16px;
    }

    .kp-compass__heading {
        font-size: 20px;
    }

    .kp-compass {
        padding: 0 8px;
    }

    .kp-semester__courses thead th {
        padding: 6px 12px;
    }

    .kp-course-row td {
        padding: 8px 12px;
        font-size: 13px;
    }

    .kp-semester__courses {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .kp-program-map {
        padding: 0 4px;
    }

    .kp-program-map__section {
        margin-bottom: 24px;
    }

    .kp-cost-row {
        padding: 10px 12px;
        font-size: 13px;
    }

    .kp-result-card {
        padding: 16px;
    }
}

/* ─── Print Header (hidden on screen) ────────────────────────── */

.kp-print-header {
    display: none;
}

/* ─── Print Button ───────────────────────────────────────────── */

.kp-program-map__controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 32px;
}

.kp-print-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    min-height: 44px;
    font-size: 14px;
    font-weight: 600;
    color: var(--kenii-text-muted);
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    cursor: pointer;
    transition: border-color 0.2s ease, color 0.2s ease;
}

.kp-print-btn:hover {
    border-color: var(--kenii-primary);
    color: var(--kenii-primary);
}

/* ─── Print Stylesheet ───────────────────────────────────────── */

@media print {
    /* Hide non-essential UI elements */
    .kp-program-map__pace-toggle,
    .kp-program-map__controls,
    .kp-program-map__cta,
    .kp-cta-btn,
    .kp-cta-banner,
    .kp-cta-inline,
    .kp-compare-bar,
    .kp-result-card__compare,
    .kp-print-btn,
    .site-header,
    .site-footer,
    #wpadminbar,
    .kp-program-map__actions,
    .kp-compass__back,
    .kp-breadcrumbs,
    nav,
    .kp-pace-toggle {
        display: none !important;
    }

    /* Full width layout */
    .kp-program-map {
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .kp-page__container {
        max-width: 100% !important;
        padding: 0 20px !important;
    }

    /* Show print header */
    .kp-print-header {
        display: block !important;
        padding: 24px 0;
        margin-bottom: 24px;
        border-bottom: 2px solid var(--kenii-text, #272a2b);
        text-align: center;
    }

    .kp-print-header__institution {
        font-family: var(--kenii-heading-font);
        font-size: 24px;
        font-weight: 500;
        margin-bottom: 4px;
    }

    .kp-print-header__title {
        font-size: 14px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1px;
        color: var(--kenii-text-muted, rgba(39, 42, 43, 0.7));
        margin-bottom: 8px;
    }

    .kp-print-header__credential {
        font-family: var(--kenii-heading-font);
        font-size: 20px;
        font-weight: 500;
        margin-bottom: 4px;
    }

    .kp-print-header__date {
        font-size: 12px;
        color: var(--kenii-text-muted, rgba(39, 42, 43, 0.7));
    }

    /* Force backgrounds to print */
    .kp-semester-card,
    .kp-semester,
    .kp-semester__header,
    .kp-career-card,
    .kp-program-map__badge,
    .kp-milestone {
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
    }

    /* Page break rules */
    .kp-semester {
        page-break-inside: avoid;
        break-inside: avoid;
    }

    .kp-career-card {
        page-break-inside: avoid;
        break-inside: avoid;
    }

    .kp-program-map__section {
        page-break-before: auto;
    }

    .kp-cost-breakdown {
        page-break-inside: avoid;
        break-inside: avoid;
    }

    .kp-transfer-item {
        page-break-inside: avoid;
        break-inside: avoid;
    }

    /* Clean up borders and shadows for print */
    .kp-semester,
    .kp-career-card,
    .kp-cost-breakdown,
    .kp-transfer-item {
        box-shadow: none !important;
        border: 1px solid #ccc !important;
    }

    /* Ensure links show URLs in print */
    .kp-course-link {
        color: #000 !important;
        text-decoration: underline !important;
    }

    /* Hide connector arrows in print */
    .kp-semester__connector,
    .kp-milestone-connector {
        display: none !important;
    }

    /* Print advisor card */
    .kp-advisor-card {
        box-shadow: none !important;
        border: 1px solid #ccc !important;
    }

    /* Print prerequisites */
    .kp-prerequisites__badge {
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
    }
}

/* ─── Prerequisites ─────────────────────────────────────────── */

.kp-prerequisites {
    margin-bottom: 32px;
}

.kp-prerequisites__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 8px;
}

.kp-prerequisites__item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 16px;
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
}

.kp-prerequisites__icon {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    margin-top: 2px;
}

.kp-prerequisites__icon--required {
    color: var(--kenii-success);
    background: rgba(16, 185, 129, 0.1);
}

.kp-prerequisites__icon--optional {
    color: var(--kenii-text-muted);
    background: var(--kenii-neutral-lightest);
}

.kp-prerequisites__content {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}

.kp-prerequisites__label {
    font-size: 15px;
    font-weight: 600;
    color: var(--kenii-text);
}

.kp-prerequisites__desc {
    font-size: 14px;
    color: var(--kenii-text-muted);
    line-height: 1.5;
}

.kp-prerequisites__badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 2px 8px;
    border-radius: var(--kenii-radius);
    background: color-mix(in srgb, var(--kenii-primary) 10%, transparent);
    color: var(--kenii-primary);
    width: fit-content;
}

.kp-prerequisites__badge--optional {
    background: var(--kenii-neutral-lightest);
    color: var(--kenii-text-muted);
}

/* ─── Milestone Connector Badges ────────────────────────────── */

.kp-milestone-connector {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 8px 0;
}

.kp-milestone-connector__line {
    width: 2px;
    height: 12px;
    background: var(--kenii-border);
}

.kp-milestone-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    background: color-mix(in srgb, var(--kenii-primary) 10%, transparent);
    color: var(--kenii-primary);
}

.kp-milestone-badge--checkpoint {
    background: #dbeafe;
    color: #1e40af;
}

.kp-milestone-badge--gateway {
    background: #fef3c7;
    color: #92400e;
}

.kp-milestone-badge--capstone {
    background: color-mix(in srgb, var(--kenii-primary) 12%, transparent);
    color: var(--kenii-primary);
}

.kp-milestone-badge svg {
    flex-shrink: 0;
}

/* ─── Advisor Card ──────────────────────────────────────────── */

.kp-advisor-card {
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    overflow: hidden;
}

.kp-advisor-card__header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    background: var(--kenii-neutral-lightest);
    border-bottom: 1px solid var(--kenii-border);
    color: var(--kenii-primary);
}

.kp-advisor-card__question {
    font-family: var(--kenii-heading-font);
    font-size: 18px;
    font-weight: 500;
    color: var(--kenii-text);
}

.kp-advisor-card__body {
    padding: 20px;
}

.kp-advisor-card__name {
    font-size: 18px;
    font-weight: 700;
    color: var(--kenii-text);
    margin-bottom: 2px;
}

.kp-advisor-card__title {
    font-size: 14px;
    color: var(--kenii-text-muted);
    margin-bottom: 12px;
}

.kp-advisor-card__contact {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.kp-advisor-card__link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--kenii-primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

.kp-advisor-card__link:hover {
    color: var(--kenii-primary-dark);
    text-decoration: underline;
}

.kp-advisor-card__link svg {
    flex-shrink: 0;
    color: var(--kenii-text-muted);
}

/* ─── CCP Pathway Map ────────────────────────────────────────── */

.kp-ccp-map {
    max-width: 900px;
}

.kp-ccp-map__header {
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--kenii-border);
}

.kp-ccp-map__badge {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: white;
    background: var(--kenii-primary);
    padding: 4px 12px;
    border-radius: var(--kenii-radius);
    margin-bottom: 10px;
}

.kp-ccp-map__title {
    font-family: var(--kenii-heading-font);
    font-size: 32px;
    font-weight: 500;
    line-height: 1.2;
    margin: 0 0 8px 0;
}

.kp-ccp-map__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    font-size: 14px;
    color: var(--kenii-text-muted);
}

.kp-ccp-map__meta-item {
    display: inline-flex;
    align-items: center;
}

.kp-ccp-map__meta-item + .kp-ccp-map__meta-item::before {
    content: '\2022';
    margin-right: 8px;
    color: var(--kenii-border);
}

.kp-ccp-map__meta-item a {
    color: var(--kenii-primary);
    text-decoration: none;
}

.kp-ccp-map__meta-item a:hover {
    text-decoration: underline;
}

/* Credential Chain */

.kp-ccp-map__chain {
    margin-bottom: 32px;
}

.kp-ccp-map__chain-track {
    display: flex;
    align-items: center;
    gap: 0;
    flex-wrap: wrap;
    padding: 16px 20px;
    background: var(--kenii-neutral-lightest);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
}

.kp-ccp-map__chain-item {
    display: flex;
    align-items: center;
    gap: 8px;
}

.kp-ccp-map__chain-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid var(--kenii-border);
    flex-shrink: 0;
    background: transparent;
}

.kp-ccp-map__chain-dot--filled {
    background: var(--kenii-primary);
    border-color: var(--kenii-primary);
}

.kp-ccp-map__chain-dot--certificate { border-color: #3b82f6; }
.kp-ccp-map__chain-dot--certificate.kp-ccp-map__chain-dot--filled { background: #3b82f6; }
.kp-ccp-map__chain-dot--diploma { border-color: #f59e0b; }
.kp-ccp-map__chain-dot--diploma.kp-ccp-map__chain-dot--filled { background: #f59e0b; }
.kp-ccp-map__chain-dot--associate { border-color: var(--kenii-primary); }
.kp-ccp-map__chain-dot--associate.kp-ccp-map__chain-dot--filled { background: var(--kenii-primary); }

.kp-ccp-map__chain-label {
    font-size: 14px;
    font-weight: 600;
    color: var(--kenii-text);
}

.kp-ccp-map__chain-arrow {
    display: inline-flex;
    align-items: center;
    margin: 0 12px;
    color: var(--kenii-border);
}

/* Grade Cards */

.kp-ccp-map__grades {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 40px;
}

.kp-ccp-map__grade-card {
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    overflow: hidden;
    background: var(--kenii-white);
}

.kp-ccp-map__grade-card--inactive {
    opacity: 0.75;
}

.kp-ccp-map__grade-card--active {
    border-color: color-mix(in srgb, var(--kenii-primary) 35%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--kenii-primary) 10%, transparent);
}

.kp-ccp-map__grade-card--post {
    border-color: var(--kenii-border);
    background: var(--kenii-neutral-lightest);
}

.kp-ccp-map__grade-header {
    padding: 14px 20px;
    border-bottom: 1px solid var(--kenii-border);
}

.kp-ccp-map__grade-card--active .kp-ccp-map__grade-header {
    background: color-mix(in srgb, var(--kenii-primary) 4%, transparent);
}

.kp-ccp-map__grade-card--inactive .kp-ccp-map__grade-header {
    background: var(--kenii-neutral-lightest);
}

.kp-ccp-map__grade-card--post .kp-ccp-map__grade-header {
    background: transparent;
}

.kp-ccp-map__grade-title {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
    color: var(--kenii-text);
}

.kp-ccp-map__grade-card--active .kp-ccp-map__grade-title {
    color: var(--kenii-primary);
}

.kp-ccp-map__grade-body {
    padding: 16px 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Semester within a grade */

.kp-ccp-map__semester {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.kp-ccp-map__semester + .kp-ccp-map__semester {
    padding-top: 16px;
    border-top: 1px solid var(--kenii-border);
}

.kp-ccp-map__semester-label {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--kenii-text-muted);
    margin-bottom: 2px;
}

/* Track rows (HS / CCP) */

.kp-ccp-map__hs-track,
.kp-ccp-map__ccp-track {
    display: flex;
    align-items: baseline;
    gap: 8px;
    font-size: 14px;
    line-height: 1.5;
}

.kp-ccp-map__track-label {
    font-weight: 700;
    color: var(--kenii-text);
    flex-shrink: 0;
    min-width: 32px;
}

.kp-ccp-map__track-courses {
    color: var(--kenii-text);
    flex: 1;
}

.kp-ccp-map__ccp-track--empty .kp-ccp-map__track-courses {
    color: var(--kenii-text-muted);
}

.kp-ccp-map__ccp-track .kp-course-link {
    color: var(--kenii-primary);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
}

.kp-ccp-map__ccp-track .kp-course-link:hover {
    color: var(--kenii-primary-dark);
    text-decoration: underline;
}

/* FREE badge */

.kp-ccp-map__free-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 700;
    color: #059669;
    background: #ecfdf5;
    padding: 2px 8px;
    border-radius: var(--kenii-radius);
    flex-shrink: 0;
    white-space: nowrap;
}

/* Cost Breakdown */

.kp-ccp-map__section {
    margin-bottom: 32px;
}

.kp-ccp-map__section-title {
    font-family: var(--kenii-heading-font);
    font-size: 24px;
    font-weight: 500;
    margin: 0 0 16px 0;
}

.kp-ccp-map__cost {
    background: var(--kenii-white);
    border: 1px solid var(--kenii-border);
    border-radius: var(--kenii-radius);
    overflow: hidden;
}

.kp-ccp-map__cost-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    font-size: 14px;
    border-bottom: 1px solid var(--kenii-border);
}

.kp-ccp-map__cost-row:last-of-type {
    border-bottom: none;
}

.kp-ccp-map__cost-row--total {
    font-weight: 700;
    font-size: 16px;
    background: var(--kenii-neutral-lightest);
    color: var(--kenii-primary);
}

.kp-ccp-map__cost-value {
    font-weight: 700;
}

.kp-ccp-map__cost-value--free {
    color: #059669;
}

.kp-ccp-map__cost-note {
    padding: 12px 20px;
    font-size: 12px;
    color: var(--kenii-text-muted);
    margin: 0;
    border-top: 1px solid var(--kenii-border);
    font-style: italic;
}

/* CTA */

.kp-ccp-map__cta {
    margin-top: 32px;
}

/* ─── CCP Responsive ─────────────────────────────────────────── */

@media (max-width: 768px) {
    .kp-ccp-map__title {
        font-size: 24px;
    }

    .kp-ccp-map__chain-track {
        gap: 8px;
        padding: 12px 16px;
    }

    .kp-ccp-map__chain-arrow {
        margin: 0 6px;
    }

    .kp-ccp-map__chain-label {
        font-size: 12px;
    }

    .kp-ccp-map__grade-body {
        padding: 12px 16px;
    }

    .kp-ccp-map__hs-track,
    .kp-ccp-map__ccp-track {
        flex-direction: column;
        gap: 2px;
    }

    .kp-ccp-map__track-label {
        min-width: auto;
    }

    .kp-ccp-map__cost-row {
        padding: 10px 16px;
        font-size: 13px;
    }
}

@media (max-width: 480px) {
    .kp-ccp-map__chain-track {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .kp-ccp-map__chain-arrow {
        transform: rotate(90deg);
        margin: 0;
    }

    .kp-ccp-map__meta {
        flex-direction: column;
        gap: 4px;
    }

    .kp-ccp-map__meta-item + .kp-ccp-map__meta-item::before {
        display: none;
    }

    .kp-ccp-map__grade-header {
        padding: 12px 16px;
    }

    .kp-ccp-map__grade-title {
        font-size: 15px;
    }

    .kp-ccp-map__section-title {
        font-size: 20px;
    }
}

@media (max-width: 768px) {
    .kp-milestone-connector {
        display: none;
    }

    .kp-advisor-card__header {
        padding: 12px 16px;
    }

    .kp-advisor-card__body {
        padding: 16px;
    }

    .kp-advisor-card__question {
        font-size: 16px;
    }
}


/* ================================================================
   KENII PATHWAYS SHORTCODES
   Styles for [kenii_career_communities], [kenii_compass],
   [kenii_ccp_pathways], [kenii_career_outcomes],
   [kenii_transfer_articulations] and hook-injected panels.

   Uses Catalog CSS custom properties with fallbacks.
   BEM naming: .kenii-{block}___{element}--{modifier}
   Responsive: 1200px / 1024px / 768px / 480px
   ================================================================ */

/* ─── Shortcode Token Layer ───────────────────────────────────── */

.kenii-career-communities,
.kenii-compass,
.kenii-ccp-grid,
.kenii-career-outcomes,
.kenii-transfer-list,
.kenii-ccp-intro,
.kenii-communities__cta-row,
.kenii-ccp-footer-strip {
    font-family: var(--kenii-body-font);
    font-size: var(--kenii-base-size, 18px);
    color: var(--kenii-text, #1A1A1A);
    line-height: 1.6;
    box-sizing: border-box;
}

/* ─── Shared Button System ────────────────────────────────────── */

.kenii-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    border-radius: var(--kenii-radius);
    font-family: var(--kenii-heading-font);
    font-size: 15px;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    border: 2px solid transparent;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
    white-space: nowrap;
}

.kenii-btn svg {
    width: 10px;
    height: 10px;
    flex-shrink: 0;
}

.kenii-btn--primary {
    background: var(--kenii-primary, #7C3AED);
    color: #FFFFFF;
    border-color: var(--kenii-primary, #7C3AED);
}

.kenii-btn--primary:hover,
.kenii-btn--primary:focus-visible {
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 88%, black);
    border-color: color-mix(in srgb, var(--kenii-primary, #7C3AED) 88%, black);
    box-shadow: 0 4px 12px color-mix(in srgb, var(--kenii-primary) 35%, transparent);
    transform: translateY(-1px);
    color: #FFFFFF;
}

.kenii-btn--white {
    background: #FFFFFF;
    color: var(--kenii-primary, #7C3AED);
    border-color: #FFFFFF;
}

.kenii-btn--white:hover,
.kenii-btn--white:focus-visible {
    background: #F3F0FF;
    transform: translateY(-1px);
}

.kenii-btn--outline {
    background: transparent;
    color: var(--kenii-primary, #7C3AED);
    border-color: var(--kenii-primary, #7C3AED);
}

.kenii-btn--outline:hover,
.kenii-btn--outline:focus-visible {
    background: var(--kenii-primary, #7C3AED);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.kenii-btn--ghost {
    background: transparent;
    color: var(--kenii-text-muted, #6B7280);
    border-color: var(--kenii-border, #E5E7EB);
}

.kenii-btn--ghost:hover,
.kenii-btn--ghost:focus-visible {
    background: var(--kenii-bg-alt, #F9FAFB);
    color: var(--kenii-text, #1A1A1A);
    border-color: var(--kenii-text-muted, #6B7280);
}

.kenii-btn--sm {
    padding: 8px 16px;
    font-size: 13px;
}

/* ─── Empty state ─────────────────────────────────────────────── */

.kenii-empty {
    color: var(--kenii-text-muted, #6B7280);
    font-size: 15px;
    padding: 32px 0;
    text-align: center;
}


/* ================================================================
   CAREER COMMUNITIES — [kenii_career_communities]
   ================================================================ */

/* Career Communities Intro */
.kenii-career-communities__intro {
    max-width: var(--kenii-max-width, 1200px);
    margin: 0 auto;
    padding: 40px 24px 0;
    text-align: center;
}

.kenii-career-communities__intro-title {
    font-family: var(--kenii-heading-font);
    font-size: 28px;
    font-weight: 800;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 16px;
}

.kenii-career-communities__intro-lead {
    font-size: 16px;
    color: var(--kenii-text-muted, #6B7280);
    max-width: 680px;
    margin: 0 auto 12px;
    line-height: 1.7;
}

.kenii-career-communities__intro-prompt {
    font-size: 14px;
    font-weight: 600;
    color: var(--kenii-text, #1A1A1A);
    margin: 0;
}

.kenii-career-communities {
    padding: 40px 0;
}

.kenii-career-communities--cols-1 { --kenii-cc-cols: 1; }
.kenii-career-communities--cols-2 { --kenii-cc-cols: 2; }
.kenii-career-communities--cols-3 { --kenii-cc-cols: 3; }
.kenii-career-communities--cols-4 { --kenii-cc-cols: 4; }

.kenii-career-communities {
    display: grid;
    grid-template-columns: repeat(var(--kenii-cc-cols, 3), 1fr);
    gap: 24px;
    max-width: var(--kenii-max-width, 1200px);
    margin: 0 auto;
    padding: 40px 24px;
}

/* Career Card */
.kenii-career-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    background: var(--kenii-card-bg, #FFFFFF);
    border: 1px solid var(--kenii-card-border, var(--kenii-border, #E5E7EB));
    border-radius: var(--kenii-radius);
    padding: 28px 24px;
    text-decoration: none;
    color: var(--kenii-text, #1A1A1A);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

.kenii-career-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: var(--kenii-community-accent, var(--kenii-primary, #7C3AED));
    opacity: 1;
    transition: opacity 0.2s ease;
}

.kenii-career-card:hover,
.kenii-career-card:focus-visible {
    transform: translateY(-2px);
    box-shadow: var(--kenii-shadow-md);
    border-color: var(--kenii-community-accent, var(--kenii-primary, #7C3AED));
    text-decoration: none;
    color: var(--kenii-text, #1A1A1A);
}

/* Icons removed — cards are text-only */
.kenii-career-card__icon {
    display: none;
}

.kenii-career-card__body {
    flex: 1;
    min-width: 0;
}

.kenii-career-card__title {
    font-family: var(--kenii-heading-font);
    font-size: 17px;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 6px;
    color: var(--kenii-text, #1A1A1A);
}

.kenii-career-card__desc {
    font-size: 13px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 0 0 6px;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.kenii-career-card__count {
    font-size: 12px;
    font-weight: 600;
    color: var(--kenii-primary, #7C3AED);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.kenii-career-card__salary {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--kenii-text-muted, #6B7280);
    margin-top: 4px;
}

.kenii-career-card__salary svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

.kenii-career-card__arrow {
    flex-shrink: 0;
    color: var(--kenii-text-muted, #6B7280);
    transition: color 0.2s ease, transform 0.2s ease;
}

.kenii-career-card__arrow svg {
    width: 16px;
    height: 16px;
}

.kenii-career-card:hover .kenii-career-card__arrow {
    color: var(--kenii-community-accent, var(--kenii-primary, #7C3AED));
    transform: translateX(4px);
}

/* Communities bottom CTA row */
.kenii-communities__cta-row {
    text-align: center;
    padding: 32px 24px 16px;
    grid-column: 1 / -1;
}


/* ================================================================
   COMPASS EXPLORER — [kenii_compass]
   3-step wizard
   ================================================================ */

.kenii-compass {
    max-width: 880px;
    margin: 0 auto;
    padding: 40px 24px 56px;
}

/* Step Indicator Bar */
.kenii-compass__steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 48px;
}

.kenii-compass__step-indicator {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.kenii-compass__step-num {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    font-weight: 700;
    border: 2px solid var(--kenii-border, #E5E7EB);
    background: var(--kenii-bg, #FFFFFF);
    color: var(--kenii-text-muted, #6B7280);
    transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.kenii-compass__step-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--kenii-text-muted, #6B7280);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: color 0.25s ease;
    white-space: nowrap;
}

.kenii-compass__step-connector {
    flex: 1;
    height: 2px;
    background: var(--kenii-border, #E5E7EB);
    max-width: 80px;
    margin-bottom: 24px;
    transition: background 0.25s ease;
}

/* Active step */
.kenii-compass__step-indicator--active .kenii-compass__step-num {
    background: var(--kenii-primary, #7C3AED);
    color: #FFFFFF;
    border-color: var(--kenii-primary, #7C3AED);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--kenii-primary, #7C3AED) 18%, transparent);
}

.kenii-compass__step-indicator--active .kenii-compass__step-label {
    color: var(--kenii-primary, #7C3AED);
}

/* Done step */
.kenii-compass__step-indicator--done .kenii-compass__step-num {
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 15%, transparent);
    color: var(--kenii-primary, #7C3AED);
    border-color: var(--kenii-primary, #7C3AED);
}

.kenii-compass__step-indicator--done .kenii-compass__step-label {
    color: var(--kenii-primary, #7C3AED);
}

/* Panel */
.kenii-compass__panel {
    animation: kenii-fade-in 0.25s ease;
}

@keyframes kenii-fade-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.kenii-compass__panel-header {
    text-align: center;
    margin-bottom: 36px;
}

.kenii-compass__panel-title {
    font-family: var(--kenii-heading-font);
    font-size: 26px;
    font-weight: 700;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 10px;
    line-height: 1.25;
}

.kenii-compass__panel-desc {
    font-size: 16px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 0;
    max-width: 540px;
    margin-left: auto;
    margin-right: auto;
}

/* Options grids */
.kenii-compass__options {
    display: grid;
    gap: 16px;
    margin-bottom: 32px;
}

.kenii-compass__options--communities {
    grid-template-columns: repeat(3, 1fr);
}

.kenii-compass__options--goals,
.kenii-compass__options--pace {
    grid-template-columns: repeat(2, 1fr);
}

/* Option button */
.kenii-compass__option {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 20px;
    background: var(--kenii-card-bg, #FFFFFF);
    border: 2px solid var(--kenii-border, #E5E7EB);
    border-radius: var(--kenii-radius);
    cursor: pointer;
    text-align: left;
    transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
    position: relative;
    color: var(--kenii-text, #1A1A1A);
    font-family: var(--kenii-body-font);
}

.kenii-compass__option:hover {
    border-color: var(--kenii-primary, #7C3AED);
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 4%, var(--kenii-bg, #FFFFFF));
    transform: translateY(-2px);
    box-shadow: 0 4px 12px color-mix(in srgb, var(--kenii-primary) 12%, transparent);
}

.kenii-compass__option--selected {
    border-color: var(--kenii-primary, #7C3AED);
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 8%, var(--kenii-bg, #FFFFFF));
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--kenii-primary, #7C3AED) 15%, transparent);
}

/* Icons removed from compass options */
.kenii-compass__option-icon {
    display: none;
}

.kenii-compass__option-label {
    font-size: 15px;
    font-weight: 700;
    line-height: 1.2;
    color: var(--kenii-text, #1A1A1A);
}

.kenii-compass__option-count,
.kenii-compass__option-meta {
    font-size: 13px;
    color: var(--kenii-text-muted, #6B7280);
    line-height: 1.4;
}

.kenii-compass__option-check {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--kenii-primary, #7C3AED);
    color: #FFFFFF;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(0.6);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.kenii-compass__option-check svg {
    width: 12px;
    height: 12px;
}

.kenii-compass__option--selected .kenii-compass__option-check {
    opacity: 1;
    transform: scale(1);
}

/* Panel footer */
.kenii-compass__panel-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    padding-top: 8px;
    border-top: 1px solid var(--kenii-border, #E5E7EB);
}

/* Results */
.kenii-compass__results {
    animation: kenii-fade-in 0.3s ease;
}

.kenii-compass__results-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 32px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--kenii-border, #E5E7EB);
    flex-wrap: wrap;
}

/* Results intro section */
.kenii-compass__results-intro {
    margin-bottom: 32px;
}

.kenii-compass__results-title {
    font-family: var(--kenii-heading-font);
    font-size: 28px;
    font-weight: 800;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 8px;
}

.kenii-compass__results-lead {
    font-size: 15px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 0 0 12px;
    line-height: 1.6;
}

.kenii-compass__results-lead strong {
    color: var(--kenii-primary, #7C3AED);
}

.kenii-compass__results-context {
    font-size: 14px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 0;
    line-height: 1.6;
}

.kenii-compass__results-actions {
    margin-bottom: 24px;
}

.kenii-compass__results-summary {
    font-size: 16px;
    color: var(--kenii-text, #1A1A1A);
}

.kenii-compass__results-summary strong {
    color: var(--kenii-primary, #7C3AED);
}

.kenii-compass__results-grid {
    display: flex;
    flex-direction: column;
    gap: 20px;
    max-width: 760px;
}

/* Result card */
.kenii-compass__result-card {
    background: var(--kenii-card-bg, #FFFFFF);
    border: 1px solid var(--kenii-card-border, var(--kenii-border, #E5E7EB));
    border-radius: 12px;
    padding: 32px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}

.kenii-compass__result-card:hover {
    box-shadow: var(--kenii-shadow-md);
    transform: translateY(-2px);
    border-color: var(--kenii-primary, #7C3AED);
    text-decoration: none;
    color: inherit;
}

.kenii-compass__result-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}

.kenii-compass__result-title {
    font-family: var(--kenii-heading-font);
    font-size: 20px;
    font-weight: 700;
    margin: 0;
    color: var(--kenii-text, #1A1A1A);
    line-height: 1.3;
}

.kenii-compass__result-cred-count {
    font-size: 12px;
    font-weight: 600;
    padding: 4px 12px;
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 8%, transparent);
    color: var(--kenii-primary, #7C3AED);
    border-radius: 100px;
    white-space: nowrap;
    flex-shrink: 0;
}

/* Credential list inside result card */
.kenii-compass__result-creds {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.kenii-compass__result-cred-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 10px 0;
    border-bottom: 1px solid var(--kenii-border-subtle, #F3F4F6);
}

.kenii-compass__result-cred-row:last-child {
    border-bottom: none;
}

.kenii-compass__result-cred-name {
    font-size: 15px;
    font-weight: 600;
    color: var(--kenii-text, #1A1A1A);
}

.kenii-compass__result-cred-meta {
    font-size: 14px;
    color: var(--kenii-text-muted, #6B7280);
    white-space: nowrap;
}

/* Career outcomes section */
.kenii-compass__result-careers {
    padding-top: 16px;
    border-top: 1px solid var(--kenii-border, #E5E7EB);
}

.kenii-compass__result-section-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--kenii-text-muted, #6B7280);
    margin-bottom: 12px;
}

.kenii-compass__result-career-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 8px 0;
}

.kenii-compass__result-career-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--kenii-text, #1A1A1A);
}

.kenii-compass__result-career-salary {
    font-size: 16px;
    font-weight: 700;
    color: var(--kenii-success, #10B981);
    white-space: nowrap;
}

/* Description */
.kenii-compass__result-desc {
    font-size: 14px;
    color: var(--kenii-text-muted, #6B7280);
    line-height: 1.7;
    margin: 0;
}

/* Legacy badge styles (kept for backward compat) */
.kenii-compass__cred-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.kenii-compass__cred-badge {
    font-size: 11px;
    font-weight: 600;
    padding: 3px 10px;
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 10%, transparent);
    color: var(--kenii-primary, #7C3AED);
    border-radius: 100px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.kenii-compass__result-footer {
    margin-top: auto;
    padding-top: 12px;
}

/* Loading spinner */
.kenii-compass__loading {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 48px 0;
    color: var(--kenii-text-muted, #6B7280);
    font-size: 15px;
}

.kenii-spinner {
    width: 36px;
    height: 36px;
    color: var(--kenii-primary, #7C3AED);
    animation: kenii-spin 0.8s linear infinite;
}

@keyframes kenii-spin {
    to { transform: rotate(360deg); }
}

.kenii-compass__no-results {
    grid-column: 1 / -1;
    text-align: center;
    color: var(--kenii-text-muted, #6B7280);
    padding: 40px 0;
}


/* ================================================================
   CCP PATHWAYS — [kenii_ccp_pathways]
   ================================================================ */

/* CCP Overview Section */
.kenii-ccp-overview {
    max-width: var(--kenii-max-width, 1200px);
    margin: 0 auto 48px;
    padding: 0 24px;
}

.kenii-ccp-overview__header {
    text-align: center;
    margin-bottom: 40px;
}

.kenii-ccp-overview__title {
    font-family: var(--kenii-heading-font);
    font-size: 28px;
    font-weight: 800;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 16px;
    line-height: 1.2;
}

.kenii-ccp-overview__lead {
    font-size: 16px;
    color: var(--kenii-text-muted, #6B7280);
    max-width: 720px;
    margin: 0 auto;
    line-height: 1.7;
}

.kenii-ccp-overview__highlights {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-bottom: 40px;
}

.kenii-ccp-highlight {
    text-align: center;
    padding: 32px 24px;
    background: var(--kenii-card-bg, #FFFFFF);
    border: 1px solid var(--kenii-border, #E5E7EB);
    border-radius: var(--kenii-radius);
}

.kenii-ccp-highlight__number {
    font-family: var(--kenii-heading-font);
    font-size: 36px;
    font-weight: 800;
    color: var(--kenii-primary, #7C3AED);
    margin-bottom: 4px;
}

.kenii-ccp-highlight__label {
    font-size: 14px;
    font-weight: 700;
    color: var(--kenii-text, #1A1A1A);
    margin-bottom: 8px;
}

.kenii-ccp-highlight__desc {
    font-size: 13px;
    color: var(--kenii-text-muted, #6B7280);
    line-height: 1.5;
}

.kenii-ccp-overview__details {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

.kenii-ccp-detail {
    padding: 28px;
    background: var(--kenii-bg-alt, #F9FAFB);
    border-radius: var(--kenii-radius);
}

.kenii-ccp-detail__title {
    font-family: var(--kenii-heading-font);
    font-size: 16px;
    font-weight: 700;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 8px;
}

.kenii-ccp-detail__text {
    font-size: 14px;
    color: var(--kenii-text-muted, #6B7280);
    line-height: 1.6;
    margin: 0;
}

/* Section heading before grid */
.kenii-ccp-section-heading {
    max-width: var(--kenii-max-width, 1200px);
    margin: 0 auto 24px;
    padding: 0 24px;
}

.kenii-ccp-section-heading__title {
    font-family: var(--kenii-heading-font);
    font-size: 22px;
    font-weight: 700;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 8px;
}

.kenii-ccp-section-heading__desc {
    font-size: 15px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 0;
    line-height: 1.6;
}

/* CCP Grid */
.kenii-ccp-grid {
    display: grid;
    gap: 24px;
    max-width: var(--kenii-max-width, 1200px);
    margin: 0 auto;
    padding: 0 24px;
}

.kenii-ccp-grid--cols-1 { grid-template-columns: 1fr; }
.kenii-ccp-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.kenii-ccp-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.kenii-ccp-grid--cols-4 { grid-template-columns: repeat(4, 1fr); }

/* CCP Card */
.kenii-ccp-card {
    background: var(--kenii-card-bg, #FFFFFF);
    border: 1px solid var(--kenii-card-border, var(--kenii-border, #E5E7EB));
    border-radius: var(--kenii-radius);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}

.kenii-ccp-card:hover {
    box-shadow: var(--kenii-shadow-md);
    transform: translateY(-2px);
    border-color: var(--kenii-primary, #7C3AED);
    text-decoration: none;
    color: inherit;
}

.kenii-ccp-card__header {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.kenii-ccp-card__badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    background: #10B981;
    color: #FFFFFF;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.1em;
    border-radius: 100px;
    text-transform: uppercase;
}

.kenii-ccp-card__community {
    font-size: 12px;
    font-weight: 600;
    color: var(--kenii-primary, #7C3AED);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.kenii-ccp-card__title {
    font-family: var(--kenii-heading-font);
    font-size: 18px;
    font-weight: 700;
    margin: 0;
    line-height: 1.3;
    color: var(--kenii-text, #1A1A1A);
}

.kenii-ccp-card__desc {
    font-size: 14px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 0;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.kenii-ccp-card__credentials {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding-top: 8px;
    border-top: 1px solid var(--kenii-border-subtle, #F3F4F6);
}

.kenii-ccp-card__cred-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 6px 0;
}

.kenii-ccp-card__cred-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--kenii-text, #1A1A1A);
}

.kenii-ccp-card__cred-credits {
    font-size: 12px;
    color: var(--kenii-text-muted, #6B7280);
    white-space: nowrap;
}

.kenii-ccp-card__footer {
    margin-top: auto;
    padding-top: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.kenii-ccp-card__link {
    font-size: 14px;
    font-weight: 600;
    color: var(--kenii-primary, #7C3AED);
}

.kenii-ccp-card__arrow {
    color: var(--kenii-text-muted, #6B7280);
    transition: transform 0.2s ease, color 0.2s ease;
}

.kenii-ccp-card__arrow svg {
    width: 14px;
    height: 14px;
}

.kenii-ccp-card:hover .kenii-ccp-card__arrow {
    transform: translateX(4px);
    color: var(--kenii-primary, #7C3AED);
}

/* CCP footer strip */
.kenii-ccp-footer-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    background: var(--kenii-bg-alt, #F9FAFB);
    border: 1px solid var(--kenii-border, #E5E7EB);
    border-radius: var(--kenii-radius);
    padding: 24px 32px;
    margin: 40px 24px 0;
    max-width: var(--kenii-max-width, 1200px);
    margin-left: auto;
    margin-right: auto;
    margin-top: 40px;
    flex-wrap: wrap;
}

.kenii-ccp-footer-strip__content {
    flex: 1;
}

.kenii-ccp-footer-strip__title {
    font-family: var(--kenii-heading-font);
    font-size: 18px;
    font-weight: 700;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 6px;
}

.kenii-ccp-footer-strip__text {
    font-size: 15px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 0;
    flex: 1;
    min-width: 200px;
}


/* ================================================================
   CAREER OUTCOMES — [kenii_career_outcomes]
   Embed panel — no hero/sidebar/CTA
   ================================================================ */

.kenii-career-outcomes {
    margin: 40px 0;
    padding: 32px;
    background: var(--kenii-bg-alt, #F9FAFB);
    border: 1px solid var(--kenii-border, #E5E7EB);
    border-radius: var(--kenii-radius);
}

.kenii-career-outcomes__heading {
    font-family: var(--kenii-heading-font);
    font-size: 22px;
    font-weight: 700;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 24px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--kenii-primary, #7C3AED);
    display: inline-block;
}

.kenii-career-outcomes__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
    margin-bottom: 20px;
}

/* Outcome card */
.kenii-career-outcomes__card {
    background: var(--kenii-card-bg, #FFFFFF);
    border: 1px solid var(--kenii-card-border, var(--kenii-border, #E5E7EB));
    border-radius: var(--kenii-radius);
    padding: 24px;
    box-shadow: var(--kenii-shadow, 0 1px 3px rgba(0,0,0,0.1));
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.kenii-career-outcomes__card-header {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.kenii-career-outcomes__soc {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--kenii-text-muted, #6B7280);
    font-family: monospace;
}

.kenii-career-outcomes__job-title {
    font-family: var(--kenii-heading-font);
    font-size: 17px;
    font-weight: 700;
    margin: 0;
    color: var(--kenii-text, #1A1A1A);
    line-height: 1.3;
}

.kenii-career-outcomes__stats {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.kenii-career-outcomes__stat {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.kenii-career-outcomes__stat-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 10%, transparent);
    color: var(--kenii-primary, #7C3AED);
    display: flex;
    align-items: center;
    justify-content: center;
}

.kenii-career-outcomes__stat-icon svg {
    width: 18px;
    height: 18px;
}

.kenii-career-outcomes__stat--growth.kenii-career-outcomes__stat--up .kenii-career-outcomes__stat-icon {
    background: color-mix(in srgb, #10B981 15%, transparent);
    color: #10B981;
}

.kenii-career-outcomes__stat--growth.kenii-career-outcomes__stat--down .kenii-career-outcomes__stat-icon {
    background: color-mix(in srgb, #EF4444 15%, transparent);
    color: #EF4444;
}

.kenii-career-outcomes__stat-label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--kenii-text-muted, #6B7280);
    margin-bottom: 2px;
}

.kenii-career-outcomes__stat-value {
    display: block;
    font-size: 20px;
    font-weight: 800;
    color: var(--kenii-text, #1A1A1A);
    line-height: 1;
}

.kenii-career-outcomes__stat--growth.kenii-career-outcomes__stat--up .kenii-career-outcomes__stat-value {
    color: #10B981;
}

.kenii-career-outcomes__stat--growth.kenii-career-outcomes__stat--down .kenii-career-outcomes__stat-value {
    color: #EF4444;
}

.kenii-career-outcomes__no-data {
    font-size: 14px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 0;
}

.kenii-career-outcomes__no-data a {
    color: var(--kenii-primary, #7C3AED);
}

.kenii-career-outcomes__source {
    font-size: 12px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 0;
}

.kenii-career-outcomes__source a {
    color: var(--kenii-primary, #7C3AED);
    text-decoration: none;
}

.kenii-career-outcomes__source a:hover {
    text-decoration: underline;
}


/* ================================================================
   TRANSFER ARTICULATIONS — [kenii_transfer_articulations]
   Embed panel — no hero/sidebar/CTA
   ================================================================ */

.kenii-transfer-list {
    margin: 40px 0;
    padding: 32px;
    background: var(--kenii-bg-alt, #F9FAFB);
    border: 1px solid var(--kenii-border, #E5E7EB);
    border-radius: var(--kenii-radius);
}

.kenii-transfer-list__heading {
    font-family: var(--kenii-heading-font);
    font-size: 22px;
    font-weight: 700;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 8px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--kenii-primary, #7C3AED);
    display: inline-block;
}

.kenii-transfer-list__intro {
    font-size: 15px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 12px 0 28px;
    line-height: 1.6;
}

.kenii-transfer-list__items {
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* Transfer item */
.kenii-transfer-list__item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 20px 0;
    border-bottom: 1px solid var(--kenii-border, #E5E7EB);
    transition: background 0.15s ease;
}

.kenii-transfer-list__item:last-child {
    border-bottom: none;
}

.kenii-transfer-list__item-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: var(--kenii-radius);
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 10%, transparent);
    color: var(--kenii-primary, #7C3AED);
    display: flex;
    align-items: center;
    justify-content: center;
}

.kenii-transfer-list__item-icon svg {
    width: 22px;
    height: 22px;
}

.kenii-transfer-list__item-body {
    flex: 1;
    min-width: 0;
}

.kenii-transfer-list__institution {
    font-size: 16px;
    font-weight: 700;
    color: var(--kenii-text, #1A1A1A);
    margin-bottom: 4px;
}

.kenii-transfer-list__institution-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--kenii-primary, #7C3AED);
    text-decoration: none;
    font-weight: 700;
    transition: color 0.2s ease;
}

.kenii-transfer-list__institution-link:hover {
    text-decoration: underline;
}

.kenii-transfer-list__institution-link svg {
    width: 12px;
    height: 12px;
    flex-shrink: 0;
}

.kenii-transfer-list__program {
    font-size: 14px;
    color: var(--kenii-text-muted, #6B7280);
    margin-bottom: 4px;
}

.kenii-transfer-list__notes {
    font-size: 13px;
    color: var(--kenii-text-muted, #6B7280);
    font-style: italic;
    margin-top: 4px;
}

.kenii-transfer-list__item-action {
    flex-shrink: 0;
    display: flex;
    align-items: center;
}


/* ================================================================
   COURSE TRANSFER TABLE — [kenii_course_transfers]
   Table-based display of transfer equivalencies from Catalog's
   kenii_articulation CPT. Injected via kenii_after_course_content.
   ================================================================ */

.kenii-transfer-table {
    margin: 40px 0;
    padding: 32px;
    background: var(--kenii-bg-alt, #F9FAFB);
    border: 1px solid var(--kenii-border, #E5E7EB);
    border-radius: var(--kenii-radius);
}

.kenii-transfer-table__heading {
    font-family: var(--kenii-heading-font);
    font-size: 22px;
    font-weight: 700;
    color: var(--kenii-text, #1A1A1A);
    margin: 0 0 8px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--kenii-primary, #7C3AED);
    display: inline-block;
}

.kenii-transfer-table__intro {
    font-size: 15px;
    color: var(--kenii-text-muted, #6B7280);
    margin: 12px 0 24px;
    line-height: 1.6;
}

.kenii-transfer-table__wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.kenii-transfer-table__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
    line-height: 1.5;
}

.kenii-transfer-table__table thead th {
    text-align: left;
    font-family: var(--kenii-heading-font);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--kenii-text-muted, #6B7280);
    padding: 12px 16px;
    border-bottom: 2px solid var(--kenii-border, #E5E7EB);
    white-space: nowrap;
}

.kenii-transfer-table__table tbody td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--kenii-border-subtle, #F3F4F6);
    color: var(--kenii-text, #1A1A1A);
    vertical-align: top;
}

.kenii-transfer-table__table tbody tr:last-child td {
    border-bottom: none;
}

.kenii-transfer-table__table tbody tr:hover {
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 3%, transparent);
}

.kenii-transfer-table__institution a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--kenii-primary, #7C3AED);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
}

.kenii-transfer-table__institution a:hover {
    text-decoration: underline;
}

.kenii-transfer-table__institution a svg {
    flex-shrink: 0;
    opacity: 0.6;
}

.kenii-transfer-table__course-code {
    font-weight: 600;
    color: var(--kenii-text, #1A1A1A);
}

.kenii-transfer-table__course-name {
    color: var(--kenii-text-muted, #6B7280);
}

.kenii-transfer-table__notes {
    display: block;
    font-size: 12px;
    color: var(--kenii-text-muted, #6B7280);
    font-style: italic;
    margin-top: 4px;
}

.kenii-transfer-table__credits {
    text-align: center;
    font-weight: 600;
}

.kenii-transfer-table__badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.05em;
    border-radius: var(--kenii-radius);
    background: color-mix(in srgb, var(--kenii-primary, #7C3AED) 10%, transparent);
    color: var(--kenii-primary, #7C3AED);
}

.kenii-transfer-table__badge--caa {
    background: color-mix(in srgb, var(--kenii-success, #10B981) 10%, transparent);
    color: var(--kenii-success, #10B981);
}

.kenii-transfer-table__badge--bilateral {
    background: color-mix(in srgb, var(--kenii-accent, #F59E0B) 10%, transparent);
    color: var(--kenii-accent, #F59E0B);
}


/* ================================================================
   CCP SIDEBAR BADGE (hook-injected into Catalog sidebar)
   ================================================================ */

.kenii-ccp-sidebar-badge {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px;
    background: color-mix(in srgb, #10B981 10%, transparent);
    border: 1px solid color-mix(in srgb, #10B981 35%, transparent);
    border-radius: var(--kenii-radius);
    margin-top: 16px;
}

.kenii-ccp-sidebar-badge__icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 6px;
    background: #10B981;
    color: #FFFFFF;
    display: flex;
    align-items: center;
    justify-content: center;
}

.kenii-ccp-sidebar-badge__icon svg {
    width: 18px;
    height: 18px;
}

.kenii-ccp-sidebar-badge__body {
    flex: 1;
    min-width: 0;
}

.kenii-ccp-sidebar-badge__label {
    display: block;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #065F46;
    margin-bottom: 4px;
}

.kenii-ccp-sidebar-badge__desc {
    display: block;
    font-size: 13px;
    color: #064E3B;
    line-height: 1.5;
    margin-bottom: 8px;
}

.kenii-ccp-sidebar-badge__link {
    font-size: 13px;
    font-weight: 600;
    color: #10B981;
    text-decoration: none;
    transition: color 0.2s ease;
}

.kenii-ccp-sidebar-badge__link:hover {
    color: #065F46;
    text-decoration: underline;
}


/* ================================================================
   RESPONSIVE — 1200px
   ================================================================ */

@media (max-width: 1200px) {
    .kenii-career-communities {
        grid-template-columns: repeat(2, 1fr);
    }

    .kenii-career-communities--cols-4 {
        grid-template-columns: repeat(3, 1fr);
    }

    .kenii-ccp-grid--cols-4 {
        grid-template-columns: repeat(3, 1fr);
    }

    .kenii-compass__options--communities {
        grid-template-columns: repeat(2, 1fr);
    }
}


/* ================================================================
   RESPONSIVE — 1024px
   ================================================================ */

@media (max-width: 1024px) {
    .kenii-compass {
        padding: 32px 20px 48px;
    }

    .kenii-compass__panel-title {
        font-size: 22px;
    }

    .kenii-compass__options--communities {
        grid-template-columns: repeat(2, 1fr);
    }

    .kenii-compass__results-grid {
        grid-template-columns: 1fr;
    }

    .kenii-ccp-grid--cols-3 {
        grid-template-columns: repeat(2, 1fr);
    }

    .kenii-ccp-grid--cols-4 {
        grid-template-columns: repeat(2, 1fr);
    }

    .kenii-career-outcomes__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}


/* ================================================================
   RESPONSIVE — 768px
   ================================================================ */

@media (max-width: 768px) {
    .kenii-career-communities {
        grid-template-columns: 1fr;
        padding: 24px 16px;
        gap: 16px;
    }

    .kenii-career-communities--cols-2,
    .kenii-career-communities--cols-3,
    .kenii-career-communities--cols-4 {
        grid-template-columns: 1fr;
    }

    .kenii-career-card {
        padding: 18px;
    }

    .kenii-compass {
        padding: 24px 16px 40px;
    }

    .kenii-compass__steps {
        margin-bottom: 32px;
        gap: 0;
    }

    .kenii-compass__step-label {
        display: none;
    }

    .kenii-compass__step-connector {
        max-width: 40px;
    }

    .kenii-compass__panel-header {
        margin-bottom: 24px;
    }

    .kenii-compass__panel-title {
        font-size: 20px;
    }

    .kenii-compass__panel-desc {
        font-size: 15px;
    }

    .kenii-compass__options--communities,
    .kenii-compass__options--goals,
    .kenii-compass__options--pace {
        grid-template-columns: 1fr;
    }

    .kenii-compass__option {
        flex-direction: row;
        align-items: center;
        padding: 16px;
    }

    .kenii-compass__option-icon {
        width: 36px;
        height: 36px;
    }

    .kenii-compass__option-icon svg {
        width: 18px;
        height: 18px;
    }

    .kenii-compass__option-count,
    .kenii-compass__option-meta {
        display: none;
    }

    .kenii-compass__panel-footer {
        flex-direction: column-reverse;
    }

    .kenii-compass__panel-footer .kenii-btn {
        width: 100%;
        justify-content: center;
    }

    .kenii-ccp-intro {
        flex-direction: column;
        padding: 20px;
    }

    .kenii-ccp-grid {
        padding: 0 16px;
    }

    .kenii-ccp-grid--cols-2,
    .kenii-ccp-grid--cols-3,
    .kenii-ccp-grid--cols-4 {
        grid-template-columns: 1fr;
    }

    .kenii-ccp-footer-strip {
        flex-direction: column;
        padding: 20px;
        text-align: center;
    }

    .kenii-career-outcomes {
        padding: 20px 16px;
    }

    .kenii-career-outcomes__grid {
        grid-template-columns: 1fr;
    }

    .kenii-transfer-list {
        padding: 20px 16px;
    }

    .kenii-transfer-list__item {
        flex-wrap: wrap;
        gap: 12px;
    }

    .kenii-transfer-list__item-action {
        width: 100%;
        padding-left: 56px;
    }

    .kenii-transfer-table {
        padding: 20px 16px;
    }

    .kenii-transfer-table__table thead {
        display: none;
    }

    .kenii-transfer-table__table tbody tr {
        display: block;
        padding: 16px 0;
        border-bottom: 1px solid var(--kenii-border, #E5E7EB);
    }

    .kenii-transfer-table__table tbody tr:last-child {
        border-bottom: none;
    }

    .kenii-transfer-table__table tbody td {
        display: block;
        padding: 2px 0;
        border-bottom: none;
    }

    .kenii-transfer-table__table tbody td::before {
        display: block;
        font-size: 10px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.05em;
        color: var(--kenii-text-muted, #6B7280);
        margin-bottom: 2px;
    }

    .kenii-transfer-table__institution::before {
        content: 'University';
    }

    .kenii-transfer-table__table tbody td:nth-child(2)::before {
        content: 'Equivalent Course';
    }

    .kenii-transfer-table__credits {
        text-align: left;
    }

    .kenii-transfer-table__credits::before {
        content: 'Credits';
    }

    .kenii-transfer-table__table tbody td:nth-child(4)::before {
        content: 'Agreement';
    }

    .kenii-compass__results-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
}


/* ================================================================
   RESPONSIVE — 480px
   ================================================================ */

@media (max-width: 480px) {
    .kenii-career-card {
        padding: 16px;
    }

    .kenii-career-card__icon {
        width: 44px;
        height: 44px;
    }

    .kenii-career-card__title {
        font-size: 15px;
    }

    .kenii-compass__panel-title {
        font-size: 18px;
    }

    .kenii-compass__steps {
        margin-bottom: 24px;
    }

    .kenii-compass__step-num {
        width: 32px;
        height: 32px;
        font-size: 13px;
    }

    .kenii-ccp-card {
        padding: 18px;
    }

    .kenii-career-outcomes__stat-value {
        font-size: 18px;
    }

    .kenii-transfer-list__item-icon {
        display: none;
    }

    .kenii-transfer-list__item-action {
        padding-left: 0;
    }

    .kenii-ccp-sidebar-badge {
        flex-direction: column;
    }

    .kenii-btn {
        padding: 11px 18px;
        font-size: 14px;
    }
}

/* ═══════════════════════════════════════════════════════════════
   ACCESSIBILITY — WCAG 2.1 AA
   Pathways inherits .kenii-sr-only and the baseline focus-ring
   pattern from Catalog's frontend CSS (loaded first). The rules
   below extend that pattern to every Pathways wrapper and to the
   smaller controls that fall outside Catalog's selectors.
   ═══════════════════════════════════════════════════════════════ */

.kenii-compass :focus-visible,
.kenii-career-communities :focus-visible,
.kenii-transfer :focus-visible,
.kenii-ccp-list :focus-visible,
.kenii-program-comparison :focus-visible,
.kenii-career-outcomes :focus-visible,
.kp-program-map :focus-visible,
.kp-comparison :focus-visible,
.kp-ccp-pathway-map :focus-visible,
.kp-result-card :focus-visible,
.kp-pace-btn:focus-visible,
.kp-print-btn:focus-visible,
.kp-course-link:focus-visible,
.kp-compare-check:focus-visible {
    outline: 2px solid var(--kenii-primary);
    outline-offset: 2px;
    border-radius: 3px;
}

@media (prefers-reduced-motion: reduce) {
    .kenii-compass *,
    .kenii-career-communities *,
    .kenii-transfer *,
    .kenii-ccp-list *,
    .kenii-program-comparison *,
    .kenii-career-outcomes *,
    .kp-program-map *,
    .kp-comparison *,
    .kp-ccp-pathway-map *,
    .kp-result-card * {
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
    }
}

.kp-compare-check {
    width: 18px;
    height: 18px;
    border: 2px solid var(--kenii-border);
    border-radius: 3px;
    cursor: pointer;
    margin: 0;
    flex-shrink: 0;
}

.kp-result-card__compare-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 44px;
    padding: 10px 0;
    cursor: pointer;
}

/* ═══════════════════════════════════════════════════════════════
   v2.5.1 — Tony's bug list against the Phase B CCP redesign.
   Bug 6 (spacing), Bug 7 (footer alignment), Bug 9 (numbered
   credential stack steps). Heading-hierarchy + sidebar-brand fixes
   are markup-level in PHP, not here.
   ═══════════════════════════════════════════════════════════════ */

/* Bug 6 — proper rhythm between heading, intro paragraph, and the table. */
.kp-ccp-map__intro {
    margin: 0 0 var(--kenii-space-md, 24px);
}
.kp-ccp-map__heading {
    margin: 0 0 var(--kenii-space-xs, 8px);
    font-family: var(--kenii-heading-font);
    font-size: 18px;
    font-weight: 700;
    color: var(--kenii-text);
    line-height: 1.3;
}
.kp-ccp-map__lead {
    margin: 0;
    color: var(--kenii-text-muted);
    line-height: 1.5;
}

/* Bug 7 — Total Credits row alignment: label flush-left, number centered in the Credits column. */
.kp-course-row--total .kp-course-row__total-label {
    text-align: left;
    font-weight: 700;
    color: var(--kenii-text);
}
.kp-course-row--total .kp-course-row__total-credits {
    text-align: center;
    font-weight: 700;
    color: var(--kenii-text);
}

/* v2.7.3 — Phase-by-phase HS Pathway render. Each phase (Grade 11 Fall, etc.)
   gets its own section with heading + course table + subtotal. Grand total at
   the bottom. Matches pre-v2.5.0 design + MCC's printable P1012C/P1042C charts. */
.kp-ccp-map__phase {
    margin: 0 0 var(--kenii-space-lg, 32px);
}
.kp-ccp-map__phase-heading {
    margin: 0 0 var(--kenii-space-xs, 8px);
    font-family: var(--kenii-heading-font);
    font-size: 16px;
    font-weight: 700;
    color: var(--kenii-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.kp-ccp-map__phase--postsecondary .kp-ccp-map__phase-heading {
    color: var(--kenii-primary);
}
.kp-course-row--subtotal th,
.kp-course-row--subtotal td {
    font-weight: 600;
    color: var(--kenii-text-muted);
    border-top: 1px solid var(--kenii-border-subtle, rgba(39,42,43,0.1));
}
.kp-course-row--subtotal .kp-course-row__subtotal-credits {
    text-align: center;
}
.kp-ccp-map__grand-total {
    margin: var(--kenii-space-lg, 32px) 0 0;
    padding: var(--kenii-space-md, 16px) var(--kenii-space-lg, 24px);
    background: var(--kenii-neutral-lightest);
    border-radius: var(--kenii-radius);
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-family: var(--kenii-heading-font);
}
.kp-ccp-map__grand-total-label {
    font-size: 16px;
    font-weight: 700;
    color: var(--kenii-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.kp-ccp-map__grand-total-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--kenii-primary);
}

/* Bug 9 — Credential stack visualization. Replaces the abstract colored
   dots that Tony couldn't parse with numbered step badges + an explicit
   context label under each credential name. */
.kp-ccp-map__chain-heading {
    margin: 0 0 var(--kenii-space-xs, 8px);
    font-family: var(--kenii-heading-font);
    font-size: 18px;
    font-weight: 700;
    color: var(--kenii-text);
}
.kp-ccp-map__chain-lead {
    margin: 0 0 var(--kenii-space-md, 24px);
    color: var(--kenii-text-muted);
    line-height: 1.5;
}
.kp-ccp-map__chain-track {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: center;
    gap: var(--kenii-space-md, 16px);
}
.kp-ccp-map__chain-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    text-align: center;
    flex: 0 1 auto;
    min-width: 120px;
    max-width: 180px;
}
.kp-ccp-map__chain-step {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--kenii-primary);
    color: var(--kenii-white);
    font-family: var(--kenii-heading-font);
    font-weight: 700;
    font-size: 16px;
    line-height: 1;
}
.kp-ccp-map__chain-label {
    font-weight: 600;
    color: var(--kenii-text);
    font-size: 14px;
    line-height: 1.3;
}
.kp-ccp-map__chain-context {
    font-size: 12px;
    color: var(--kenii-text-muted);
    line-height: 1.3;
}
.kp-ccp-map__chain-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    align-self: center;
    color: var(--kenii-text-muted);
    font-size: 18px;
    padding-top: 8px;
}
@media (max-width: 768px) {
    .kp-ccp-map__chain-track {
        flex-direction: column;
    }
    .kp-ccp-map__chain-arrow {
        transform: rotate(90deg);
    }
    .kp-ccp-map__chain-item {
        max-width: 100%;
    }
}
