/* Responsive UI – Lesbarkeit, Touch, Tablet & verschiedene Endgeräte */

:root {
    --touch-target-min: 44px;
}

/* Schnellere Tap-Reaktion, weniger Doppel-Tap-Zoom auf Buttons */
@media (pointer: coarse) {
    html {
        -webkit-tap-highlight-color: rgba(0, 0, 128, 0.15);
    }

    a,
    button,
    summary,
    [role="button"],
    input[type="submit"],
    input[type="button"],
    .lagebild-briefing-calendar__cell,
    .lagebild-date-cell,
    .mm-menu-item,
    .mm-list-item {
        touch-action: manipulation;
    }
}

/* ── Basis: fluid Schrift auf kleinen Screens ── */
@media (max-width: 991.98px) {
    body.theme-klassisch {
        font-size: 12px;
    }
}

@media (max-width: 1199.98px) {
    body.theme-klassisch .form-control,
    body.theme-klassisch .form-select,
    body.theme-klassisch input[type="search"],
    body.theme-klassisch input[type="date"],
    body.theme-klassisch input[type="text"] {
        font-size: 16px !important; /* verhindert iOS-Zoom beim Fokus */
    }
}

@media (max-width: 575.98px) {
    body.theme-klassisch {
        font-size: 13px;
    }

    body.theme-klassisch .app-shell__workspace {
        padding: 2px;
    }

    body.theme-klassisch .app-shell__client {
        padding: 2px;
    }
}

/* ── Navigation: Touch-Ziele ── */
@media (max-width: 1199.98px), (pointer: coarse) {
    body.theme-klassisch .professional-navbar .navbar-nav > .nav-item > .nav-link,
    body.theme-klassisch .nav-toolbar .btn {
        min-height: var(--touch-target-min);
        display: inline-flex;
        align-items: center;
        padding: 0.45rem 0.75rem !important;
    }

    body.theme-klassisch .navbar-toggler {
        min-width: var(--touch-target-min);
        min-height: var(--touch-target-min);
    }
}

/* ── Taskleiste / Footer ── */
@media (max-width: 767.98px) {
    body.theme-klassisch .app-shell__status-hint {
        display: none;
    }

    body.theme-klassisch .site-footer .row {
        text-align: center;
    }

    body.theme-klassisch .site-footer .nav {
        justify-content: center !important;
    }

    body.theme-klassisch .app-shell__clock {
        margin-left: auto;
    }
}

/* ── Lagebild-Briefing ── */
@media (max-width: 1199.98px) {
    .lagebild-briefing__chip,
    .lagebild-briefing__cluster,
    button.lagebild-briefing__chip.is-filter {
        min-height: var(--touch-target-min);
        padding: 0.4rem 0.75rem;
    }

    .lagebild-briefing__chips {
        gap: 0.5rem;
    }
}

