
p, h1, h2, h3, h4, h5, h6{
    padding: 0;
    margin: 0;
}

:root {
    --prism-blue: rgb(0, 92, 154);
    --prism-sky: rgb(44, 182, 255);
    --prism-sky-soft: #A6DBFF;
    --prism-bg-soft: rgb(227, 244, 255);
    --prism-bg-softer: #F7FBFF;
    --prism-radius: 8px;
    --prism-shadow-sm: 0 1px 2px rgba(0, 92, 154, 0.08);
    --prism-shadow-md: 0 8px 24px rgba(0, 92, 154, 0.12);
}

.skip-link {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 1000;
    background: var(--prism-blue);
    color: #fff;
    padding: 8px 12px;
    border-radius: var(--prism-radius);
    text-decoration: none;
}

.site-header {
    background: #fff;
    border-bottom: 1px solid #e6eef5;
    position: sticky;
    top: 0;
    z-index: 1020;
}
.brand-wordmark {
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    line-height: 1;
}
.brand-pr {
    color: var(--prism-blue);
}
.brand-ism {
    background: linear-gradient(90deg, var(--prism-blue), var(--prism-sky));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.nav-text-link {
    color: var(--prism-blue);
    font-weight: 600;
    text-decoration: none;
}
.nav-text-link:hover { color: var(--prism-sky); }

.btn-cta {
    background: var(--prism-blue);
    color: #fff;
    font-weight: 600;
    padding: 10px 20px;
    border-radius: var(--prism-radius);
    border: 1px solid var(--prism-blue);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, border-color 0.15s, transform 0.05s;
}
.btn-cta:hover, .btn-cta:focus-visible {
    background: #2085ce;
    border-color: #2085ce;
    color: #fff;
}
.btn-cta:active { transform: translateY(1px); }

.btn-cta-ghost {
    background: transparent;
    color: var(--prism-blue);
    font-weight: 600;
    padding: 10px 20px;
    border-radius: var(--prism-radius);
    border: 1px solid var(--prism-blue);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, color 0.15s;
}
.btn-cta-ghost:hover, .btn-cta-ghost:focus-visible {
    background: var(--prism-bg-soft);
    color: var(--prism-blue);
}
.btn-cta-lg { padding: 14px 28px; font-size: 18px; }

.hero {
    padding: 72px 0 56px;
    background: linear-gradient(180deg, #ffffff 0%, var(--prism-bg-softer) 100%);
}
.hero .eyebrow {
    color: var(--prism-sky);
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-size: 14px;
    margin-bottom: 12px;
}
.hero-fullname {
    font-size: 17px;
    font-weight: 500;
    letter-spacing: 0.01em;
    margin-bottom: 14px;
    opacity: 0.72;
}
.hero-title {
    font-size: 48px;
    line-height: 1.1;
    font-weight: 700;
    margin-bottom: 20px;
}
.hero-sub {
    font-size: 20px;
    line-height: 1.55;
    margin-bottom: 28px;
    max-width: 560px;
}
.hero-ctas { margin-bottom: 16px; }
.hero-trust {
    font-size: 15px;
    color: #5a7a95;
}
.hero-visual {
    position: relative;
    background: var(--prism-bg-soft);
    border-radius: 12px;
    padding: 16px;
    box-shadow: var(--prism-shadow-md);
}
.hero-visual-img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 8px;
}
.hero-visual-tag {
    position: absolute;
    top: 8px;
    right: 8px;
    background: rgba(0, 92, 154, 0.85);
    color: #fff;
    font-size: 11px;
    padding: 4px 8px;
    border-radius: 4px;
    letter-spacing: 0.04em;
}

.prism-intro { padding-top: 16px; }

.social-proof {
    background: var(--prism-bg-softer);
    padding: 72px 0;
}
.social-proof-title {
    text-align: center;
    font-size: 22px;
    font-weight: 600;
    margin-bottom: 32px;
    letter-spacing: 0.02em;
}
.logo-strip {
    list-style: none;
    padding: 0;
    margin: 0 0 56px;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
}
.logo-tile {
    background: #fff;
    border: 1px dashed #b3cbe0;
    border-radius: var(--prism-radius);
    height: 72px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    color: #6c8aa5;
    text-align: center;
    padding: 8px;
}
.testimonial-row { margin-top: 8px; }
.testimonial-card {
    background: #fff;
    border-radius: 12px;
    padding: 28px;
    height: 100%;
    box-shadow: var(--prism-shadow-sm);
    border: 1px solid #e6eef5;
    margin: 0;
}
.testimonial-mark {
    color: var(--prism-sky);
    font-size: 24px;
    margin-bottom: 12px;
    display: block;
}
.testimonial-quote {
    font-size: 17px;
    line-height: 1.5;
    color: var(--prism-blue);
    margin: 0 0 16px;
    padding: 0;
    border: 0;
    font-style: italic;
}
.testimonial-attr {
    font-size: 14px;
    color: #5a7a95;
    line-height: 1.4;
}
.stat-card {
    background: linear-gradient(135deg, var(--prism-blue) 0%, #2085ce 100%);
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    border: 0;
}
.stat-card .stat-number {
    font-size: 56px;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 8px;
}
.stat-card .stat-label {
    color: rgba(255, 255, 255, 0.9);
    font-size: 15px;
    margin: 0;
    max-width: 220px;
}

.compliance-band {
    padding: 72px 0 40px;
    background: #fff;
}
.compliance-badges {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
}
.compliance-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--prism-bg-soft);
    color: var(--prism-blue);
    padding: 10px 16px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 15px;
    border: 1px solid #cfe5f5;
}
.compliance-badge i { color: var(--prism-sky); }
.compliance-badge-pending {
    opacity: 0.7;
    border-style: dashed;
}

