/* On wider screens, hide mobile dropdown entirely */
@media (min-width: 721px) {
    .mobile-nav {
        display: none;
    }
}

@media (max-width: 720px) {
    /* Header řádkování */
    .nav-wrap {
        height: auto;
        padding: .35rem 0 .6rem;
        flex-wrap: wrap;
        gap: .4rem 0;
    }

    /* 1. Řádek: brand; 2. Řádek: menu přes celou šířku */
    .site-header nav {
        order: 2;
        width: 100%;
    }

    /* ZAJISTI, aby bylo menu vidět (zrušíme staré "display:none") */
    .site-header nav ul {
        display: flex !important;
        flex-direction: column;
        gap: .25rem;
        margin: 0;
        padding: .35rem;
        border: 1px solid var(--border);
        border-radius: 12px;
        background: var(--bg);
        box-shadow: var(--shadow);
    }

    .site-header nav li { width: 100%; }
    .site-header nav a.nav-link {
        display: block;
        width: 100%;
        padding: .55rem .7rem;
        border-radius: 8px;
    }

    /* „Others“: žádný dropdown — vždy rozbalené položky */
    details.dropdown { display: block !important; position: static; }
    details.dropdown > summary { display: none; }
    .dropdown-menu {
        position: static;
        display: block;
        border: 0;
        box-shadow: none;
        padding: 0;
        min-width: 0;
        margin-top: .25rem;
    }
    .dropdown-menu a {
        display: block;
        padding: .55rem .7rem;
        border-radius: 8px;
    }

    /* Jemný hover */
    .site-header nav a.nav-link:hover,
    .site-header nav a.nav-link:focus,
    .dropdown-menu a:hover,
    .dropdown-menu a:focus {
        background: var(--chip);
        text-decoration: none;
        outline: none;
    }

    /* Uprav hero pro mobily (ponechávám tvé stávající) */
    .hero { padding: 40px 0 28px; }
    .hero-grid { grid-template-columns: 1fr; gap: 1.25rem; }
    .profile-card { grid-template-columns: 1fr; grid-template-areas: "avatar" "intro"; gap: 0.75rem; justify-items: center; }
    .avatar { width: 160px; height: 160px; }
    .hero-grid .orbit-wrap { margin-top: 1rem; }

    /* a hlavně: kompletně skryj legacy mobilní dropdown konstrukci */
    .mobile-nav { display: none !important; }
}

/* TEACHING */

@media (max-width: 900px) {
    .teaching-main {
        padding: 40px 0 56px;
    }

    .year-grid {
        grid-template-columns: 1fr;
        /* jeden sloupec */
        gap: .75rem;
        /* menší mezery */
    }

    .year-aside {
        order: 0;
    }

    .year-content {
        order: 1;
    }

    /* jistota pořadí: nadpis → kurzy */
    .year-aside h2 {
        margin: 0 0 .25rem;
    }

    .course-list {
        gap: .6rem;
    }

    .section-divider {
        margin: 18px 0 0;
    }

    .year-grid {
        grid-template-columns: 1fr;
        /* jeden sloupec */
        justify-items: start;
        /* zarovnej položky vlevo */
        gap: .75rem;
    }

    .year-aside {
        text-align: left;
        /* místo původního center */
    }

    .year-aside h2 {
        margin-left: 0;
        /* pro jistotu srovnat odsazení */
    }
}

@media (max-width: 600px) {
    .course-item {
        grid-template-columns: 1fr;
        gap: .35rem;
    }

    .course-code {
        justify-self: start;
    }

    .course-info {
        grid-column: 1;
    }
}

@media (max-width: 720px) {
    .year-grid {
        grid-template-columns: 1fr;
        grid-template-areas:
            "aside"
            "content";
        gap: .75rem;
    }

    .year-aside {
        grid-area: aside;
        text-align: center;
    }

    .year-content {
        grid-area: content;
    }
}