
/* ===== press.css ===== */

.press-hero {
    position: relative;
    z-index: auto;
    background: linear-gradient(to bottom, #fafafa, #f0f0f0);
    padding-bottom: 2rem;
}

.press-doc-list {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

/* ===== Pressedokumente: DE + EN nebeneinander ===== */

.press-doc-card {
    display: flex;
    align-items: flex-start;
    background: white;
    padding: 1.4rem;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    gap: 1.5rem;
}

.press-doc-text {
  flex: 1 1 auto;      /* füllt die linke Seite */
  min-width: 0;
}

.press-doc-side {
  flex: 0 0 160px;     /* schmale rechte Spalte */
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}

.press-preview img {
  width: 100%;
  border-radius: 6px;
  box-shadow: var(--shadow);
  cursor: pointer;
}

.press-doc-card #media-tracks {
  display: flex;
  justify-content: center;
  margin-top: 1.5rem;
}

.press-doc-card .media-track {
  width: min(720px, 100%);
}

.press-doc-download {
  align-self: center;   /* Layout-Hilfe in der Card */
}

.press-doc-download.btn.small {
  padding: 0.35rem 0.6rem;
}

/* ===== Mobile ===== */
@media (max-width: 640px) {

  /* Card darf umbrechen: erst Text volle Breite, darunter 2 Sprachen nebeneinander */
  .press-doc-card{
    flex-wrap: wrap;           /* statt nur row/column */
    align-items: flex-start;
    gap: 1rem;
  }

  /* Text immer volle Breite → keine schmale „Zeitungs-Spalte“ mehr */
  .press-doc-text{
    flex: 1 1 100%;
    min-width: 0;              /* wichtig gegen komisches Überlaufen */
  }

  /* Sprach-Spalten: 2 nebeneinander */
  .press-doc-side{
    flex: 1 1 calc(50% - 0.5rem);
    max-width: calc(50% - 0.5rem);
    min-width: 0;
    align-self: flex-start;
  }

  /* Button/Preview sauber zentrieren */
  .press-doc-download{
    display: inline-flex;
    justify-content: center;
    width: auto;
    align-self: stretch;
    margin: 0;                 /* falls irgendwo Margin gesetzt wurde */
  }
}

@media (display-mode: standalone) {

  .press-doc-download.is-disabled {
    opacity: 0.45;
    cursor: not-allowed;
    background: #bbb !important;

    position: relative;   /* 🔑 Pflicht */
    user-select: none;    /* 🔑 Text nicht markierbar */
  }

  .press-doc-download.is-disabled::after {
    content: "PDF-Download im App-Modus nicht verfügbar";
    position: absolute;
    bottom: 100%;
    margin-bottom: 0.35rem;
    left: 50%;
    transform: translateX(-50%);

    font-size: 0.65rem;
    white-space: nowrap;
    
    background: rgba(0,0,0,0.85);  /* 🔑 fehlte */
    color: #fff;                   /* 🔑 fehlte */
    padding: 0.25rem 0.45rem;
    border-radius: 4px;

    opacity: 0;
    transition: opacity 0.25s ease;
    pointer-events: none;
    z-index: 1000;              
  }

  .press-doc-download.is-disabled.show-hint::after {
    opacity: 1;
  }

  .press-preview img{
    width: 100%;
    height: auto;
    display: block;
  }

  .press-preview,
  .res-thumb.plakat {
    width: 160px;
  }
  
}

.press-gallery {
  background: #f3f3f3;
}

.press-grid {
  padding-top: 0.5rem;
}

.press-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.4rem;
    margin-top: 1.5rem;
}

.press-card {
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    background: white;
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);
}

.press-card:hover {
  transform: translateY(-2px);
}

.press-card img {
    width: 100%;
    height: 180px;
    object-fit: cover;
}

@media (max-width: 760px) {
    .press-card img {
        height: 220px;
    }
}

.press-card-body {
    padding: 1rem;
}

.press-card-download {
    color: var(--accent);
    font-size: 0.85rem;
}

.press-logo-row {
    display: flex;
    justify-content: center;
    gap: 3rem;
    flex-wrap: wrap;
    margin-top: 2rem;
}

.press-logo-item {
    text-align: center;
}

.press-logo-item img {
    max-height: 80px;
    object-fit: contain;
}

.press-logo-item-active {
    text-align: center;
}

.press-logo-item-active img {
    max-height: 80px;
    object-fit: contain;
}

.press-logo-item-active:hover {
  transform: scale(1.03);
}

.press-partners {
    text-align: center;
}

.press-hero,
.press-docs,
.press-gallery,
.press-partners {
  background: #f3f3f3;
}
