/* --- File: ./app/static/css/responsive.css --- */
/* Alle @media Queries für responsives Design */

/* Anpassungen für schmalere Bildschirme (Tablet/kleine Desktops) */
@media (max-width: 880px) {
    /* --- Mobile Navigation --- */
    .main-nav ul.nav-links {
        display: none;
        position: absolute;
        top: 55px; /* Höhe des Headers */
        left: 0;
        width: 100%;
        background-color: var(--header-bg);
        flex-direction: column;
        align-items: stretch;
        padding: 0;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.4);
        border-top: 1px solid var(--border-color);
        height: auto;
        z-index: 99;
    }
    .main-nav ul.nav-links.active {
        display: flex;
    }
    .main-nav ul li {
        margin-left: 0;
        width: 100%;
        height: auto;
    }
    .main-nav ul li a {
        padding: 0.75rem 1.25rem;
        width: 100%;
        justify-content: flex-start;
        border-bottom: 1px solid var(--border-color);
        height: auto;
        font-size: 1rem;
    }
    .main-nav ul li:last-child a {
        border-bottom: none;
    }
    .main-nav ul li.active a {
        border-bottom-color: var(--border-color);
        background-color: var(--accent-color-light);
        color: var(--accent-color);
    }

    /* Rechten Bereich (Theme, Login/Logout) anders anordnen */
    .main-nav ul li.nav-item-separator {
        display: none; /* Separator ausblenden */
    }
     .main-nav ul li.nav-item-theme-toggle {
        order: 1; /* Theme-Toggle als erstes Element im rechten Block */
        margin-left: 0; /* Kein linker Rand */
        border-top: 1px solid var(--border-color);
        width: 100%; /* Volle Breite */
    }
    .navbar-theme-toggle {
        padding: 0.75rem 1.25rem; /* Gleiches Padding wie Links */
        font-size: 1rem; /* Gleiche Größe wie Links */
        width: 100%; /* Volle Breite */
        justify-content: flex-start; /* Links ausrichten wie andere Links */
        gap: 0.375rem; /* Gleicher Abstand wie bei anderen Links */
    }
    /* Text im Theme Toggle auf Mobilgeräten anzeigen */
    .nav-theme-text {
        display: inline; /* Text anzeigen */
    }
    .main-nav ul li.nav-right {
        order: 2; /* Login/Logout als zweites Element */
        margin-left: 0;
        margin-top: 0; /* Kein extra Top-Margin */
        border-top: 1px solid var(--border-color); /* Linie über Login/Logout */
        width: 100%;
    }
    .main-nav ul li.nav-right a {
        justify-content: center; /* Text zentrieren */
        color: var(--btn-danger-bg);
    }
    .main-nav ul li.nav-right a:hover {
        background-color: var(--input-bg);
    }
    .navbar-toggle {
        display: block;
    }
    .nav-login-text {
        display: none; /* Login-Text bleibt ausgeblendet */
    }


    /* --- ALLGEMEINE ANPASSUNGEN FÜR CONTROL BARS AUF MOBILGERÄTEN --- */
    .profile-view-controls, .blog-controls, .tracker-filters {
        flex-wrap: wrap;
        justify-content: center;
    }
    .profile-view-controls > div, .blog-controls > div {
        justify-content: center;
        margin-bottom: 10px;
    }
     .profile-view-controls > div:last-child, .blog-controls > div:last-child {
        margin-bottom: 0;
    }

    /* Verstecke Text-Labels in Buttons in den Control-Bars */
    .profile-view-controls .filter-btn span,
    .blog-controls .view-switch-btn span,
    .blog-controls #search-button span,
    .tracker-filters .filter-tab span {
        display: none;
    }
    /* Verstecke Text-Labels, die keine Span-Tags sind */
    .profile-view-controls .controls-label, .blog-controls .controls-label {
        display: none;
    }
    /* Passe Icons an */
    .profile-view-controls .filter-btn i,
    .blog-controls .view-switch-btn i,
    .blog-controls #search-button i,
    .tracker-filters .filter-tab i {
        margin-right: 0;
        font-size: 1.1em;
    }
    /* Verstecke Ansichtsumschalter in Profilen, da erzwungene Listenansicht */
    .profile-view-controls #view-switch-grid,
    .profile-view-controls #view-switch-list {
        display: none !important;
    }

    /* Globale Regel, um Text in normalen Buttons auf Mobilgeräten auszublenden */
    .btn.btn-mobile-icon-only > span {
        display: none;
    }
    .btn.btn-mobile-icon-only > i {
        margin-right: 0; /* Entfernt den Abstand, wenn kein Text da ist */
    }

    /* --- Responsive Anpassung für .controls auf Tracker-Seite --- */
    .controls {
        flex-direction: column;
        gap: 1rem;
    }
    .control-group {
        flex-basis: auto;
        width: 100%;
        max-width: none;
    }

    /* --- Admin-Settings-Reihe untereinander --- */
    .settings-row {
        flex-direction: column;
        align-items: initial;
        row-gap: 1.875rem;
        column-gap: 0;
    }
    .settings-row > .content-box-standard {
        flex-basis: auto;
        width: 100%;
        margin-bottom: 0;
        height: auto !important; /* Höhenausgleich aufheben */
    }

    /* --- About-Seite-Reihe untereinander --- */
    .about-row {
        flex-direction: column;
        row-gap: 1.875rem;
        column-gap: 0;
        margin-bottom: 0;
    }
    .about-row > .content-box-standard,
    .about-row > .about-column {
        flex-basis: 100%;
        margin-bottom: 0;
    }
    .about-column {
        grid-template-rows: auto auto;
        grid-template-columns: 1fr;
        gap: 1.875rem;
    }
    .about-column > .content-box-standard {
        margin-bottom: 0 !important;
    }

    /* --- Responsive Tabellen (z.B. Health Log) --- */
    .health-log-table {
        border: none;
        box-shadow: none;
    }
    .health-log-table thead {
        display: none; /* Kopfzeile ausblenden */
    }
    .health-log-table tr {
        display: block;
        border: 1px solid var(--border-color);
        border-radius: 8px;
        margin-bottom: 1rem;
        padding: 0.75rem;
        background-color: var(--box-bg-color);
    }
    .health-log-table td {
        display: block;
        text-align: right; /* Werte rechts ausrichten */
        border-bottom: 1px dashed var(--box-border-color);
        padding: 0.6rem 0;
    }
    .health-log-table td:last-child {
        border-bottom: none;
    }
    .health-log-table td::before {
        content: attr(data-label);
        float: left;
        font-weight: bold;
        color: var(--box-text-color);
    }


} /* Ende @media (max-width: 880px) */

