/* ==========================================================================
   site-content.css — Tema uyarlama katmanı
   tema/site mockup'ındaki .ph placeholder kutuları gerçek <img> ile dolduruldu.
   Görseller placeholder ile aynı sınıfları (.ph, .ph.r169, .ph.big, .ph.circ ...)
   kullanır; bu dosya yalnızca <img class="ph"> öğelerinin kutuyu doğru
   doldurmasını sağlar. style.css'e dokunmadan üstüne yüklenir.
   ========================================================================== */

/* Görseller genişliği doldurur; yükseklik kapsayıcının kuralından gelir
   (sabit px veren .ph kuralları veya aspect-ratio). height:auto kritik:
   aksi halde aspect-ratio ile boyutlanan kutularda görsel çöker. */
/* Sistem geneli yazı tipi — haber/gazete tarzı:
   gövde Roboto (--font-sans, style.css'i override eder), başlıklar Roboto Slab (--font-serif). */
:root {
  --font-sans: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --font-serif: "Roboto Slab", Georgia, "Times New Roman", serif;
}

/* Başlıklar serif (manşet, kart, bölüm başlıkları — hepsi h1–h6 etiketi).
   Tema başlıklara font-family vermiyordu; bu kural gövdeden ayırır. */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
}

/* ==========================================================================
   Ana menü (#mainnav): üst çizgi + aktif sayfa ::selection rengini alır
   ========================================================================== */
/* Üstte de çizgi (tema yalnızca alt çizgi veriyordu) */
#mainnav {
  border-top: 1px solid var(--border);
}
/* Yazarlar ilk öğe; tema ona her zaman marka rengi veriyordu (her sayfada kırmızı
   görünüyordu). Varsayılanı normal metne çek — yalnızca aktifken renklensin. */
#mainnav li:first-child a {
  color: var(--text);
}
/* Aktif menü öğesi: kırmızı vurgu (ilk öğe geçersiz kılınımından SONRA gelmeli ki kazansın) */
#mainnav li a.active {
  color: #ed0d0d;
  border-radius: 4px;
}

