/*
 * Mobile polish layer shared across the project.
 * Kept intentionally scoped to narrow screens to avoid desktop regressions.
 */

:root {
    --mobile-gap: clamp(0.5rem, 2.4vw, 0.9rem);
    --mobile-card-radius: 14px;
    --mobile-safe-left: max(0.6rem, env(safe-area-inset-left, 0px));
    --mobile-safe-right: max(0.6rem, env(safe-area-inset-right, 0px));
    --mobile-safe-bottom: max(0.72rem, env(safe-area-inset-bottom, 0px));
}

.mobile-skeleton {
    position: relative;
    overflow: hidden;
    border-radius: 10px;
    background: color-mix(in srgb, #1e293b 72%, #64748b 28%);
}

.mobile-skeleton::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.24) 50%, transparent 100%);
    animation: mobile-shimmer 1.15s ease-in-out infinite;
}

.mobile-skeleton-line {
    height: 11px;
    margin-bottom: 0.48rem;
}

.mobile-skeleton-line:last-child {
    margin-bottom: 0;
}

.mobile-skeleton-line.w-70 {
    width: 70%;
}

.mobile-skeleton-line.w-50 {
    width: 50%;
}

.mobile-skeleton-card {
    border-radius: 12px;
    padding: 0.72rem;
    border: 1px solid rgba(148, 163, 184, 0.28);
    background: color-mix(in srgb, #0f172a 88%, #1d4ed8 12%);
}

.mobile-skeleton-grid {
    display: grid;
    gap: 0.58rem;
}

.mobile-filters-toggle {
    display: none;
}

.mobile-menu-close-btn {
    display: none;
}

.mobile-menu-section-title {
    display: none;
}

@keyframes mobile-shimmer {
    100% {
        transform: translateX(100%);
    }
}

@media (max-width: 900px) {
    :root {
        --mobile-ham-panel-bg: linear-gradient(180deg, rgba(9, 22, 38, 0.96) 0%, rgba(15, 28, 47, 0.98) 100%);
        --mobile-ham-panel-border: rgba(148, 163, 184, 0.22);
        --mobile-ham-overlay: rgba(2, 6, 23, 0.56);
        --mobile-ham-text: #edf4ff;
        --mobile-ham-text-soft: #94a3b8;
        --mobile-ham-active-bg: linear-gradient(90deg, rgba(11, 79, 140, 0.96), rgba(13, 139, 117, 0.9));
        --mobile-ham-hover-bg: rgba(90, 168, 240, 0.14);
    }

    .page-home .mobile-nav-toggle,
    .page-player-home .mobile-nav-toggle,
    .page-teacher-home .mobile-nav-toggle,
    .page-teacher-courses .mobile-nav-toggle,
    .page-classes .mobile-nav-toggle,
    .page-jugadores .mobile-nav-toggle {
        width: 36px;
        height: 36px;
        padding: 0;
        border-radius: 999px;
        border: 0;
        background: transparent;
        box-shadow: none;
    }

    .page-home .mobile-nav-toggle:hover,
    .page-home .mobile-nav-toggle:focus-visible,
    .page-player-home .mobile-nav-toggle:hover,
    .page-player-home .mobile-nav-toggle:focus-visible,
    .page-teacher-home .mobile-nav-toggle:hover,
    .page-teacher-home .mobile-nav-toggle:focus-visible,
    .page-teacher-courses .mobile-nav-toggle:hover,
    .page-teacher-courses .mobile-nav-toggle:focus-visible,
    .page-classes .mobile-nav-toggle:hover,
    .page-classes .mobile-nav-toggle:focus-visible,
    .page-jugadores .mobile-nav-toggle:hover,
    .page-jugadores .mobile-nav-toggle:focus-visible {
        background: rgba(148, 163, 184, 0.12);
        border: 0;
        box-shadow: none;
    }

    .page-home .home-mobile-menu,
    .page-player-home .teacher-mobile-menu,
    .page-teacher-home .teacher-mobile-menu,
    .page-teacher-courses .teacher-courses-sidebar,
    .page-classes #classes-sidebar,
    .page-jugadores #jugadores-sidebar {
        width: 100vw;
        background: var(--mobile-ham-panel-bg);
        border-right: 1px solid var(--mobile-ham-panel-border);
        box-shadow: 20px 0 40px -26px rgba(2, 6, 23, 0.95);
        color: var(--mobile-ham-text);
    }

    .page-home .home-mobile-overlay,
    .page-player-home .teacher-mobile-overlay,
    .page-teacher-home .teacher-mobile-overlay,
    .page-teacher-courses .teacher-courses-mobile-overlay,
    .page-classes .sidebar-overlay,
    .page-jugadores .sidebar-overlay {
        background: var(--mobile-ham-overlay);
    }

    .page-home .home-mobile-brand,
    .page-player-home .teacher-mobile-brand,
    .page-teacher-home .teacher-mobile-brand,
    .page-teacher-courses .teacher-courses-sidebar .sidebar-brand,
    .page-classes #classes-sidebar .sidebar-brand,
    .page-jugadores #jugadores-sidebar .sidebar-brand,
    .page-jugadores #jugadores-sidebar .logo-block {
        border-bottom: 1px solid var(--mobile-ham-panel-border);
        padding-bottom: 0.9rem;
        margin-bottom: 0.2rem;
    }

    .page-home .home-mobile-icon,
    .page-player-home .teacher-mobile-icon,
    .page-teacher-home .teacher-mobile-icon,
    .page-teacher-courses .teacher-courses-sidebar .sidebar-brand-icon,
    .page-classes #classes-sidebar .sidebar-brand-icon,
    .page-jugadores #jugadores-sidebar .sidebar-brand-icon {
        color: #dbeafe;
        background: linear-gradient(135deg, rgba(11, 79, 140, 0.96), rgba(13, 139, 117, 0.92));
        box-shadow: 0 14px 24px -18px rgba(11, 79, 140, 0.98);
    }

    .page-home .home-mobile-brand h2,
    .page-player-home .teacher-mobile-brand h2,
    .page-teacher-home .teacher-mobile-brand h2,
    .page-teacher-courses .teacher-courses-sidebar .sidebar-brand-copy h2,
    .page-classes #classes-sidebar .sidebar-brand-copy h2,
    .page-jugadores #jugadores-sidebar .sidebar-brand-copy h2,
    .page-jugadores #jugadores-sidebar .logo-block h2 {
        color: var(--mobile-ham-text);
    }

    .page-home .home-mobile-brand p,
    .page-player-home .teacher-mobile-brand p,
    .page-teacher-home .teacher-mobile-brand p,
    .page-teacher-courses .teacher-courses-sidebar .sidebar-brand-copy p,
    .page-classes #classes-sidebar .sidebar-brand-copy p,
    .page-jugadores #jugadores-sidebar .sidebar-brand-copy p,
    .page-jugadores #jugadores-sidebar .logo-block p {
        color: var(--mobile-ham-text-soft);
    }

    .page-home .home-mobile-nav,
    .page-player-home .teacher-mobile-nav,
    .page-teacher-home .teacher-mobile-nav,
    .page-teacher-courses .teacher-courses-sidebar .sidebar-nav,
    .page-classes #classes-sidebar .sidebar-nav,
    .page-jugadores #jugadores-sidebar .sidebar-nav,
    .page-jugadores #jugadores-sidebar .side-nav,
    .page-jugadores #jugadores-sidebar .side-actions {
        display: grid;
        align-content: start;
        gap: 0.45rem;
    }

    .page-jugadores #jugadores-sidebar .side-actions {
        border-top: 1px solid var(--mobile-ham-panel-border);
        padding-top: 0.65rem;
        grid-template-columns: 1fr;
    }

    .page-jugadores #jugadores-sidebar .side-nav {
        grid-template-columns: 1fr;
    }

    .page-home .home-mobile-actions,
    .page-player-home .teacher-mobile-actions,
    .page-teacher-home .teacher-mobile-actions,
    .page-teacher-courses #teacher-courses-sidebar .sidebar-actions,
    .page-classes #classes-sidebar .sidebar-actions,
    .page-jugadores #jugadores-sidebar .side-actions,
    .page-dashboard #mobileTabbar .mobile-tabbar-actions {
        border-top: 1px solid var(--mobile-ham-panel-border);
        padding-top: 0.65rem;
        display: grid;
        align-content: start;
        gap: 0.45rem;
    }

    .page-classes #classes-sidebar .sidebar-nav > hr,
    .page-classes #classes-sidebar #admin-menu hr {
        border: 0;
        border-top: 1px solid var(--mobile-ham-panel-border);
        margin: 0.3rem 0;
    }

    .page-home .home-mobile-link,
    .page-player-home .teacher-mobile-link,
    .page-teacher-home .teacher-mobile-link,
    .page-teacher-courses .teacher-courses-sidebar .nav-item,
    .page-classes #classes-sidebar .nav-item,
    .page-jugadores #jugadores-sidebar .nav-item,
    .page-jugadores #jugadores-sidebar .nav-link,
    .page-jugadores #jugadores-sidebar .side-actions .btn {
        width: 100%;
        min-height: 44px;
        border: none;
        border-radius: 8px;
        background: transparent;
        color: var(--mobile-ham-text-soft);
        padding: 0.66rem 0.78rem;
        text-align: left;
        justify-content: flex-start;
        display: inline-flex;
        align-items: center;
        gap: 0.55rem;
        font-size: 0.9rem;
        font-weight: 600;
        cursor: pointer;
        box-shadow: none;
        transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease;
    }

    .page-home #home-mobile-menu .profile-menu-anchor,
    .page-player-home #player-mobile-menu .profile-menu-anchor,
    .page-teacher-home #teacher-mobile-menu .profile-menu-anchor,
    .page-teacher-courses #teacher-courses-sidebar .profile-menu-anchor,
    .page-dashboard #mobileTabbar .profile-menu-anchor,
    .page-jugadores #jugadores-sidebar .side-actions .profile-menu-anchor {
        width: 100%;
        display: block;
        z-index: 1;
    }

    .page-classes #classes-sidebar > .profile-menu-anchor,
    .page-classes #classes-sidebar .sidebar-actions .profile-menu-anchor {
        width: 100%;
        display: block;
        z-index: 1;
    }

    .page-home #home-mobile-menu .profile-menu-trigger,
    .page-player-home #player-mobile-menu .profile-menu-trigger,
    .page-teacher-home #teacher-mobile-menu .profile-menu-trigger,
    .page-teacher-courses #teacher-courses-sidebar .profile-menu-trigger,
    .page-classes #classes-sidebar .profile-menu-trigger,
    .page-dashboard #mobileTabbar .profile-menu-trigger,
    .page-jugadores #jugadores-sidebar .profile-menu-trigger {
        width: 100%;
        min-height: 44px;
        border: none;
        border-radius: 8px;
        background: transparent;
        color: var(--mobile-ham-text-soft);
        padding: 0.66rem 0.78rem;
        text-align: left;
        justify-content: flex-start;
        gap: 0.55rem;
        box-shadow: none;
        transform: none;
    }

    .page-home #home-mobile-menu .profile-menu-trigger:hover,
    .page-player-home #player-mobile-menu .profile-menu-trigger:hover,
    .page-teacher-home #teacher-mobile-menu .profile-menu-trigger:hover,
    .page-teacher-courses #teacher-courses-sidebar .profile-menu-trigger:hover,
    .page-classes #classes-sidebar .profile-menu-trigger:hover,
    .page-dashboard #mobileTabbar .profile-menu-trigger:hover,
    .page-jugadores #jugadores-sidebar .profile-menu-trigger:hover {
        transform: translateX(2px);
        color: var(--mobile-ham-text);
        background: var(--mobile-ham-hover-bg);
    }

    .page-home #home-mobile-menu .profile-menu-trigger .profile-label,
    .page-player-home #player-mobile-menu .profile-menu-trigger .profile-label,
    .page-teacher-home #teacher-mobile-menu .profile-menu-trigger .profile-label,
    .page-teacher-courses #teacher-courses-sidebar .profile-menu-trigger .profile-label,
    .page-classes #classes-sidebar .profile-menu-trigger .profile-label,
    .page-dashboard #mobileTabbar .profile-menu-trigger .profile-label,
    .page-jugadores #jugadores-sidebar .profile-menu-trigger .profile-label {
        display: inline;
        max-width: none;
        white-space: nowrap;
    }

    .mobile-menu-section-title {
        display: block;
        margin: 0.1rem 0 0.2rem;
        color: var(--mobile-ham-text-soft);
        font-size: 0.68rem;
        font-weight: 800;
        letter-spacing: 0.14em;
        text-transform: uppercase;
    }

    .page-home .home-mobile-link:hover,
    .page-player-home .teacher-mobile-link:hover,
    .page-teacher-home .teacher-mobile-link:hover,
    .page-teacher-courses .teacher-courses-sidebar .nav-item:hover,
    .page-classes #classes-sidebar .nav-item:hover,
    .page-jugadores #jugadores-sidebar .nav-item:hover,
    .page-jugadores #jugadores-sidebar .nav-link:hover,
    .page-jugadores #jugadores-sidebar .side-actions .btn:hover {
        transform: translateX(2px);
        color: var(--mobile-ham-text);
        background: var(--mobile-ham-hover-bg);
    }

    .page-home .home-mobile-link--active,
    .page-home .home-mobile-menu .nav-item.active,
    .page-player-home .teacher-mobile-link--active,
    .page-player-home .teacher-mobile-menu .nav-item.active,
    .page-teacher-home .teacher-mobile-link--active,
    .page-teacher-home .teacher-mobile-menu .nav-item.active,
    .page-teacher-courses .teacher-courses-sidebar .nav-item.active,
    .page-classes #classes-sidebar .nav-item.active,
    .page-jugadores #jugadores-sidebar .nav-item.active,
    .page-jugadores #jugadores-sidebar .nav-link.active {
        color: #fff;
        background: var(--mobile-ham-active-bg);
        box-shadow: 0 10px 25px -16px rgba(79, 70, 229, 0.95);
        position: relative;
    }

    .page-home .home-mobile-link--active::after,
    .page-home .home-mobile-menu .nav-item.active::after,
    .page-player-home .teacher-mobile-link--active::after,
    .page-player-home .teacher-mobile-menu .nav-item.active::after,
    .page-teacher-home .teacher-mobile-link--active::after,
    .page-teacher-home .teacher-mobile-menu .nav-item.active::after,
    .page-teacher-courses .teacher-courses-sidebar .nav-item.active::after,
    .page-jugadores #jugadores-sidebar .nav-item.active::after,
    .page-jugadores #jugadores-sidebar .nav-link.active::after {
        content: "";
        position: absolute;
        right: 10px;
        width: 6px;
        height: 6px;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.95);
    }

    .page-home .home-shell,
    .page-player-home .content-area,
    .page-teacher-home .content-area,
    .page-teacher-courses .content-area,
    .page-jugadores .main-content,
    .page-classes .content-area,
    .page-dashboard .content-area {
        width: min(100%, calc(100% - 1rem));
    }

    .page-home .panel,
    .page-player-home .panel,
    .page-teacher-home .panel,
    .page-teacher-courses .panel,
    .page-jugadores .panel,
    .page-classes .content-section,
    .page-dashboard .table-container {
        border-radius: var(--mobile-card-radius);
    }

    .page-home .home-main,
    .page-player-home .content-area,
    .page-teacher-home .content-area,
    .page-teacher-courses .content-area,
    .page-jugadores .main-content,
    .page-classes .content-area,
    .page-dashboard .content-area {
        gap: clamp(0.68rem, 2.6vw, 1rem);
    }
}

