/* Plan 006: responsive.css — Cross-cutting responsive breakpoint overrides
   Extracted from frontend/styles.css on 2026-04-03 */

/* ── Session metrics grid ── */
@media (max-width: 1024px) {
}

@media (max-width: 640px) {
}

/* ── Student info / learning profile ── */
@media (max-width: 768px) {

}

@media (max-width: 768px) {

}

/* ── Global cross-cutting overrides ── */
@media (max-width: 1024px) {
    body {
        max-width: 1200px;
        background-color: #f0f2f5;
        overflow-x: hidden;
    }

    header.detail-header {
        flex-wrap: wrap;
        gap: 8px 10px;
    }

    header.detail-header h1 {
        order: 3;
        width: 100%;
        text-align: center;
        font-size: 1.1rem;
    }

header.detail-header .profile-dropdown {
        flex: 1 1 auto;
        min-width: 0;
    }

    header.detail-header .profile-menu-trigger {
        width: 100%;
        border-radius: 10px;
        height: 38px;
    }


.section, .analysis-section-card {
        min-width: 0;
    }


    .container {
        grid-template-columns: 1fr;
    }

    #appContainer.container {
        grid-template-columns: 1fr;
    }


.session-detail.session-subject {
        min-width: 0;
        white-space: normal;
    }


    .session-detail.session-subject {
        flex: 1 1 auto;
    }


    .severity-row {
        flex-wrap: wrap;
        align-items: center;
    }

.severity-value {
        width: auto;
    }


    .severity-bar {
        min-width: 0;
        flex: 1 1 auto;
    }

    .severity-value {
        flex: 0 0 auto;
        margin-left: auto;
        text-align: right;
    }
}

@media (max-width: 768px) {
    header.index-header {
        padding: 0 1rem;
    }

    .header-title-group .header-subtitle {
        display: none;
    }
}

@media (max-width: 640px) {
    .session-editor-row {
        grid-template-columns: 1fr;
    }

    .session-form-card {
        padding: 12px;
    }
}

/* ── Student Profile View ── */
@media (max-width: 1024px) {
    .spr-below-fold {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
}

@media (max-width: 480px) {

    .spr-avatar {
        width: 64px;
        height: 64px;
    }


.spr-panel {
        padding: var(--space-6);
    }
}

/* ── Staff Profile View ── */
@media (max-width: 1280px) {
    .sfp-students-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1024px) {
    .sfp-hero-main {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-6);
    }

    .sfp-kpi-grid {
        grid-template-columns: 1fr;
    }

    .sfp-lower-grid {
        grid-template-columns: 1fr;
    }

    .sfp-profile-card {
        border-radius: var(--radius-xl);
    }
}

@media (max-width: 640px) {
    .sfp-hero-card {
        border-radius: var(--radius-xl);
        padding: var(--space-6);
    }

    .sfp-hero-avatar-frame {
        width: 86px;
        height: 86px;
    }

    .sfp-hero-avatar-initials {
        font-size: 30px;
    }

    .sfp-hero-name {
        font-size: clamp(28px, 9vw, 40px);
    }

    .sfp-kpi-card {
        border-radius: var(--radius-xl);
        padding: var(--space-5);
        min-height: 96px;
    }

    .sfp-kpi-value {
        font-size: 34px;
    }

    .sfp-section-heading-row {
        flex-wrap: wrap;
        align-items: flex-start;
    }

    .sfp-student-name {
        font-size: 24px;
    }

    .sfp-student-meta {
        font-size: var(--text-body);
    }

    .sfp-profile-card {
        padding: var(--space-6);
    }
}