img.ph {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

/* ==========================================================================
   İkon uyum katmanı — Material Symbols (<x-bi>)
   Material ikonları DOLU (fill) ikonlardır; renk `fill:currentColor` ile gelir.
   Tema (style.css) bazı bağlamlarda svg'ye `fill:none;stroke:...` veriyordu (çizgi
   ikon varsayımı) → bu Material'ı görünmez yapardı. Aşağıdaki kurallar dolguyu geri
   açar ve temanın `stroke` ile verdiği rengi `fill`e taşır. Marka ikonları (.bi-brand)
   hariç tutulur (kendi 16x16 dolu logoları). Özgüllük (0,2,1) > tema `.x svg` (0,1,1). */
svg.bi:not(.bi-brand) { fill: currentColor; stroke: none; }
/* Marka rengi gereken bağlamlar (tema fill/stroke ile var(--brand) veriyordu) */
.yanpanel-bilgi-ikon svg.bi,
.uy-benefit-ico svg.bi,
.bulten-vitrin-ikon svg.bi,
.galerigoster-ustetiket svg.bi,
.konum-sec svg.bi,
.mb-badge svg.bi { fill: var(--brand); }
/* Beyaz (renkli zemin üstü) bağlamlar */
.video-oynat svg.bi,
.video-rozet svg.bi,
.galeri-sayi svg.bi,
.roportaj-etiket svg.bi,
.galeridetay-ustetiket svg.bi,
.mb-card-bookmark svg.bi { fill: #fff; }

/* Sabit en/boy (px) veren kutularda görselin kutuyu tam doldurması için
   object-fit zaten yukarıda; ekstra yükseklik gerekmiyor. */

/* ==========================================================================
   Sonsuz kaydırma — alta eklenen haberler (haber-sonsuz.js)
   ========================================================================== */
/* Haberler arası ayraç (kalın yumuşak çizgi) */
.sonsuz-ayrac {
  margin: 2.25rem 0;
  border: 0;
  border-top: 8px solid var(--border);
  opacity: .5;
}
.sonsuz-eklendi { scroll-margin-top: 80px; }
.sonsuz-son {
  text-align: center;
  color: var(--text-secondary);
  padding: 2.5rem 1rem 1.5rem;
  font-size: .95rem;
}

/* Sidebar "Sıradaki Haberler" listesi kaydırırken görünür kalsın (tema sticky offseti) */
.haber-siradaki {
  position: sticky;
  top: calc(var(--header-h) + 50px);
}

/* ==========================================================================
   Yazar sidebar modülü (.yazar-yan) — Popüler/Diğer Yazarlar + Yazarın Diğer Yazıları
   ========================================================================== */
.yazar-yan {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: .9rem 1rem 1rem;
  margin-bottom: 1.25rem;
  background: var(--surface, #fff);
}
.yazar-yan--yapiskan {
  position: sticky;
  top: calc(var(--header-h) + 50px);
}
.yazar-yan-baslik {
  font-size: 1.05rem;
  font-weight: 700;
  margin: 0 0 .75rem;
  padding-bottom: .55rem;
  border-bottom: 2px solid var(--brand);
}
.yazar-yan-liste {
  display: flex;
  flex-direction: column;
}
.yazar-yan-oge {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .55rem 0;
  border-top: 1px solid var(--border);
  color: var(--text);
}
.yazar-yan-oge:first-child { border-top: 0; }
.yazar-yan-av {
  flex: 0 0 44px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--border);
}
.yazar-yan-bilgi {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.yazar-yan-ad {
  font-weight: 700;
  font-size: .92rem;
  line-height: 1.25;
}
.yazar-yan-oge:hover .yazar-yan-ad { color: var(--brand); }
.yazar-yan-meta {
  font-size: .8rem;
  color: var(--text-secondary);
  line-height: 1.3;
  margin-top: .15rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.yazar-yan-oge--metin { align-items: flex-start; }

/* ==========================================================================
   Biyografiler — editöryal liste (portre + alan + ad + künye + alıntı + özet)
   ========================================================================== */
.biyo-liste { display: flex; flex-direction: column; gap: 2.25rem; margin-top: 1.5rem; }
.biyo-satir {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 1.75rem;
  align-items: start;
  padding-bottom: 2.25rem;
  border-bottom: 1px solid var(--border);
}
.biyo-satir:last-child { border-bottom: 0; padding-bottom: 0; }
/* dönüşümlü: çift satırlarda portre sağda */
.biyo-satir:nth-child(even) { grid-template-columns: 1fr 240px; }
.biyo-satir:nth-child(even) .biyo-portre { order: 2; }
.biyo-portre {
  display: block;
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  background: var(--border);
}
.biyo-portre img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.biyo-portre:hover img { transform: scale(1.04); }
.biyo-icerik { min-width: 0; }
.biyo-alan {
  display: inline-block;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #fff;
  background: var(--brand);
  padding: .25rem .6rem;
  border-radius: 4px;
  margin-bottom: .6rem;
}
.biyo-ad { font-size: clamp(1.5rem, 3vw, 2.1rem); line-height: 1.12; margin: 0 0 .35rem; }
.biyo-ad a { color: var(--text); }
.biyo-ad a:hover { color: var(--brand); }
.biyo-kunye { font-size: .9rem; color: var(--text-secondary); font-weight: 600; margin-bottom: .9rem; }
.biyo-alinti {
  margin: 0 0 .9rem;
  padding: .1rem 0 .1rem 1.1rem;
  border-left: 3px solid var(--brand);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1.5;
  color: var(--text);
}
.biyo-ozet {
  color: var(--text-secondary);
  line-height: 1.7;
  margin: 0 0 1rem;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.biyo-oku { font-weight: 700; color: var(--brand); }
.biyo-oku:hover { text-decoration: underline; }
.biyo-bos { color: var(--text-secondary); padding: 2rem 0; }
/* öne çıkan satır — daha büyük portre + alıntı */
.biyo-one { grid-template-columns: 340px 1fr; gap: 2.25rem; }
.biyo-one .biyo-ad { font-size: clamp(1.9rem, 4vw, 2.7rem); }
.biyo-one .biyo-alinti { font-size: 1.3rem; }
.biyo-one .biyo-ozet { -webkit-line-clamp: 6; }

/* alt şerit — en çok okunan biyografiler */
.biyo-populer { margin-top: 3rem; padding-top: 1.5rem; border-top: 2px solid var(--border); }
.biyo-populer-izgara {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 1.25rem;
  margin-top: 1rem;
}
.biyo-populer-kart { display: block; }
.biyo-populer-kart figure { margin: 0 0 .5rem; border-radius: 8px; overflow: hidden; aspect-ratio: 3 / 4; }
.biyo-populer-kart .ph { width: 100%; height: 100%; object-fit: cover; }
.biyo-populer-ad { display: block; font-weight: 700; font-size: .95rem; line-height: 1.25; color: var(--text); }
.biyo-populer-kart:hover .biyo-populer-ad { color: var(--brand); }
.biyo-populer-alan { display: block; font-size: .75rem; color: var(--text-secondary); margin-top: .15rem; }

@media (max-width: 700px) {
  .biyo-satir, .biyo-satir:nth-child(even), .biyo-one { grid-template-columns: 1fr; gap: 1rem; }
  .biyo-satir:nth-child(even) .biyo-portre { order: 0; }
  .biyo-portre { max-width: 240px; aspect-ratio: 1 / 1; }
}

/* Çok okunanlar / sıradaki haberler listesi üstte boşluk bırakmasın */
.haber-populer {
  margin-top: 0;
}

/* ==========================================================================
   Header şehir seçici — aranabilir + boyutu kısıtlı özel açılır liste
   (native <select id="hxCity"> JS ile gizlenir; değer/change işlevsel kalır)
   ========================================================================== */
/* Mobilde menü (hamburger) butonu en sağda, sağdaki ikonların sağında dursun */
@media (max-width: 768px) {
  .ustbilgi-cubuk .menu-ac {
    order: 9;            /* logo ve header-actions order:0 → nav-toggle en sona */
    margin-right: 0;
    margin-left: .85rem;
  }
}

.hx-city-native { display: none; }
.hava-sehir-etiket {
  font-size: .85rem;
  font-weight: 700;
  color: var(--text);
  cursor: pointer;
  white-space: nowrap;
  padding-right: 15px;          /* sağdaki absolute caret'e yer aç */
  user-select: none;
}
.hava-sehir-acilir {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 1200;
  width: 200px;                 /* GENİŞLİK kısıtlı */
  max-width: 80vw;
  background: var(--surface, #fff);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 10px 28px rgba(0, 0, 0, .16);
  padding: 6px;
  display: none;
}
.hava-sehir-acilir.open { display: block; }
.hava-sehir-ara {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: .42rem .6rem;
  font: inherit;
  font-size: .85rem;
  color: var(--text);
  background: var(--surface, #fff);
  margin-bottom: 6px;
}
.hava-sehir-ara:focus { outline: none; border-color: var(--brand); }
.hava-sehir-liste {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 240px;            /* YÜKSEKLİK kısıtlı + kaydırma */
  overflow-y: auto;
}
.hava-sehir-secenek {
  padding: .42rem .6rem;
  border-radius: 7px;
  cursor: pointer;
  font-size: .875rem;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hava-sehir-secenek:hover { background: var(--brand); color: #fff; }
.hava-sehir-secenek.selected { color: var(--brand); font-weight: 800; }
.hava-sehir-secenek.selected:hover { color: #fff; }
.hava-sehir-secenek[hidden] { display: none; }
/* Offcanvas (mobil) seçicide etiket, kendi select boyutuyla uyumlu olsun */
.yanpanel-bilgi-sehir .hava-sehir-etiket {
  font-size: .95rem;
  font-weight: 800;
  padding-right: 16px;
}
/* Offcanvas paneli içinde popup geniş ekrana sığsın ve YUKARI doğru açılsın */
.yanpanel-bilgi-sehir .hava-sehir-acilir {
  width: 240px;
  top: auto;
  bottom: calc(100% + 8px);
}

/* ==========================================================================
   En Çok Okunan Haberler — sekmeler (Bugün/Bu Hafta/Trend) + sıra rozetli kartlar
   ========================================================================== */
.cokokunan-ust {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .4rem .75rem;
}
.cokokunan-ust .bolum-baslik { margin-bottom: .5rem; }
.cokokunan-sekmeler { display: inline-flex; gap: .35rem; flex-wrap: wrap; }
.cokokunan-sekme {
  font: inherit;
  font-size: .85rem;
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--surface, #fff);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: .35rem .9rem;
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.cokokunan-sekme:hover { color: var(--brand); border-color: var(--brand); }
.cokokunan-sekme.active { background: var(--brand); border-color: var(--brand); color: #fff; }
.cokokunan-icerik { margin-top: 1rem; }
.cokokunan-icerik.eco-loading { opacity: .45; pointer-events: none; transition: opacity .15s ease; }
.cokokunan-bos { width: 100%; padding: 2rem 1rem; text-align: center; color: var(--text-secondary); }
/* sıra rozeti — görselin sol üstünde numara */
.cokokunan-kart figure { position: relative; }
.cokokunan-sira {
  position: absolute;
  top: .5rem;
  left: .5rem;
  min-width: 1.7rem;
  height: 1.7rem;
  padding: 0 .45rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--brand);
  color: #fff;
  font-size: .9rem;
  font-weight: 800;
  line-height: 1;
  border-radius: 7px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .28);
}

/* Haber içeriği (CKEditor / icerik HTML) — görseller taşmasın */
.haber-govde img:not(.ph) {
  max-width: 100%;
  height: auto;
  border-radius: 2px;
}

.haber-govde iframe {
  max-width: 100%;
}

/* Sayfa içeriği (statik sayfalar) */
.sayfa-icerik img {
  max-width: 100%;
  height: auto;
}

/* ==========================================================================
   Reklam alanları — [reklam-KOD] token'ı ReplaceAdPlaceholders ile doldurulur.
   Reklam yoksa kutu boş kalır ve gizlenir (boş "REKLAM" çerçevesi olmaz).
   ========================================================================== */
.reklam-alani {
  margin: 1.5rem 0;
  text-align: center;
  line-height: 0;
}
.reklam-alani:empty {
  display: none !important;
  margin: 0;
}
.reklam-alani img {
  max-width: 100%;
  height: auto;
}
.reklam-alani a {
  display: inline-block;
  line-height: 0;
}
/* geniş masthead reklamı (970×90) — ortalanır */
.reklam-masthead {
  max-width: 970px;
  margin-left: auto;
  margin-right: auto;
}
/* içerik içi reklam */
.reklam-inline {
  margin: 1.25rem 0;
}
/* sidebar / dikdörtgen reklam (300×250, 300×600) */
.reklam-rect {
  margin: 0 0 1.5rem;
}
/* İçeriği kalmayan (yalnızca boş reklamdan ibaret olup o da kaldırılan) sidebar
   boş sütun bırakmasın. Boş reklam sarmalayıcısı middleware'de tamamen silinir. */
.video-kenar:empty,
.galeri-kenar:empty,
.kategori-kenar:empty,
.haber-kenarcubuk:empty {
  display: none !important;
}