@media (max-width: 992px) {
    .page-home .mobile-menu-close-btn,
    .page-player-home .mobile-menu-close-btn,
    .page-teacher-home .mobile-menu-close-btn,
    .page-teacher-courses .mobile-menu-close-btn,
    .page-classes .mobile-menu-close-btn,
    .page-jugadores .mobile-menu-close-btn,
    .page-dashboard .mobile-menu-close-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.35rem;
        margin-left: auto;
        border: 1px solid rgba(148, 163, 184, 0.32);
        background: rgba(51, 65, 85, 0.62);
        color: #e2e8f0;
        border-radius: 10px;
        min-height: 36px;
        padding: 0.4rem 0.58rem;
        cursor: pointer;
        font-size: 0.74rem;
        font-weight: 700;
        transition: background 0.18s ease, border-color 0.18s ease;
    }

    .page-home .mobile-menu-close-btn:hover,
    .page-player-home .mobile-menu-close-btn:hover,
    .page-teacher-home .mobile-menu-close-btn:hover,
    .page-teacher-courses .mobile-menu-close-btn:hover,
    .page-classes .mobile-menu-close-btn:hover,
    .page-jugadores .mobile-menu-close-btn:hover,
    .page-dashboard .mobile-menu-close-btn:hover {
        background: rgba(11, 79, 140, 0.18);
        border-color: rgba(90, 168, 240, 0.36);
    }

    .page-dashboard #mobileTabbar .mobile-tabbar-actions .mobile-tab-link,
    .page-dashboard #mobileTabbar .mobile-tabbar-actions .profile-menu-trigger {
        width: 100%;
        justify-content: flex-start;
    }
}