.cta-band {
    background: var(--prism-blue);
    padding: 64px 0;
    color: #fff;
}
.cta-band-title {
    font-size: 36px;
    font-weight: 700;
    margin-bottom: 12px;
}
.cta-band-sub {
    font-size: 18px;
    margin: 0 auto 28px;
    max-width: 600px;
    color: rgba(255, 255, 255, 0.9);
}
.cta-band .btn-cta {
    background: #fff;
    color: var(--prism-blue);
    border-color: #fff;
}
.cta-band .btn-cta:hover, .cta-band .btn-cta:focus-visible {
    background: var(--prism-bg-soft);
    color: var(--prism-blue);
    border-color: var(--prism-bg-soft);
}
.cta-band .btn-cta-ghost {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.6);
}
.cta-band .btn-cta-ghost:hover, .cta-band .btn-cta-ghost:focus-visible {
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
    border-color: #fff;
}

/* ── Early Warning System ─────────────────────────────────────── */

.ews-section {
    padding: 72px 0;
    background: var(--prism-bg-softer);
}

.ews-indicators {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.ews-indicator {
    display: flex;
    align-items: flex-start;
    gap: 14px;
}
.ews-indicator-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    background: var(--prism-bg-soft);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--prism-sky);
    font-size: 17px;
    border: 1px solid #cfe5f5;
}
.ews-indicator-text strong {
    display: block;
    color: var(--prism-blue);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 2px;
}
.ews-indicator-text p {
    color: #5a7a95;
    font-size: 15px;
    margin: 0;
}

/* Scorecard mock */
.ews-card-mock {
    position: relative;
    background: #fff;
    border-radius: 14px;
    box-shadow: var(--prism-shadow-md);
    padding: 24px;
    border: 1px solid #e2edf5;
}
.ews-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 8px;
}
.ews-student-name {
    font-size: 17px;
    font-weight: 700;
    color: var(--prism-blue);
    display: block;
}
.ews-grade {
    font-size: 13px;
    color: #6c8aa5;
}
.ews-risk-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.02em;
}
.ews-risk-high  { background: #FFF0EE; color: #B94040; border: 1px solid #F0B4A4; }
.ews-risk-moderate { background: #FFF8E1; color: #7A5800; border: 1px solid #F0D080; }
.ews-risk-low   { background: #F1F8F4; color: #2E7D32; border: 1px solid #A8D5B0; }

.ews-score-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--prism-bg-softer);
    border-radius: 8px;
    padding: 10px 14px;
    margin-bottom: 20px;
}
.ews-score-label { font-size: 14px; color: #5a7a95; }
.ews-score-value { font-size: 18px; font-weight: 700; color: var(--prism-blue); }

.ews-factors { display: flex; flex-direction: column; gap: 14px; margin-bottom: 20px; }
.ews-factor {
    display: grid;
    grid-template-columns: 90px 1fr 80px;
    align-items: center;
    gap: 10px;
}
.ews-factor-name { font-size: 14px; font-weight: 600; color: var(--prism-blue); }
.ews-bar-track {
    height: 10px;
    background: #e9f2f9;
    border-radius: 999px;
    overflow: hidden;
}
.ews-bar-fill { height: 100%; border-radius: 999px; transition: width 0.3s; }
.ews-fill-high     { background: #D9534F; }
.ews-fill-moderate { background: #F0A500; }
.ews-fill-low      { background: #4CAF50; }

.ews-factor-level { font-size: 13px; font-weight: 600; text-align: right; }
.ews-level-high     { color: #B94040; }
.ews-level-moderate { color: #7A5800; }
.ews-level-low      { color: #2E7D32; }

.ews-card-footer {
    border-top: 1px solid #e2edf5;
    padding-top: 14px;
    font-size: 14px;
    color: #5a7a95;
    display: flex;
    align-items: flex-start;
    gap: 8px;
}
.ews-card-footer i { color: var(--prism-sky); margin-top: 2px; flex-shrink: 0; }
.ews-card-mock .hero-visual-tag { bottom: 8px; right: 8px; top: auto; }

@media screen and (max-width: 575px) {
    .ews-factor { grid-template-columns: 80px 1fr 64px; }
}

/* ── /Early Warning System ────────────────────────────────────── */

/* ── Feature grid ─────────────────────────────────────────────── */
.feature-grid-section {
    padding: 72px 0;
    background: var(--prism-bg-soft);
}

.feature-card {
    background: #fff;
    border-radius: 12px;
    padding: 28px;
    height: 100%;
    box-shadow: var(--prism-shadow-sm);
    border: 1px solid #e6eef5;
}

.feature-card-icon {
    width: 44px;
    height: 44px;
    background: var(--prism-bg-softer);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--prism-sky);
    font-size: 18px;
    border: 1px solid #cfe5f5;
    margin-bottom: 14px;
    flex-shrink: 0;
}

.feature-card-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--prism-blue);
    margin-bottom: 14px;
}

.feature-card-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.feature-card-list li {
    font-size: 15px;
    color: #3a5a72;
    padding-left: 18px;
    position: relative;
    line-height: 1.45;
}

.feature-card-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 7px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--prism-sky);
}

.feature-card-note {
    font-size: 13px;
    color: #6c8aa5;
    font-weight: 400;
}
/* ── /Feature grid ────────────────────────────────────────────── */

/* ── PRISM feature image placeholder ─────────────────────────── */
.prism-img-placeholder {
    background: var(--prism-bg-soft);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--prism-sky);
    font-size: 13px;
    border: 2px dashed var(--prism-sky-soft);
    text-align: center;
    overflow: hidden;
}
.prism-img-placeholder img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
}
/* ── /PRISM feature image placeholder ────────────────────────── */

/* ── Capability cards: per-area hero + compact grid ──────────── */
/* Framed screenshot */
.zz-shot {
    border-radius: 10px;
    border: 1px solid #d6ebfb;
    box-shadow: 0 8px 28px rgba(0, 92, 154, .12);
    overflow: hidden;
    background: #fff;
}
.zz-shot img {
    width: 100%;
    height: auto;
    display: block;
}

/* Dashed screenshot placeholder */
.zz-ph {
    border-radius: 10px;
    border: 2px dashed #A6DBFF;
    background: #f2f9ff;
    color: #2CB6FF;
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 14px;
    padding: 20px;
}

/* Per-area hero — holds 1–2 framed shots side-by-side (stacks on mobile) */
.zz-area-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 16px;
    padding: 20px 0 28px;
    border-bottom: 1px solid #d6ebfb;
}
.zz-area-hero > .zz-shot,
.zz-area-hero > .zz-ph {
    flex: 1 1 320px;
    min-height: 0;
}