@media (max-width: 767.98px) {
    .lagebild-briefing {
        --briefing-gap: 0.75rem;
    }

    .lagebild-briefing__hero {
        grid-template-columns: 1fr;
        grid-template-areas:
            "ring"
            "text"
            "map";
        justify-items: center;
        text-align: center;
    }

    .lagebild-briefing--compact .lagebild-briefing__hero {
        grid-template-areas: "ring" "text";
    }

    .lagebild-briefing__hero-text {
        width: 100%;
        text-align: left;
    }

    .lagebild-briefing__intro {
        font-size: 1rem;
        line-height: 1.45;
    }

    .lagebild-briefing__quick-stats {
        justify-content: center;
    }

    .lagebild-briefing__view-switch {
        width: 100%;
        display: flex;
    }

    .lagebild-briefing__view-btn {
        flex: 1 1 50%;
        min-height: 2.5rem;
    }

    .lagebild-briefing__spectrum-legend {
        flex-direction: column;
        align-items: stretch;
    }

    .lagebild-briefing__chip,
    .lagebild-briefing__cluster {
        min-height: var(--touch-target-min);
    }

    .lagebild-briefing__chips {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        gap: 0.35rem;
        padding-bottom: 0.25rem;
        scrollbar-width: thin;
    }

    .lagebild-briefing__chip {
        flex: 0 0 auto;
    }

    .lagebild-briefing__clusters {
        display: flex;
        flex-direction: column;
        gap: 0.35rem;
    }

    .lagebild-briefing__event-grid {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 575.98px) {
    .lagebild-briefing__index-ring {
        width: 6.5rem;
        height: 6.5rem;
    }

    .lagebild-briefing__index-score {
        font-size: 1.5rem;
    }
}

/* ── Cluster-Mindmap ── */
@media (max-width: 1199.98px) {
    .mm-menu-item,
    .mm-btn {
        min-height: var(--touch-target-min);
        padding: 0.4rem 0.75rem;
        font-size: 12px;
    }

    .mm-list-item {
        min-height: var(--touch-target-min);
        padding: 0.45rem 0.5rem;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .mm-input,
    .mm-input[type="search"] {
        min-height: var(--touch-target-min);
        font-size: 16px;
        padding: 0.4rem 0.5rem;
    }

    .mm-check {
        min-height: var(--touch-target-min);
        padding: 0.25rem 0;
    }

    .mm-check input[type="checkbox"],
    .mm-check input[type="range"] {
        width: 1.1rem;
        height: 1.1rem;
    }
}

@media (max-width: 991.98px) {
    .lage-cluster-mindmap,
    .mm-shell {
        min-height: auto;
    }

    .mm-shell {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
    }

    .mm-canvas-pane {
        min-height: 0;
        order: 1;
    }

    .mm-sidebar {
        order: 2;
        max-height: none;
        border-top: 2px solid #808080;
    }

    .mm-stage {
        min-height: min(48vh, 420px);
    }

    .mm-svg {
        min-height: min(48vh, 420px);
    }

    .lagebild-briefing__view-panel[data-briefing-view="cluster"] .lage-cluster-mindmap {
        min-height: auto;
    }
}

@media (max-width: 767.98px) {
    .mm-menubar {
        flex-wrap: wrap;
        gap: 4px;
    }

    .mm-menubar__hint {
        display: none;
    }

    .mm-stage {
        min-height: max(260px, 42vh);
    }

    .mm-svg {
        min-height: max(260px, 42vh);
    }

    .mm-list {
        max-height: min(36vh, 280px);
    }

    /* Sidebar als aufklappbare Leiste (Handy + Tablet Hochformat) */
    .mm-sidebar {
        display: none;
    }

    .mm-sidebar.is-open {
        display: flex;
    }
}

/* Tablet Querformat: Mindmap + Sidebar nebeneinander */
@media (min-width: 768px) and (max-width: 1199.98px) and (orientation: landscape) {
    .mm-shell {
        grid-template-columns: 1fr minmax(240px, 32%);
        grid-template-rows: auto;
    }

    .mm-sidebar {
        display: flex;
        max-height: calc(100dvh - 140px);
        overflow-y: auto;
    }

    .mm-stage {
        min-height: calc(100dvh - 180px);
    }

    .mm-svg {
        min-height: calc(100dvh - 180px);
    }
}

@media (max-width: 575.98px) {
    .mm-stats {
        flex-wrap: wrap;
        justify-content: center;
        gap: 0.5rem 1rem;
    }

    .mm-detail {
        max-height: none;
    }

    .lage-cluster-mindmap.is-fullscreen .mm-shell {
        height: calc(100dvh - 8px);
    }

    .lage-cluster-mindmap.is-fullscreen .mm-stage {
        min-height: 55dvh;
    }
}

/* Querformat Handy */
@media (max-width: 896px) and (orientation: landscape) {
    .mm-shell {
        grid-template-columns: 1fr 240px;
        grid-template-rows: auto;
    }

    .mm-sidebar {
        display: flex;
        max-height: calc(100dvh - 120px);
        overflow-y: auto;
    }

    .mm-stage {
        min-height: calc(100dvh - 160px);
    }
}

/* ── Kalender & Zusatz-Blöcke ── */
@media (max-width: 1199.98px), (pointer: coarse) {
    .lagebild-briefing-calendar__btn,
    .lagebild-briefing-calendar__today,
    .lagebild-briefing-calendar__link {
        min-height: var(--touch-target-min);
        min-width: var(--touch-target-min);
        padding: 0.4rem 0.65rem;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .lagebild-briefing-calendar__date-input {
        min-height: var(--touch-target-min);
        font-size: 16px;
        padding: 0.35rem 0.5rem;
    }

    .lagebild-briefing-calendar__grid-summary {
        min-height: var(--touch-target-min);
        display: flex;
        align-items: center;
        padding: 0.35rem 0;
    }

    .lagebild-briefing-calendar__cell {
        min-height: var(--touch-target-min);
        font-size: 0.8rem;
    }

    .lagebild-briefing-calendar__cell-score {
        font-size: 0.7rem;
    }

    .lagebild-supplement__block > summary {
        min-height: var(--touch-target-min);
        display: flex;
        align-items: center;
        padding: 0.5rem 0.65rem;
    }
}

@media (max-width: 1199.98px) {
    .lagebild-briefing-calendar__row {
        gap: 0.65rem;
    }

    .lagebild-briefing-calendar__actions {
        flex-wrap: wrap;
    }

    .lagebild-briefing-calendar__links {
        flex: 1 1 100%;
        gap: 0.5rem;
    }

    .lagebild-briefing__chips {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        gap: 0.5rem;
        padding-bottom: 0.25rem;
        scrollbar-width: thin;
    }

    .lagebild-briefing__chip {
        flex: 0 0 auto;
    }
}

/* ── Home-Toolbar ── */
@media (max-width: 1199.98px), (pointer: coarse) {
    .home-toolbar__item {
        min-height: var(--touch-target-min);
    }
}

@media (max-width: 575.98px) {
    .home-toolbar__list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.35rem;
    }

    .home-toolbar__item {
        min-height: 2.75rem;
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: center;
    }
}

/* ── Tabellen horizontal scrollen ── */
@media (max-width: 991.98px) {
    #main-content .table {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}

/* ── SVG Labels auf kleinen Screens (via Klasse am Root) ── */
.lage-cluster-mindmap.is-compact-ui .mm-node-label {
    font-size: 12px !important;
}

.lage-cluster-mindmap.is-compact-ui .mm-node-sub {
    font-size: 10px !important;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .lagebild-briefing__view-panel {
        animation: none;
    }
}
