/* Startseiten-Boxen „Beste/Beliebteste Reiseziele" (dest-reco.js, home-reco/home-popular).
   Gleicher Farbcode wie die Ergebnisseiten: Marken-Tokens (--brand-dark), Rahmen #ddd,
   Badges = Preis-Chip-Farben (grün/orange). Volle Inhaltsbreite. */

.reco { width: 100%; margin: 34px 0 0; }

.reco-head { margin: 0 0 12px; }
.reco-title { font-size: 18px; font-weight: 700; color: var(--brand-dark, #003663); margin: 0; }
.reco-sub { font-size: 13px; color: var(--gray-text, #666); margin: 3px 0 0; }

/* Monats-Reiter */
.reco-months { display: flex; flex-wrap: wrap; gap: 6px; margin: 0 0 10px; }
.reco-month {
  font: inherit; font-size: 13px; padding: 5px 10px; border-radius: 4px;
  border: 1px solid var(--gray-border, #ddd); background: #fff; color: #444; cursor: pointer;
}
.reco-month:hover { border-color: var(--brand-dark, #003663); color: var(--brand-dark, #003663); }
.reco-month.is-active {
  background: var(--brand-dark, #003663); border-color: var(--brand-dark, #003663);
  color: #fff; font-weight: 700;
}
.reco-month--outlook { border-style: dashed; color: #9aa1ac; }
.reco-month--outlook.is-active { background: var(--gray-text, #666); border-color: var(--gray-text, #666); color: #fff; }

/* Kategorie-Chips */
.reco-cats { display: flex; flex-wrap: wrap; gap: 6px; margin: 0 0 14px; }
.reco-cat {
  font: inherit; font-size: 13px; padding: 5px 13px; border-radius: 4px;
  border: 1px solid var(--gray-border, #ddd); background: #fff; color: #444; cursor: pointer;
}
.reco-cat:hover { border-color: var(--brand-dark, #003663); color: var(--brand-dark, #003663); }
.reco-cat.is-active {
  background: #e7eef4; border-color: var(--brand-dark, #003663);
  color: var(--brand-dark, #003663); font-weight: 700;
}

/* Karten-Raster — 4 Spalten auf Desktop (12 Karten = 3 saubere Reihen) */
.reco-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 10px; }
.reco-cards.is-loading { opacity: .5; }
.reco-card {
  display: block; padding: 11px 13px; border: 1px solid var(--gray-border, #ddd); border-radius: 4px;
  background: #fff; text-decoration: none; color: var(--home-text, #1a1f2e);
}
.reco-card:hover { border-color: var(--brand-dark, #003663); box-shadow: 0 1px 4px rgba(0, 54, 99, .12); }
.reco-card-top { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; }
.reco-city { font-size: 15px; font-weight: 700; flex: 0 1 auto; min-width: 0; }
.reco-loc { font-size: 11px; color: #9aa1ac; white-space: nowrap; flex: 0 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.reco-wx { font-size: 13px; color: var(--gray-text, #666); margin: 6px 0 10px; }
.reco-card-bot { display: flex; align-items: center; justify-content: space-between; gap: 8px; }

/* Erreichbarkeits-Badges = Preis-Chip-Farben der Ergebnisseiten */
.reco-badge { font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 4px; }
.reco-badge--direct { background: #e4f7e7; color: #1f7a33; }
.reco-badge--conn { background: #fff1db; color: #9a5a00; }
.reco-badge--outlook { background: #eef0f3; color: var(--gray-text, #666); }
.reco-price { font-size: 14px; font-weight: 700; color: var(--brand-dark, #003663); }

.reco-empty { font-size: 14px; color: var(--gray-text, #666); grid-column: 1 / -1; margin: 4px 0; }

.reco-all {
  display: inline-block; margin: 14px 0 0; font-size: 13px; font-weight: 700;
  color: var(--brand-dark, #003663); text-decoration: none;
}
.reco-all:hover { text-decoration: underline; }