/* Anpassungen für sehr schmale Bildschirme (Smartphones) */
@media (max-width: 600px) {
    /* Profil Header Layout anpassen */
    .profile-header {
        flex-direction: column;
        align-items: center;
        gap: 1.25rem;
        flex-wrap: wrap;
    }
    .profile-picture-container {
        width: 80%;
        max-width: 280px;
    }
    .profile-picture-container.deceased-indicator::after {
        border-width: 30px 30px 0 0;
    }
    .profile-header .bio-details {
        width: 100%;
        text-align: center;
    }
    .profile-header .bio-details strong {
        display: block;
        margin-bottom: 2px;
        min-width: 0;
        width: auto;
        margin-right: 0;
        text-align: center;
    }
    .bio-details p.visual-desc-detail {
        text-align: center;
    }
    /* Pfeilnavigation etwas kleiner */
    .profile-nav-arrows a {
        font-size: 2rem;
        padding: 0.75rem 0.5rem;
    }
    .profile-nav-prev { left: 0.3125rem; }
    .profile-nav-next { right: 0.3125rem; }

     /* Profilübersicht Controls weiter anpassen */
    .profile-view-controls > div {
        flex-wrap: wrap;
        justify-content: center;
    }

    /* Login-Box Padding reduzieren */
    .login-container {
         padding: 1.5rem 1.5rem;
    }
} /* Ende @media (max-width: 600px) */