/* Compact 2-column capability grid */
.zz-area-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
}
.zz-area-grid .zz-cap {
    padding: 20px 16px;
    border-bottom: 1px solid #d6ebfb;
    border-right: 1px solid #d6ebfb;
}
.zz-area-grid .zz-cap:nth-child(even) { border-right: 0; }
.zz-area-grid .zz-cap:nth-last-child(-n+2) { border-bottom: 0; }
.zz-area-grid .zz-cap h4 {
    font-size: 16px;
    font-weight: 700;
    color: rgb(0, 92, 154);
    margin-bottom: 6px;
}
.zz-area-grid .zz-cap ul {
    list-style: disc;
    padding-left: 20px;
    color: rgb(0, 92, 154);
    font-size: 15px;
    font-weight: 400;
    margin: 0;
}
.zz-area-grid .zz-cap ul li { margin-bottom: 4px; }

/* Odd card count: last card spans full width when alone on its row */
.zz-area-grid .zz-cap:nth-child(odd):last-child { grid-column: 1 / -1; border-right: 0; }

@media (max-width: 575px) {
    .zz-area-grid { grid-template-columns: 1fr; }
    .zz-area-grid .zz-cap { border-right: 0; }
    .zz-area-grid .zz-cap:nth-last-child(-n+2) { border-bottom: 1px solid #d6ebfb; }
    .zz-area-grid .zz-cap:last-child { border-bottom: 0; }
}
/* ── /Capability cards ───────────────────────────────────────── */

/* ── Product UI mockups (crisp HTML replicas of hero screenshots) ── */
.pm {
    background: #f4f8fb;
    color: var(--prism-blue);
    font-size: 13px;
    line-height: 1.45;
    text-align: left;
}
.pm * { box-sizing: border-box; }

/* Top app bar */
.pm-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    background: #fff;
    padding: 11px 16px;
    border-bottom: 1px solid #e6eef5;
}
.pm-bar-title { font-size: 15px; font-weight: 700; margin: 0; }
.pm-user { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; }
.pm-avatar {
    width: 26px; height: 26px; border-radius: 50%;
    background: var(--prism-blue); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px; font-weight: 700;
}
.pm-bell { color: #9bb0c2; }

.pm-body { padding: 16px; }
.pm-cols { display: flex; gap: 14px; align-items: flex-start; }
.pm-col { flex: 1 1 0; min-width: 0; }

.pm-card { background: #fff; border: 1px solid #e6eef5; border-radius: 10px; padding: 14px; }
.pm-card + .pm-card { margin-top: 12px; }

.pm-eyebrow {
    font-size: 10.5px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
    color: #6b8298; margin: 0 0 10px; display: flex; align-items: center; gap: 7px;
}
.pm-eyebrow i { color: var(--prism-sky); }
.pm-sub { font-size: 12px; color: #5b7185; margin: 0 0 12px; }

.pm-btn {
    background: var(--prism-blue); color: #fff; border: 0; border-radius: 6px;
    padding: 7px 12px; font-size: 12px; font-weight: 600; display: inline-flex;
    align-items: center; gap: 6px; white-space: nowrap;
}
.pm-btn-sky { background: var(--prism-sky); }
.pm-btn-ghost { background: #fff; border: 1px solid #d6e3ee; color: var(--prism-blue); }
.pm-btn-row { display: flex; gap: 10px; align-items: center; margin-top: 12px; }

.pm-label { font-size: 12px; font-weight: 600; margin: 12px 0 5px; }
.pm-label .pm-muted { color: #9bb0c2; font-weight: 400; }
.pm-field {
    border: 1px solid #d6e3ee; border-radius: 7px; padding: 9px 11px; background: #fff;
    display: flex; align-items: center; justify-content: space-between; font-size: 12.5px;
}
.pm-textarea { min-height: 76px; align-items: flex-start; color: #33485c; }

/* Generic chips / badges */
.pm-chip {
    display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 600;
    padding: 3px 9px; border-radius: 999px; background: var(--prism-bg-soft); color: var(--prism-blue);
}
.pm-chip-sky { background: #e2f4ff; color: #0c6fa6; }
.pm-badge { font-size: 10.5px; font-weight: 700; padding: 2px 8px; border-radius: 999px; }
.pm-badge-amber { background: #fdecc8; color: #9a6700; }
.pm-badge-red { background: #fbd5d5; color: #b42323; }
.pm-badge-green { background: #c8f0d2; color: #1f7a3d; }
.pm-badge-blue { background: #d8ecff; color: #0c6fa6; }
.pm-badge-gray { background: #e7edf3; color: #5b7185; }

/* Documentation Assistant: doc-type tiles */
.pm-tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.pm-tile {
    border: 1px solid #e1e9f1; border-radius: 8px; padding: 10px 6px; text-align: center;
    font-size: 11px; font-weight: 600; color: #5b7185; background: #fff;
}
.pm-tile i { display: block; font-size: 15px; margin-bottom: 5px; color: #9bb0c2; }
.pm-tile.is-active { border-color: var(--prism-sky); background: #eaf6ff; color: var(--prism-blue); }
.pm-tile.is-active i { color: var(--prism-sky); }

/* Generated note */
.pm-note-title { font-weight: 700; font-size: 13px; margin: 0 0 8px; }
.pm-note p { margin: 0 0 8px; font-size: 12.5px; color: #33485c; }
.pm-note strong { color: var(--prism-blue); }

/* List rows (active plans, students) */
.pm-row {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    border: 1px solid #e6eef5; border-radius: 8px; padding: 9px 11px; background: #fff;
}
.pm-row + .pm-row { margin-top: 8px; }
.pm-row-main { min-width: 0; }
.pm-row-name { font-weight: 700; font-size: 12.5px; }
.pm-row-sub { font-size: 11px; color: #6b8298; }

/* Intervention plan blocks */
.pm-block { background: var(--prism-bg-softer); border: 1px solid #e6eef5; border-radius: 8px; padding: 11px 12px; }
.pm-block + .pm-block { margin-top: 9px; }
.pm-block-head { font-size: 11px; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: #0c6fa6; margin: 0 0 5px; display: flex; align-items: center; gap: 6px; }
.pm-block p { margin: 0; font-size: 12px; color: #33485c; }
.pm-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 11px; }

/* KPI stat cards (analytics) */
.pm-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 14px; }
.pm-kpi { border-radius: 10px; padding: 12px; text-align: center; border: 1px solid transparent; }
.pm-kpi-num { font-size: 26px; font-weight: 800; line-height: 1; }
.pm-kpi-label { font-size: 10.5px; margin-top: 5px; color: #5b7185; }
.pm-kpi-amber { background: #fdf4dd; border-color: #f3e2b0; }
.pm-kpi-amber .pm-kpi-num { color: #b8860b; }
.pm-kpi-red { background: #fdeaea; border-color: #f6cdcd; }
.pm-kpi-red .pm-kpi-num { color: #c0392b; }
.pm-kpi-gray { background: #f1f5f9; border-color: #e2e9f0; }
.pm-kpi-gray .pm-kpi-num { color: #8aa0b3; }

/* Risk-signal + school rows */
.pm-signal { display: flex; align-items: flex-start; gap: 9px; padding: 8px 0; border-top: 1px solid #eef3f8; font-size: 12px; color: #33485c; }
.pm-signal:first-of-type { border-top: 0; }
.pm-signal i { color: var(--prism-sky); margin-top: 2px; }
.pm-signal i.fa-arrow-trend-up { color: #c0392b; }
.pm-signal i.fa-arrow-trend-down { color: #2ec36b; }
.pm-signal i.fa-arrow-trend-positive { color: #2ec36b; }
.pm-signal i.fa-arrow-trend-negative { color: #c0392b; }
.pm-school { padding: 9px 0; border-top: 1px solid #eef3f8; }
.pm-school:first-of-type { border-top: 0; }
.pm-school-group { font-size: 9.5px; font-weight: 700; letter-spacing: .06em; color: #9bb0c2; margin-bottom: 3px; }
.pm-school-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.pm-school-name { font-weight: 700; font-size: 12.5px; }
.pm-school-sub { font-size: 11px; color: #6b8298; }
.pm-school-stats { font-size: 11px; color: #5b7185; white-space: nowrap; }
.pm-school-stats b { color: var(--prism-blue); }
.pm-dot { width: 9px; height: 9px; border-radius: 50%; background: #2ec36b; display: inline-block; margin-left: 6px; }

@media (max-width: 700px) {
    .pm-cols { flex-direction: column; }
    .pm-kpis { grid-template-columns: repeat(2, 1fr); }
}
/* ── /Product UI mockups ─────────────────────────────────────── */

/* ── Feature scroll layout: sticky section rail + continuous scroll ── */
.prism-feature-scroll {
    display: flex;
    align-items: flex-start;
    gap: 24px;
}

/* Sticky left rail (Scrollspy target). Header is sticky at top:0/72px,
   so the rail sits just below it. */
.prism-rail {
    position: sticky;
    top: 88px;
    flex: 0 0 200px;
    align-self: flex-start;
}
.prism-rail .nav-link {
    color: var(--prism-blue);
    font-weight: 700;
    font-size: 15px;
    padding: 10px 14px;
    border-left: 3px solid transparent;
    border-radius: 0 6px 6px 0;
    white-space: nowrap;
    transition: background-color .15s, border-color .15s, color .15s;
}
.prism-rail .nav-link:hover {
    background-color: var(--prism-bg-soft);
}
.prism-rail .nav-link.active {
    color: var(--prism-sky);
    background-color: var(--prism-bg-soft);
    border-left-color: var(--prism-sky);
}

.prism-feature-body {
    flex: 1 1 auto;
    min-width: 0;
    background: #fff;
    border-radius: 8px;
    padding: 0 12px 8px;
}

/* Anchor offset so section titles clear the sticky header on jump */
.prism-feat {
    scroll-margin-top: 88px;
    padding-top: 8px;
}
.prism-feat:not(:last-child) {
    border-bottom: 2px solid var(--prism-bg-soft);
    margin-bottom: 8px;
    padding-bottom: 16px;
}

@media (prefers-reduced-motion: no-preference) {
    html { scroll-behavior: smooth; }
}

/* Mobile: rail becomes a horizontal sticky chip strip under the header */
@media (max-width: 991px) {
    .prism-feature-scroll {
        flex-direction: column;
        gap: 0;
    }
    .prism-rail {
        position: sticky;
        top: 64px;
        z-index: 1010;
        flex: 1 1 auto;
        width: 100%;
        background: var(--prism-sky);
        margin: 0 -12px 16px;
        padding: 8px 12px;
        width: calc(100% + 24px);
        box-shadow: 0 6px 12px -4px rgba(0, 92, 154, .3);
    }
    /* Segmented control: one connected track, 3 equal flush segments */
    .prism-rail .nav {
        flex-direction: row !important;
        flex-wrap: nowrap;
        gap: 0;
        width: 100%;
        background: rgba(255, 255, 255, .25);
        border-radius: 999px;
        padding: 3px;
    }
    .prism-rail .nav-item { flex: 1 1 0; }
    .prism-rail .nav-link {
        width: 100%;
        text-align: center;
        padding: 7px 8px;
        border: 0;
        border-radius: 999px;
        background: transparent;
        color: #fff;
        font-size: 14px;
    }
    .prism-rail .nav-link.active {
        background: #fff;
        color: var(--prism-blue);
    }
    .prism-feat { scroll-margin-top: 148px; }
}

/* Modal form polish */
#contactModal .modal-title { color: var(--prism-blue); }
#contactModal .form-label {
    color: var(--prism-blue);
    font-weight: 600;
    font-size: 14px;
    margin-bottom: 6px;
}
#contactModal .form-control:focus,
#contactModal .form-select:focus {
    border-color: var(--prism-sky);
    box-shadow: 0 0 0 0.2rem rgba(44, 182, 255, 0.2);
}

/* Footer polish */
footer { background: var(--prism-blue); }

.footer-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    padding-top: 20px;
    padding-bottom: 20px;
}

.footer-links {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.footer-links a {
    color: rgba(255, 255, 255, 0.8);
    font-size: 13px;
    text-decoration: none;
    transition: color 0.15s;
}

.footer-links a:hover { color: #fff; }

.footer-copy {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.6);
    margin: 0;
}

.footer-disclaimer {
    font-size: 12px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.5);
    margin: 0;
    padding-top: 14px;
    padding-bottom: 18px;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
}

/* Sample-data note under the feature screenshots */
.prism-demo-note {
    font-size: 13px;
    font-style: italic;
    color: var(--prism-blue);
    opacity: 0.75;
    text-align: center;
    margin: 20px auto 0;
    max-width: 760px;
    padding: 0 12px;
}

@media screen and (max-width: 991px) {
    .hero { padding: 48px 0 40px; }
    .hero-title { font-size: 38px; }
    .hero-sub { font-size: 18px; }
    .logo-strip { grid-template-columns: repeat(3, 1fr); }
}

@media screen and (max-width: 575px) {
    .hero-title { font-size: 30px; }
    .hero-sub { font-size: 16px; }
    .cta-band-title { font-size: 26px; }
    .cta-band-sub { font-size: 16px; }
    .logo-strip { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .stat-card .stat-number { font-size: 44px; }
    .compliance-badge { font-size: 13px; padding: 8px 12px; }
}
.py-140{padding: 140px 0;}
.pt-100{padding-top: 100px;}
.pb-60{padding-bottom: 60px;}

.fw_700{font-weight: 700;}
.fw_600{font-weight: 600;}
.fw_500{font-weight: 500;}
.fw_400{font-weight: 400;}

.blue-text{color: rgb(0, 92, 154);}
.sky-blue-text {color: rgb(44, 182, 255);}
.bg-blue-sky{background-color: rgb(44, 182, 255);}
.bg-blue{background-color: rgb(0, 92, 154) !important; }
.bg-blue2{background-color: rgb(227, 244, 255);}

.fs_40{font-size: 40px;}
.fs_36{font-size: 36px;}
.fs_32{font-size: 32px;}
.fs_30{font-size: 30px;}
.fs_24{font-size: 24px;}

.fs_20{font-size: 20px;}
.fs_16{font-size: 16px;}

ul.custom-bullets {
    list-style-type: disc;
    padding-left: 40px;
    color: rgb(0, 92, 154);
    font-size: 20px;
    font-weight: 400;
    margin-bottom: 0;
}

ul.custom-bullets li {
    margin-bottom: 10px;
}
.monthly-prise{
    background-color: rgb(244, 244, 244);
}
.btnRegister:hover {
    background: #2085ce;
    text-decoration: none;
}
.btnRegister {
    background: #005c9a;
    padding: 15px 30px;
    font-size: 20px;
    color: #fff;
    font-weight: 600;
    margin: 20px auto 0;
    border-radius: 4px;
    display: inline-block;
    text-decoration: none;
}

.feature-title {
    font-size: 18px;
    color: rgb(0, 92, 154) !important;
}

.check-icon {
    color: #2CB6FF;
    font-size: 20px;
}

@media screen and (max-width: 991px) {
    .feature-card{
        min-height: fit-content;
    }
}

@media screen and (max-width: 430px) {

.fs_40{font-size: 30px;}
.fs_36{font-size: 26px;}
.fs_32{font-size: 22px;}
.fs_30{font-size: 20px;}
.fs_24{font-size: 18px;}

.fs_20{font-size: 16px;}
.fs_16{font-size: 16px;}
.py-140 {
    padding: 70px 0;
}
.pt-100 {
    padding-top: 50px;
}
}

/* ============================================================
   Hero Animated Dashboard Mockup  —  3-screen cycling carousel
   Cycle duration: 12 s   |   Std 0–34%  EWS 34–67%  Ana 67–100%
   (Observations screen retained in markup but hidden)
   ============================================================ */

.hero-visual { padding: 0; overflow: hidden; }

/* ── Browser chrome ── */
.mock-chrome {
    display: flex;
    align-items: center;
    gap: 6px;
    background: #e4edf5;
    padding: 9px 12px;
    border-bottom: 1px solid #cdd8e4;
}
.mock-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.mock-dot:nth-child(1) { background: #ff6058; }
.mock-dot:nth-child(2) { background: #ffbd2e; }
.mock-dot:nth-child(3) { background: #28c840; }
.mock-url-bar {
    flex: 1;
    text-align: center;
    font-size: 11px;
    color: #5a7a95;
    background: #fff;
    border: 1px solid #cdd8e4;
    border-radius: 4px;
    padding: 3px 10px;
    letter-spacing: 0.02em;
}

/* ── Tab bar ── */
.mock-tabs {
    display: flex;
    background: #f4f8fb;
    border-bottom: 2px solid #dde6ee;
}
.mock-tab {
    flex: 1;
    text-align: center;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
    padding: 7px 4px;
    color: #8aaabb;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    animation-duration: 12s;
    animation-iteration-count: infinite;
    animation-timing-function: step-end;
}
.mock-tab-obs { animation-name: mockTabObs; display: none; } /* hidden for now */
.mock-tab-std { animation-name: mockTabStd; }
.mock-tab-ews { animation-name: mockTabEws; }
.mock-tab-ana { animation-name: mockTabAna; }

/* ── Screens container ── */
.mock-screens {
    position: relative;
    height: 258px;
    background: #fff;
    overflow: hidden;
}
.mock-screen {
    position: absolute;
    inset: 0;
    padding: 12px 14px;
    animation-duration: 12s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}
.mock-screen-obs { animation-name: mockSlideObs; display: none; } /* hidden for now */
.mock-screen-std { animation-name: mockSlideStd; }
.mock-screen-ews { animation-name: mockSlideEws; }
.mock-screen-ana { animation-name: mockSlideAna; }

/* ─────────────────────────────────────────
   SCREEN 1: Student observation cards
   ───────────────────────────────────────── */
.mock-cards-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    height: 100%;
}
.mock-card {
    background: #f7fbff;
    border: 1px solid #dce9f5;
    border-radius: 8px;
    padding: 8px 9px;
    display: flex;
    flex-direction: column;
    gap: 5px;
    animation-duration: 12s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}
.mock-card-1 { animation-name: mockCard1; }
.mock-card-2 { animation-name: mockCard2; }
.mock-card-3 { animation-name: mockCard3; }
.mock-card-4 { animation-name: mockCard4; }
.mock-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 4px;
}
.mock-card-name {
    font-size: 10px;
    font-weight: 700;
    color: var(--prism-blue);
    line-height: 1.3;
}
.mock-std-badge {
    font-size: 8.5px;
    font-weight: 700;
    padding: 2px 5px;
    border-radius: 3px;
    white-space: nowrap;
    flex-shrink: 0;
}
.mock-std-pass { background: #e8f8ef; color: #1a7a42; }
.mock-std-fail { background: #fef0f0; color: #c03a2b; }
.mock-card-av {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    color: #fff;
    margin: 0 auto;
}
.mock-card-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 9.5px;
    color: #6c8aa5;
    margin-top: auto;
}

/* ─────────────────────────────────────────
   SCREEN 2: Standards mastery summary
   ───────────────────────────────────────── */
.mock-std-list {
    display: flex;
    flex-direction: column;
    gap: 9px;
    height: 100%;
}
.mock-std-item {
    background: #fff;
    border: 1px solid #e2ecf5;
    border-radius: 8px;
    padding: 9px 10px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    box-shadow: 0 1px 2px rgba(40, 70, 100, 0.04);
    animation-duration: 12s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}
.mock-std-item-1 { animation-name: mockStdItem1; }
.mock-std-item-2 { animation-name: mockStdItem2; }
.mock-std-item-3 { animation-name: mockStdItem3; }
.mock-std-item-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.mock-std-code {
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 11px;
    font-weight: 700;
    color: var(--prism-blue);
    letter-spacing: 0.02em;
}
.mock-std-obs { font-size: 9px; color: #93afc0; }
.mock-std-pills { display: flex; gap: 5px; }
.mock-spill {
    font-size: 8.5px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 4px;
    white-space: nowrap;
}
.mock-spill-mast { background: #e8f8ef; color: #1a7a42; }
.mock-spill-dev  { background: #fbf3e0; color: #8a6d1f; }
.mock-spill-not  { background: #fef0f0; color: #c03a2b; }
.mock-std-bar {
    display: flex;
    gap: 2px;
    height: 5px;
    border-radius: 3px;
    overflow: hidden;
}
.mock-bar-seg { display: block; border-radius: 3px; }

/* ─────────────────────────────────────────
   SCREEN 3: Early Warning System
   ───────────────────────────────────────── */
.mock-ews-head {
    display: grid;
    grid-template-columns: 1fr auto auto auto;
    gap: 6px;
    padding-bottom: 6px;
    border-bottom: 1px solid #e0ecf5;
    margin-bottom: 2px;
}
.mock-ews-lbl {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #93afc0;
    text-align: center;
}
.mock-ews-lbl:first-child { text-align: left; }
.mock-ews-row {
    display: grid;
    grid-template-columns: 1fr auto auto auto;
    gap: 6px;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid #f0f6fb;
    animation-duration: 12s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}
.mock-ews-row-1 { animation-name: mockEwsRow1; }
.mock-ews-row-2 { animation-name: mockEwsRow2; }
.mock-ews-row-3 { animation-name: mockEwsRow3; }
.mock-ews-row-4 { animation-name: mockEwsRow4; }
.mock-ews-name { font-size: 11px; font-weight: 600; color: var(--prism-blue); }
.mock-ews-val  { font-size: 11px; color: #4a6a85; text-align: center; }
.mock-ews-alert { color: #c03a2b; font-weight: 700; }

/* Shared risk pills */
.mock-pill {
    font-size: 9px;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 20px;
    white-space: nowrap;
    text-align: center;
}
.mock-pill-hi  { background: #fef0f0; color: #c03a2b; border: 1px solid #f5c6c6; }
.mock-pill-mod { background: #fff4e5; color: #b35c00; border: 1px solid #ffd599; }
.mock-pill-low { background: #e8f8ef; color: #1a7a42; border: 1px solid #a0ddb8; }

/* ─────────────────────────────────────────
   SCREEN 4: Analytics  (donut + bar chart)
   ───────────────────────────────────────── */
.mock-charts-wrap {
    display: flex;
    gap: 14px;
    height: 100%;
}
.mock-chart-panel {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}
.mock-chart-ttl {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: #93afc0;
}

/* Donut */
.mock-donut-wrap {
    position: relative;
    width: 100px;
    height: 100px;
    margin: 0 auto;
    flex-shrink: 0;
}
.mock-donut-svg { width: 100px; height: 100px; display: block; }
.mock-seg {
    fill: none;
    animation-duration: 12s;
    animation-iteration-count: infinite;
    animation-timing-function: ease;
}
.mock-seg-low { animation-name: mockSegLow; }
.mock-seg-mod { animation-name: mockSegMod; }
.mock-seg-hi  { animation-name: mockSegHi;  }
.mock-donut-ctr {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1.1;
    animation: mockAnaFade 12s infinite ease;
}
.mock-donut-num { font-size: 20px; font-weight: 700; color: var(--prism-blue); }
.mock-donut-sub { font-size: 9px; color: #6c8aa5; }
.mock-legend {
    display: flex;
    flex-direction: column;
    gap: 3px;
    margin-top: auto;
}
.mock-legend-item {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 10px;
    color: #4a6a85;
}
.mock-legend-item i {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    font-style: normal;
    display: inline-block;
}

/* Vertical bar chart */
.mock-vchart {
    flex: 1;
    display: flex;
    align-items: flex-end;
    gap: 5px;
    border-left: 1px solid #e0ecf5;
    border-bottom: 1px solid #e0ecf5;
    padding: 6px 0 0 4px;
}
.mock-vcol {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    gap: 3px;
    height: 100%;
}
.mock-vbar {
    width: 100%;
    border-radius: 2px 2px 0 0;
    background: var(--prism-sky);
    height: 0;
    animation-duration: 12s;
    animation-iteration-count: infinite;
    animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.mock-vbar-1 { animation-name: mockVbar1; }
.mock-vbar-2 { animation-name: mockVbar2; }
.mock-vbar-3 { animation-name: mockVbar3; }
.mock-vbar-4 { animation-name: mockVbar4; }
.mock-vbar-5 { animation-name: mockVbar5; }
.mock-vcol-lbl { font-size: 8px; color: #93afc0; }

/* =============================================================
   KEYFRAMES  (all synced to 12 s cycle)
   Screens:  Std 0–34%  |  EWS 34–67%  |  Analytics 67–100%
   (Obs keyframes retained but screen/tab hidden via display:none)
   Transitions span ~3% (~0.36 s) at each boundary
   ============================================================= */

/* Screen slides */
@keyframes mockSlideObs {
    0%   { opacity: 1; transform: translateX(0); }
    22%  { opacity: 1; transform: translateX(0); }
    25%  { opacity: 0; transform: translateX(-18px); }
    97%  { opacity: 0; transform: translateX(18px); }
    100% { opacity: 1; transform: translateX(0); }
}
@keyframes mockSlideStd {
    0%   { opacity: 1; transform: translateX(0); }
    31%  { opacity: 1; transform: translateX(0); }
    34%  { opacity: 0; transform: translateX(-18px); }
    96%  { opacity: 0; transform: translateX(18px); }
    100% { opacity: 1; transform: translateX(0); }
}
@keyframes mockSlideEws {
    0%   { opacity: 0; transform: translateX(18px); }
    31%  { opacity: 0; transform: translateX(18px); }
    34%  { opacity: 1; transform: translateX(0); }
    64%  { opacity: 1; transform: translateX(0); }
    67%  { opacity: 0; transform: translateX(-18px); }
    100% { opacity: 0; transform: translateX(-18px); }
}
@keyframes mockSlideAna {
    0%   { opacity: 0; transform: translateX(18px); }
    64%  { opacity: 0; transform: translateX(18px); }
    67%  { opacity: 1; transform: translateX(0); }
    97%  { opacity: 1; transform: translateX(0); }
    100% { opacity: 0; transform: translateX(-18px); }
}

/* Tab active indicator */
@keyframes mockTabObs {
    0%   { color: var(--prism-blue); border-bottom-color: var(--prism-blue); }
    22%  { color: var(--prism-blue); border-bottom-color: var(--prism-blue); }
    25%  { color: #8aaabb; border-bottom-color: transparent; }
    100% { color: #8aaabb; border-bottom-color: transparent; }
}
@keyframes mockTabStd {
    0%   { color: var(--prism-blue); border-bottom-color: var(--prism-blue); }
    31%  { color: var(--prism-blue); border-bottom-color: var(--prism-blue); }
    34%  { color: #8aaabb; border-bottom-color: transparent; }
    100% { color: #8aaabb; border-bottom-color: transparent; }
}
@keyframes mockTabEws {
    0%   { color: #8aaabb; border-bottom-color: transparent; }
    31%  { color: #8aaabb; border-bottom-color: transparent; }
    34%  { color: var(--prism-blue); border-bottom-color: var(--prism-blue); }
    64%  { color: var(--prism-blue); border-bottom-color: var(--prism-blue); }
    67%  { color: #8aaabb; border-bottom-color: transparent; }
    100% { color: #8aaabb; border-bottom-color: transparent; }
}
@keyframes mockTabAna {
    0%   { color: #8aaabb; border-bottom-color: transparent; }
    64%  { color: #8aaabb; border-bottom-color: transparent; }
    67%  { color: var(--prism-blue); border-bottom-color: var(--prism-blue); }
    97%  { color: var(--prism-blue); border-bottom-color: var(--prism-blue); }
    100% { color: #8aaabb; border-bottom-color: transparent; }
}

/* Student cards: stagger fade-up during 0–12%, out at 22–25% */
@keyframes mockCard1 {
    0%   { opacity: 0; transform: translateY(7px); }
    4%   { opacity: 1; transform: translateY(0); }
    22%  { opacity: 1; transform: translateY(0); }
    25%  { opacity: 0; }
    97%  { opacity: 0; transform: translateY(7px); }
    100% { opacity: 0; transform: translateY(7px); }
}
@keyframes mockCard2 {
    0%   { opacity: 0; transform: translateY(7px); }
    2%   { opacity: 0; transform: translateY(7px); }
    6%   { opacity: 1; transform: translateY(0); }
    22%  { opacity: 1; transform: translateY(0); }
    25%  { opacity: 0; }
    97%  { opacity: 0; transform: translateY(7px); }
    100% { opacity: 0; transform: translateY(7px); }
}
@keyframes mockCard3 {
    0%   { opacity: 0; transform: translateY(7px); }
    4%   { opacity: 0; transform: translateY(7px); }
    8%   { opacity: 1; transform: translateY(0); }
    22%  { opacity: 1; transform: translateY(0); }
    25%  { opacity: 0; }
    97%  { opacity: 0; transform: translateY(7px); }
    100% { opacity: 0; transform: translateY(7px); }
}
@keyframes mockCard4 {
    0%   { opacity: 0; transform: translateY(7px); }
    6%   { opacity: 0; transform: translateY(7px); }
    10%  { opacity: 1; transform: translateY(0); }
    22%  { opacity: 1; transform: translateY(0); }
    25%  { opacity: 0; }
    97%  { opacity: 0; transform: translateY(7px); }
    100% { opacity: 0; transform: translateY(7px); }
}

/* Standards items: stagger fade-up during 0–12%, out at 31–34% */
@keyframes mockStdItem1 {
    0%   { opacity: 0; transform: translateY(7px); }
    5%   { opacity: 1; transform: translateY(0); }
    31%  { opacity: 1; transform: translateY(0); }
    34%  { opacity: 0; }
    96%  { opacity: 0; transform: translateY(7px); }
    100% { opacity: 0; transform: translateY(7px); }
}
@keyframes mockStdItem2 {
    0%   { opacity: 0; transform: translateY(7px); }
    3%   { opacity: 0; transform: translateY(7px); }
    8%   { opacity: 1; transform: translateY(0); }
    31%  { opacity: 1; transform: translateY(0); }
    34%  { opacity: 0; }
    96%  { opacity: 0; transform: translateY(7px); }
    100% { opacity: 0; transform: translateY(7px); }
}
@keyframes mockStdItem3 {
    0%   { opacity: 0; transform: translateY(7px); }
    5%   { opacity: 0; transform: translateY(7px); }
    10%  { opacity: 1; transform: translateY(0); }
    31%  { opacity: 1; transform: translateY(0); }
    34%  { opacity: 0; }
    96%  { opacity: 0; transform: translateY(7px); }
    100% { opacity: 0; transform: translateY(7px); }
}

/* EWS rows: stagger slide-in from right during 34–47%, out at 64–67% */
@keyframes mockEwsRow1 {
    0%   { opacity: 0; transform: translateX(10px); }
    31%  { opacity: 0; transform: translateX(10px); }
    36%  { opacity: 1; transform: translateX(0); }
    64%  { opacity: 1; transform: translateX(0); }
    67%  { opacity: 0; }
    100% { opacity: 0; transform: translateX(10px); }
}
@keyframes mockEwsRow2 {
    0%   { opacity: 0; transform: translateX(10px); }
    34%  { opacity: 0; transform: translateX(10px); }
    39%  { opacity: 1; transform: translateX(0); }
    64%  { opacity: 1; transform: translateX(0); }
    67%  { opacity: 0; }
    100% { opacity: 0; transform: translateX(10px); }
}
@keyframes mockEwsRow3 {
    0%   { opacity: 0; transform: translateX(10px); }
    37%  { opacity: 0; transform: translateX(10px); }
    42%  { opacity: 1; transform: translateX(0); }
    64%  { opacity: 1; transform: translateX(0); }
    67%  { opacity: 0; }
    100% { opacity: 0; transform: translateX(10px); }
}
@keyframes mockEwsRow4 {
    0%   { opacity: 0; transform: translateX(10px); }
    40%  { opacity: 0; transform: translateX(10px); }
    45%  { opacity: 1; transform: translateX(0); }
    64%  { opacity: 1; transform: translateX(0); }
    67%  { opacity: 0; }
    100% { opacity: 0; transform: translateX(10px); }
}

/* Vertical bars: grow staggered during 67–82%, reset at 100% */
@keyframes mockVbar1 {
    0%   { height: 0; } 65% { height: 0; }
    73%  { height: 43px; } 97% { height: 43px; } 100% { height: 0; }
}
@keyframes mockVbar2 {
    0%   { height: 0; } 67% { height: 0; }
    75%  { height: 62px; } 97% { height: 62px; } 100% { height: 0; }
}
@keyframes mockVbar3 {
    0%   { height: 0; } 69% { height: 0; }
    77%  { height: 76px; } 97% { height: 76px; } 100% { height: 0; }
}
@keyframes mockVbar4 {
    0%   { height: 0; } 71% { height: 0; }
    79%  { height: 53px; } 97% { height: 53px; } 100% { height: 0; }
}
@keyframes mockVbar5 {
    0%   { height: 0; } 73% { height: 0; }
    82%  { height: 86px; } 97% { height: 86px; } 100% { height: 0; }
}

/* Donut segments: draw staggered during 75–90%, erase at 97–100%
   Circumference = 2π × 28 ≈ 176  |  Low=110 Mod=44 Hi=22 */
@keyframes mockSegLow {
    0%   { stroke-dasharray: 0 176; } 65% { stroke-dasharray: 0 176; }
    76%  { stroke-dasharray: 110 66; } 97% { stroke-dasharray: 110 66; }
    100% { stroke-dasharray: 0 176; }
}
@keyframes mockSegMod {
    0%   { stroke-dasharray: 0 176; } 68% { stroke-dasharray: 0 176; }
    79%  { stroke-dasharray: 44 132; } 97% { stroke-dasharray: 44 132; }
    100% { stroke-dasharray: 0 176; }
}
@keyframes mockSegHi {
    0%   { stroke-dasharray: 0 176; } 71% { stroke-dasharray: 0 176; }
    82%  { stroke-dasharray: 22 154; } 97% { stroke-dasharray: 22 154; }
    100% { stroke-dasharray: 0 176; }
}

/* Donut center label fade */
@keyframes mockAnaFade {
    0%   { opacity: 0; } 64% { opacity: 0; }
    70%  { opacity: 1; } 97% { opacity: 1; }
    100% { opacity: 0; }
}

/* ── Reduce motion ── */
@media (prefers-reduced-motion: reduce) {
    .mock-screen-ews,
    .mock-screen-ana,
    .mock-tab-ews,
    .mock-tab-ana  { animation: none !important; }

    .mock-screen-ews,
    .mock-screen-ana { opacity: 0 !important; pointer-events: none; }
    .mock-tab-std  { animation: none !important; color: var(--prism-blue) !important;
                     border-bottom-color: var(--prism-blue) !important; }

    .mock-screen-std,
    .mock-std-item { animation: none !important; opacity: 1 !important; transform: none !important; }
    .mock-vbar { animation: none !important; height: 50px !important; }
    .mock-seg-low { stroke-dasharray: 110 66 !important; }
    .mock-seg-mod { stroke-dasharray: 44 132 !important; }
    .mock-seg-hi  { stroke-dasharray: 22 154 !important; }
}