@media (max-width: 768px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    html {
        scroll-padding-top: 72px;
    }

    body {
        line-height: 1.45;
    }

    img,
    svg,
    video,
    canvas {
        max-width: 100%;
        height: auto;
    }

    .btn,
    button,
    .btn-primary,
    .btn-secondary,
    .btn-dashboard,
    .btn-logout,
    .global-home-link,
    .profile-menu-trigger,
    .profile-menu-btn {
        min-height: 44px;
    }

    input,
    select,
    textarea,
    .form-control,
    .profile-menu-field input,
    .profile-menu-field select {
        font-size: 16px;
        min-height: 44px;
    }

    .header,
    .main-header,
    .home-header {
        row-gap: var(--mobile-gap);
    }

    .page-home .home-header,
    .page-player-home .header,
    .page-teacher-home .header,
    .page-classes .header,
    .page-jugadores .main-header,
    .page-dashboard .main-header {
        padding-top: max(0.78rem, calc(env(safe-area-inset-top, 0px) + 0.24rem));
    }

    .header-right,
    .header-actions,
    .content-actions,
    .summary-actions,
    .detail-actions,
    .task-actions,
    .management-actions,
    .form-actions,
    .tools,
    .calendar-controls,
    .mobile-shortcuts,
    .hero-actions,
    .table-header {
        gap: 0.5rem;
    }

    .table-wrap,
    .table-container,
    .management-table,
    .calendar-grid,
    .calendar-events-grid {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    table.mobile-card-table {
        width: 100%;
        min-width: 0 !important;
    }

    table.mobile-card-table thead {
        display: none;
    }

    table.mobile-card-table tbody {
        display: grid;
        gap: 0.62rem;
    }

    table.mobile-card-table tbody tr {
        display: grid;
        gap: 0.38rem;
        padding: 0.7rem;
        border: 1px solid rgba(148, 163, 184, 0.26);
        border-radius: 12px;
        background: color-mix(in srgb, #0f172a 88%, #1d4ed8 12%);
    }

    table.mobile-card-table tbody td {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 0.58rem;
        border: 0 !important;
        padding: 0 !important;
        text-align: right;
        min-height: 22px;
    }

    table.mobile-card-table tbody td::before {
        content: attr(data-label);
        font-size: 0.73rem;
        font-weight: 700;
        color: color-mix(in srgb, #f8fafc 54%, #94a3b8 46%);
        text-align: left;
        letter-spacing: 0.01em;
        flex: 0 0 44%;
        max-width: 44%;
    }

    table.mobile-card-table tbody td[data-label=""]::before {
        content: "";
        display: none;
    }

    table.mobile-card-table tbody td > * {
        margin-left: auto;
    }

    .page-classes .mobile-filters-toggle {
        display: inline-flex;
        width: 100%;
        justify-content: center;
        margin-bottom: 0.55rem;
    }

    .page-classes .filters.mobile-filters-sheet {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 5300;
        margin: 0;
        padding: 0.68rem 0.68rem calc(0.68rem + env(safe-area-inset-bottom, 0px));
        border-radius: 16px 16px 0 0;
        border: 1px solid rgba(148, 163, 184, 0.3);
        background: linear-gradient(180deg, rgba(15, 23, 42, 0.98) 0%, rgba(17, 24, 39, 0.98) 100%);
        transform: translateY(105%);
        transition: transform 0.22s ease;
        max-height: min(78vh, 720px);
        overflow-y: auto;
        box-shadow: 0 -20px 48px -26px rgba(2, 6, 23, 0.95);
    }

    .page-classes.classes-filters-open .filters.mobile-filters-sheet {
        transform: translateY(0);
    }

    .page-classes .mobile-filters-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.5rem;
        padding-bottom: 0.55rem;
        margin-bottom: 0.55rem;
        border-bottom: 1px solid rgba(148, 163, 184, 0.26);
        color: #f1f5f9;
        font-size: 0.88rem;
        font-weight: 700;
    }

    .page-classes .mobile-filters-close {
        border: 1px solid rgba(148, 163, 184, 0.32);
        background: rgba(51, 65, 85, 0.62);
        color: #e2e8f0;
        border-radius: 10px;
        min-height: 36px;
        min-width: 36px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
    }

    .page-classes #classes-mobile-filters-overlay {
        position: fixed;
        inset: 0;
        border: 0;
        margin: 0;
        padding: 0;
        width: 100%;
        height: 100%;
        background: rgba(2, 6, 23, 0.42);
        z-index: 5250;
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.16s ease;
    }

    .page-classes #classes-mobile-filters-overlay.active {
        opacity: 1;
        pointer-events: auto;
    }

    .page-classes.classes-filters-open {
        overflow: hidden;
    }

    .page-jugadores #evaluation-form .form-actions,
    .page-classes .modal-content .form-actions {
        position: sticky;
        bottom: calc(env(safe-area-inset-bottom, 0px) + 0px);
        z-index: 2;
        padding-top: 0.58rem;
        padding-bottom: calc(0.38rem + env(safe-area-inset-bottom, 0px));
        background: linear-gradient(180deg, rgba(15, 23, 42, 0) 0%, rgba(15, 23, 42, 0.88) 34%);
        backdrop-filter: blur(3px);
    }

    .page-home .home-shell,
    .page-player-home .content-area,
    .page-teacher-home .content-area,
    .page-teacher-courses .content-area,
    .page-jugadores .main-content,
    .page-classes .content-area,
    .page-dashboard .content-area,
    .page-login .page-shell,
    .page-alianza .container,
    .page-debug {
        padding-left: var(--mobile-safe-left);
        padding-right: var(--mobile-safe-right);
    }

    .page-home .home-shell,
    .page-player-home .content-area,
    .page-teacher-home .content-area,
    .page-teacher-courses .content-area,
    .page-jugadores .main-content,
    .page-classes .content-area,
    .page-dashboard .content-area {
        padding-bottom: var(--mobile-safe-bottom);
    }

    .page-home .header-actions,
    .page-player-home .header-right,
    .page-teacher-home .header-right,
    .page-teacher-courses .header-actions,
    .page-classes .header-right,
    .page-jugadores .header-actions {
        width: 100%;
        align-items: stretch;
    }

    .page-home .header-actions .btn,
    .page-player-home .header-right .btn,
    .page-teacher-home .header-right .btn,
    .page-classes .header-right .btn-logout,
    .page-classes .header-right .btn-dashboard,
    .page-jugadores .header-actions .btn,
    .page-login .promo-actions .btn,
    .page-alianza .hero-actions .btn,
    .page-alianza .final-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .page-home .date-pill,
    .page-teacher-home .teacher-date,
    .page-jugadores .pill,
    .page-classes .user-name {
        width: 100%;
        text-align: center;
        justify-content: center;
    }

    .global-home-link--inline {
        flex: 0 0 auto;
        align-self: center;
        max-width: 100%;
    }

    .profile-menu-dropdown {
        max-width: min(92vw, 320px);
        right: 0;
    }

    .profile-menu-foot {
        flex-direction: column;
    }

    .profile-menu-foot .profile-menu-btn {
        width: 100%;
    }

    .page-classes .filters,
    .page-classes .content-controls,
    .page-jugadores .tools,
    .page-dashboard .table-header > div,
    .page-dashboard .table-header {
        border-radius: 12px;
    }

    .page-classes .filters,
    .page-jugadores .tools,
    .page-dashboard .table-header > div {
        padding: 0.45rem;
        background: color-mix(in srgb, #0f4c81 6%, transparent);
    }

    .page-dashboard .table-header > div .btn,
    .page-classes .content-actions .btn-primary,
    .page-classes .content-actions .btn-secondary,
    .page-jugadores .tools .btn {
        min-height: 44px;
    }

    .page-home .panel-head h3,
    .page-player-home .panel-head h3,
    .page-teacher-home .panel-head h3,
    .page-jugadores .panel-head h2,
    .page-classes .content-section h2,
    .page-dashboard .table-header h3 {
        line-height: 1.25;
    }

    .page-home .list-item,
    .page-player-home .item,
    .page-teacher-home .item,
    .page-teacher-home .capacity-item,
    .page-jugadores .history-item,
    .page-jugadores table tbody tr,
    .page-classes .class-card {
        padding: 0.72rem;
    }

    .pagination button,
    .chip {
        min-height: 40px;
    }

    .page-dashboard .content-area {
        padding-left: var(--mobile-safe-left) !important;
        padding-right: var(--mobile-safe-right) !important;
    }

    .page-dashboard .table-header > div,
    .page-dashboard .class-actions,
    .page-dashboard .user-actions {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
    }

    .page-dashboard .table-header .form-control,
    .page-dashboard .class-actions .btn {
        width: 100% !important;
    }

    .page-login .login-footer {
        row-gap: 0.55rem;
    }

    .page-login .login-footer a {
        min-height: 38px;
        display: inline-flex;
        align-items: center;
    }

    .page-alianza .nav {
        -webkit-overflow-scrolling: touch;
        scroll-padding-left: 0.4rem;
    }

    .page-debug {
        padding: 0.6rem;
    }
}

@media (max-width: 560px) {
    .page-home .home-shell,
    .page-player-home .content-area,
    .page-teacher-home .content-area,
    .page-teacher-courses .content-area,
    .page-jugadores .main-content,
    .page-classes .content-area,
    .page-dashboard .content-area {
        width: calc(100% - 0.5rem);
    }

    .page-home .panel,
    .page-home .hero-card,
    .page-player-home .panel,
    .page-teacher-home .panel,
    .page-jugadores .panel,
    .page-classes .content-section,
    .page-classes .modal-content,
    .page-dashboard .table-container,
    .profile-menu-dialog {
        border-radius: 12px;
    }

    .page-dashboard .main-header,
    .page-home .home-header,
    .page-player-home .header,
    .page-teacher-home .header,
    .page-classes .header,
    .page-jugadores .main-header {
        border-radius: 12px;
    }

    .page-dashboard .mobile-tabbar,
    .page-jugadores .mobile-nav-shell {
        border-radius: 12px;
    }
}

@media (hover: none) and (pointer: coarse) {
    .page-home .home-mobile-link:hover,
    .page-player-home .teacher-mobile-link:hover,
    .page-teacher-home .teacher-mobile-link:hover,
    .page-classes #classes-sidebar .nav-item:hover,
    .page-jugadores #jugadores-sidebar .nav-link:hover,
    .page-jugadores #jugadores-sidebar .side-actions .btn:hover,
    .page-home #home-mobile-menu .profile-menu-trigger:hover,
    .page-player-home #player-mobile-menu .profile-menu-trigger:hover,
    .page-teacher-home #teacher-mobile-menu .profile-menu-trigger:hover,
    .page-classes #classes-sidebar .profile-menu-trigger:hover,
    .page-jugadores #jugadores-sidebar .profile-menu-trigger:hover {
        transform: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    .mobile-skeleton::after {
        animation: none !important;
    }
}
