

/* RESPONSIVE → Content (gesamte Seitenstruktur) */

@media (max-width: 768px) {
  .wrap {
    flex-direction: column;
    gap: 1rem;
  }

  .flex-left,
  .flex-right {
    flex: 1 1 100%; /* volle Breite */
    width: 100%;
    max-width: 100%;
    min-width: 0;   /* verhindert Überlauf → wichtiger, oft vergessener Trick! */
  }

  #world-map,
  #world-top10,
  #song-top10 {
    display: none;
  }

  /* RESPONSIVE → TABLE.php */

  table {
    width: 100%;
    border-collapse: collapse;
  }

  thead {
    display: none; /* Kopfzeile ausblenden */
  }

  tbody tr {
    display: block;
    margin-bottom: 1rem;
    border-radius: 6px;
    padding: 12px;
    background: var(--color-bg-table-card);
    border: 1px solid #e0e0e0;
  }

  tbody td {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 1rem;
    text-align: left;
    border: none;
    align-items: center;
    width: 100%;
  }

  tbody td::before {
    content: attr(data-label);
    font-weight: 500;
    text-transform: capitalize;
    color: var(--color-text-secondary, var(--color-text));
  }

  tbody td.table-no-entries {
    grid-template-columns: 1fr;  /* nur eine Spalte */
    justify-items: start;        /* Inhalt linksbündig */
    padding: 0.75rem;            /* etwas Luft wie bei normalen Zellen */
  }

  tbody td.table-no-entries::before {
    content: none;               /* kein Label */
  }

  td[data-label="Info"] .info-cell {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    white-space: nowrap;
  }

  /* 🔒 City-Text soll als ein Block behandelt werden und nicht umbrechen */
  td[data-label="City"] .city-cell {
    display: inline-block;
    white-space: nowrap;
  }

  /* RESPONSIVE → Charts Era */

  .chart-wrapper.era {
    height: 380px;
  }

  /* RESPONSIVE → Charts Donut */

  .setlist-chart__container {
    flex-wrap: wrap;
  }

  .setlist,
  .chart-wrapper.donut {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .donut-canvas {
    width: 100%;
    height: auto;
  }

  /* RESPONSIVE → Prev & Next Buttons */

  .prev-next-nav {
    flex-direction: column;
    align-items: stretch;
    gap: 1.25rem;
  }

  .prev-next-nav a,
  .nav-placeholder {
    width: 100%;
    min-width: unset; /* entfernt feste Mindestbreite */
  }

  /* ⚙️ RESPONSIVE → Floating Settings Panel */

  .settings-panel {
    left: auto;
    right: 1rem;
    bottom: 70px;
    width: 90vw;
    z-index: 1000;
  }

  /* RESPONSIVE → Tabbed List (Unterseiten) */

  .tabbed-list {
    padding: 0 0.8rem;
  }

  /* === RESPONSIVE → Footer === */

  footer .inner {
    flex-direction: column;
    gap: 2rem; /* 2rem Abstand zwischen allen Segmenten */
  }

  footer .footer-segment {
    flex: 1 1 100%;
    min-width: 100%;
    text-align: center;
  }

  /* === RESPONSIVE → Table Controls === */

  .table-controls {
    gap: 1.25rem;
    margin: 30px 0 20px;
  }

  /* Obere Zeile: Show Entries & Select Year */
  .controls-top {
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
  }

  /* Dropdown-Wrapper */
  .show-entries,
  .era-filter {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
    gap: 0.35rem;
  }

  /* Dropdowns */
  #entries,
  #era-filter {
    width: 100%;
    margin-left: 0;
  }

  .search-block {
    display: none;
  }

}






/* 🟢📱 Queries for Tablets und Smartphones */

@media (max-width: 480px) {
  .member-grid-top,
  .member-grid {
    grid-template-columns: repeat(2, minmax(120px, 1fr));
    gap: 1rem;
    width: 100%;
    justify-content: center;
  }
}

/* Floating Panel for Smartphones */
@media (max-width: 480px) {
  .settings-float {
    left: 1rem; /* ganzer Block (Button + Menü) */
    bottom: 2rem;
  }
  .settings-panel {
    left: 1rem; /* nur Menü (nicht das Zahnrad) */
    bottom: calc(2rem + 56px + 1.25rem);
    max-width: 90vw;
  }
}

/* Tablets (577px–1024px) */

@media (min-width: 577px) and (max-width: 1024px) {
  #modal-img-prev:focus,
  #modal-img-next:focus {
    outline: none;
    background-color: transparent;
  }
}

/* Kleine Bildschirme / Mobile */

@media (max-width: 640px) {
  #modal-img-box {
    width: 90%;
    max-height: 90vh;
    height: 90vh;
  }
}

@media (max-width: 640px) {
  .tabbed-list {
    --tab-secondary-text-color: #334155; /* kräftiger als #475569 */
  }
}

/* dl dd dt elemente */

@media (max-width: 640px) {
  dl.dl-meta {
    grid-template-columns: 1fr; /* 1 Spalte */
  }

  dl.dl-meta dt {
    grid-column: 1;
  }

  dl.dl-meta dd {
    grid-column: 1;
    padding-left: 0.625rem; /* kleine optische Einrückung */
  }
}

/* Hover-Effekte nur für Desktop */
@media (hover: hover) and (pointer: fine) {
  .modal-img-nav button:hover,
  .modal-img-nav button:hover svg,
  #modal-img-close:hover .close-icon,
  #modal-img-close:hover .close-icon svg {
    transform: scale(1.1);
    background: none;
  }

  .modal-img-nav button:hover {
    color: #000;
  }
}

